{
  "instance_id": "django__django-13660",
  "repo": "django/django",
  "created_at": "2020-11-09T22:43:32Z",
  "problem_statement": "shell command crashes when passing (with -c) the python code with functions.\nDescription\n\t\nThe examples below use Python 3.7 and Django 2.2.16, but I checked that the code is the same on master and works the same in Python 3.8.\nHere's how ​python -c works:\n$ python -c <<EOF \" \nimport django\ndef f():\n\t\tprint(django.__version__)\nf()\"\nEOF\n2.2.16\nHere's how ​python -m django shell -c works (paths shortened for clarify):\n$ python -m django shell -c <<EOF \"\nimport django\ndef f():\n\t\tprint(django.__version__)\nf()\"\nEOF\nTraceback (most recent call last):\n File \"{sys.base_prefix}/lib/python3.7/runpy.py\", line 193, in _run_module_as_main\n\t\"__main__\", mod_spec)\n File \"{sys.base_prefix}/lib/python3.7/runpy.py\", line 85, in _run_code\n\texec(code, run_globals)\n File \"{sys.prefix}/lib/python3.7/site-packages/django/__main__.py\", line 9, in <module>\n\tmanagement.execute_from_command_line()\n File \"{sys.prefix}/lib/python3.7/site-packages/django/core/management/__init__.py\", line 381, in execute_from_command_line\n\tutility.execute()\n File \"{sys.prefix}/lib/python3.7/site-packages/django/core/management/__init__.py\", line 375, in execute\n\tself.fetch_command(subcommand).run_from_argv(self.argv)\n File \"{sys.prefix}/lib/python3.7/site-packages/django/core/management/base.py\", line 323, in run_from_argv\n\tself.execute(*args, **cmd_options)\n File \"{sys.prefix}/lib/python3.7/site-packages/django/core/management/base.py\", line 364, in execute\n\toutput = self.handle(*args, **options)\n File \"{sys.prefix}/lib/python3.7/site-packages/django/core/management/commands/shell.py\", line 86, in handle\n\texec(options['command'])\n File \"<string>\", line 5, in <module>\n File \"<string>\", line 4, in f\nNameError: name 'django' is not defined\nThe problem is in the ​usage of ​exec:\n\tdef handle(self, **options):\n\t\t# Execute the command and exit.\n\t\tif options['command']:\n\t\t\texec(options['command'])\n\t\t\treturn\n\t\t# Execute stdin if it has anything to read and exit.\n\t\t# Not supported on Windows due to select.select() limitations.\n\t\tif sys.platform != 'win32' and not sys.stdin.isatty() and select.select([sys.stdin], [], [], 0)[0]:\n\t\t\texec(sys.stdin.read())\n\t\t\treturn\nexec should be passed a dictionary containing a minimal set of globals. This can be done by just passing a new, empty dictionary as the second argument of exec.\n",
  "patch": "diff --git a/django/core/management/commands/shell.py b/django/core/management/commands/shell.py\n--- a/django/core/management/commands/shell.py\n+++ b/django/core/management/commands/shell.py\n@@ -84,13 +84,13 @@ def python(self, options):\n     def handle(self, **options):\n         # Execute the command and exit.\n         if options['command']:\n-            exec(options['command'])\n+            exec(options['command'], globals())\n             return\n \n         # Execute stdin if it has anything to read and exit.\n         # Not supported on Windows due to select.select() limitations.\n         if sys.platform != 'win32' and not sys.stdin.isatty() and select.select([sys.stdin], [], [], 0)[0]:\n-            exec(sys.stdin.read())\n+            exec(sys.stdin.read(), globals())\n             return\n \n         available_shells = [options['interface']] if options['interface'] else self.shells\n",
  "similar_bug_items": [
    {
      "pr_number": 11886,
      "pr_title": "Fixed #30405 -- Fixed source code mismatch crash in ExceptionReporter. ",
      "pr_body": "[ticket 30405](https://code.djangoproject.com/ticket/30405)",
      "issue_id": 30405,
      "issue_title": "IndexError in _get_lines_from_file when module does not match file contents (via loader)",
      "issue_body": "self = <django.views.debug.ExceptionReporter object at 0x7f2a7908ac18>\nfilename = '…/project/.venv/lib/python3.7/site-packages/pdb.py'\nlineno = 230\ncontext_lines = 7\nloader = <_frozen_importlib_external.SourceFileLoader object at 0x7f2a73609278>\nmodule_name = 'pdb'\n\n[23]   …/Vcs/django/django/core/handlers/exception.py(90)response_for_exception()\n-> response = handle_uncaught_exception(request, get_resolver(get_urlconf()), sys.exc_info())\n[24]   …/Vcs/django/django/core/handlers/exception.py(125)handle_uncaught_exception()\n-> return debug.technical_500_response(request, *exc_info)\n[25]   …/Vcs/django/django/views/debug.py(94)technical_500_response()\n-> html = reporter.get_traceback_html()\n[26]   …/Vcs/django/django/views/debug.py(333)get_traceback_html()\n-> c = Context(self.get_traceback_data(), use_l10n=False)\n[27]   …/Vcs/django/django/views/debug.py(264)get_traceback_data()\n-> frames = self.get_traceback_frames()\n[28]   …/Vcs/django/django/views/debug.py(427)get_traceback_frames()\n-> filename, lineno, 7, loader, module_name,\n\n 385             try:\n 386                 context_line = source[lineno]\n 387             except:\n 388                 __import__('pdb').set_trace()\n 389  ->         post_context = source[lineno + 1:upper_bound]\n 390\n 391             return lower_bound, pre_context, context_line, post_context\n(Pdb++) source\n['# this file is needed to hijack pdb without eggs', 'import os.path', \"pdb_path = os.path.join(os.path.dirname(os.path.dirname(__file__)), 'pdb.py')\", 'with open(pdb_path) as f:', \"    exec(compile(f.read(), pdb_path, 'exec'))\"]\nIt uses the loader (\n​\nhttps://github.com/django/django/blob/47885278c669dd7a13a4c3ff7e58e1cbe88af385/django/views/debug.py#L351\n), which picks up the\npth\n, and then the contents does not match the expected line number.\nI think it should maybe always use the given filename?!",
      "issue_closed_at": "2019-11-12T04:53:04",
      "base_commit": "6e2f05b2e33a6c80c7a411ce76af7b5a08acb835",
      "changes": [
        {
          "file": "django/views/debug.py",
          "type": "function",
          "name": "get_traceback_text",
          "class_name": "ExceptionReporter",
          "code": "def get_traceback_text(self):\n        \"\"\"Return plain text version of debug 500 HTTP error page.\"\"\"\n        with Path(CURRENT_DIR, 'templates', 'technical_500.txt').open(encoding='utf-8') as fh:\n            t = DEBUG_ENGINE.from_string(fh.read())\n        c = Context(self.get_traceback_data(), autoescape=False, use_l10n=False)\n        return t.render(c)"
        },
        {
          "file": "django/views/debug.py",
          "type": "function",
          "name": "_get_lines_from_file",
          "class_name": "ExceptionReporter",
          "code": "def _get_lines_from_file(self, filename, lineno, context_lines, loader=None, module_name=None):\n        \"\"\"\n        Return context_lines before and after lineno from file.\n        Return (pre_context_lineno, pre_context, context_line, post_context).\n        \"\"\"\n        source = None\n        if hasattr(loader, 'get_source'):\n            try:\n                source = loader.get_source(module_name)\n            except ImportError:\n                pass\n            if source is not None:\n                source = source.splitlines()\n        if source is None:\n            try:\n                with open(filename, 'rb') as fp:\n                    source = fp.read().splitlines()\n            except OSError:\n                pass\n        if source is None:\n            return None, [], None, []\n\n        # If we just read the source from a file, or if the loader did not\n        # apply tokenize.detect_encoding to decode the source into a\n        # string, then we should do that ourselves.\n        if isinstance(source[0], bytes):\n            encoding = 'ascii'\n            for line in source[:2]:\n                # File coding may be specified. Match pattern from PEP-263\n                # (https://www.python.org/dev/peps/pep-0263/)\n                match = re.search(br'coding[:=]\\s*([-\\w.]+)', line)\n                if match:\n                    encoding = match.group(1).decode('ascii')\n                    break\n            source = [str(sline, encoding, 'replace') for sline in source]\n\n        lower_bound = max(0, lineno - context_lines)\n        upper_bound = lineno + context_lines\n\n        pre_context = source[lower_bound:lineno]\n        context_line = source[lineno]\n        post_context = source[lineno + 1:upper_bound]\n\n        return lower_bound, pre_context, context_line, post_context"
        },
        {
          "file": "django/views/debug.py",
          "type": "function",
          "name": "_get_lines_from_file",
          "class_name": "ExceptionReporter",
          "code": "def _get_lines_from_file(self, filename, lineno, context_lines, loader=None, module_name=None):\n        \"\"\"\n        Return context_lines before and after lineno from file.\n        Return (pre_context_lineno, pre_context, context_line, post_context).\n        \"\"\"\n        source = None\n        if hasattr(loader, 'get_source'):\n            try:\n                source = loader.get_source(module_name)\n            except ImportError:\n                pass\n            if source is not None:\n                source = source.splitlines()\n        if source is None:\n            try:\n                with open(filename, 'rb') as fp:\n                    source = fp.read().splitlines()\n            except OSError:\n                pass\n        if source is None:\n            return None, [], None, []\n\n        # If we just read the source from a file, or if the loader did not\n        # apply tokenize.detect_encoding to decode the source into a\n        # string, then we should do that ourselves.\n        if isinstance(source[0], bytes):\n            encoding = 'ascii'\n            for line in source[:2]:\n                # File coding may be specified. Match pattern from PEP-263\n                # (https://www.python.org/dev/peps/pep-0263/)\n                match = re.search(br'coding[:=]\\s*([-\\w.]+)', line)\n                if match:\n                    encoding = match.group(1).decode('ascii')\n                    break\n            source = [str(sline, encoding, 'replace') for sline in source]\n\n        lower_bound = max(0, lineno - context_lines)\n        upper_bound = lineno + context_lines\n\n        pre_context = source[lower_bound:lineno]\n        context_line = source[lineno]\n        post_context = source[lineno + 1:upper_bound]\n\n        return lower_bound, pre_context, context_line, post_context"
        }
      ]
    },
    {
      "pr_number": 8228,
      "pr_title": "Fixed #27966 -- Bumped required psycopg2 version to 2.5.4.",
      "pr_body": "",
      "issue_id": 27966,
      "issue_title": "Bump required version of pyscopg2 to 2.5.4",
      "issue_body": "​\nthis commit\nuses the cursor as context manager (line in question is marked), which were added in psycopg2 2.5 (\n​\nrelease notes\n) (see third item)\nbut\n​\nhere\ndjango checks only for 2.4.5.\n​\nthis commit here\nmade 2.4.5 a requirement and documented that in a few places.",
      "issue_closed_at": "2017-03-21T11:23:31",
      "base_commit": "7063a85579f40585f2601ba6e6887b0982e7ce43",
      "changes": [
        {
          "file": "django/db/backends/postgresql/base.py",
          "type": "function",
          "name": "psycopg2_version",
          "class_name": "DatabaseWrapper",
          "code": "def psycopg2_version(self):\n        return PSYCOPG2_VERSION"
        }
      ]
    },
    {
      "pr_number": 3259,
      "pr_title": "Fixed #23537 -- Added Oracle GIS SchemaEditor.",
      "pr_body": "",
      "issue_id": 23537,
      "issue_title": "Oracle GIS backend missing SchemaEditor",
      "issue_body": "I think this results in missing indexes and metadata for GIS fields.\nThere is one test failure that will be fixed by this:\n======================================================================\nFAIL: test_add_gis_field (django.contrib.gis.tests.gis_migrations.test_operations.OperationTests)\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/home/tim/code/django/django/contrib/gis/tests/gis_migrations/test_operations.py\", line 77, in test_add_gis_field\n    2\nAssertionError: 0 != 2",
      "issue_closed_at": "2014-09-25T19:33:18",
      "base_commit": "45bd7b3bd9008941580c100b9fc7361e3ff3ff0d",
      "changes": [
        {
          "file": "django/contrib/gis/db/backends/oracle/base.py",
          "type": "line",
          "name": "line 6",
          "code": "from django.contrib.gis.db.backends.oracle.creation import OracleCreation\nfrom django.contrib.gis.db.backends.oracle.introspection import OracleIntrospection\nfrom django.contrib.gis.db.backends.oracle.operations import OracleOperations\n\n\nclass DatabaseFeatures(BaseSpatialFeatures, OracleDatabaseFeatures):"
        },
        {
          "file": "django/contrib/gis/db/backends/oracle/base.py",
          "type": "function",
          "name": "__init__",
          "class_name": "DatabaseWrapper",
          "code": "def __init__(self, *args, **kwargs):\n        super(DatabaseWrapper, self).__init__(*args, **kwargs)\n        self.features = DatabaseFeatures(self)\n        self.ops = OracleOperations(self)\n        self.creation = OracleCreation(self)\n        self.introspection = OracleIntrospection(self)"
        },
        {
          "file": "django/contrib/gis/db/backends/oracle/operations.py",
          "type": "class",
          "name": "OracleOperations",
          "code": "class OracleOperations(DatabaseOperations, BaseSpatialOperations):\n    compiler_module = \"django.contrib.gis.db.backends.oracle.compiler\"\n\n    name = 'oracle'\n    oracle = True\n    valid_aggregates = {'Union', 'Extent'}\n\n    Adapter = OracleSpatialAdapter\n    Adaptor = Adapter  # Backwards-compatibility alias.\n\n    area = 'SDO_GEOM.SDO_AREA'\n    gml = 'SDO_UTIL.TO_GMLGEOMETRY'\n    centroid = 'SDO_GEOM.SDO_CENTROID'\n    difference = 'SDO_GEOM.SDO_DIFFERENCE'\n    distance = 'SDO_GEOM.SDO_DISTANCE'\n    extent = 'SDO_AGGR_MBR'\n    intersection = 'SDO_GEOM.SDO_INTERSECTION'\n    length = 'SDO_GEOM.SDO_LENGTH'\n    num_geom = 'SDO_UTIL.GETNUMELEM'\n    num_points = 'SDO_UTIL.GETNUMVERTICES'\n    perimeter = length\n    point_on_surface = 'SDO_GEOM.SDO_POINTONSURFACE'\n    reverse = 'SDO_UTIL.REVERSE_LINESTRING'\n    sym_difference = 'SDO_GEOM.SDO_XOR'\n    transform = 'SDO_CS.TRANSFORM'\n    union = 'SDO_GEOM.SDO_UNION'\n    unionagg = 'SDO_AGGR_UNION'\n\n    # We want to get SDO Geometries as WKT because it is much easier to\n    # instantiate GEOS proxies from WKT than SDO_GEOMETRY(...) strings.\n    # However, this adversely affects performance (i.e., Java is called\n    # to convert to WKT on every query).  If someone wishes to write a\n    # SDO_GEOMETRY(...) parser in Python, let me know =)\n    select = 'SDO_UTIL.TO_WKTGEOMETRY(%s)'\n\n    distance_functions = {\n        'distance_gt': (SDODistance('>'), dtypes),\n        'distance_gte': (SDODistance('>='), dtypes),\n        'distance_lt': (SDODistance('<'), dtypes),\n        'distance_lte': (SDODistance('<='), dtypes),\n        'dwithin': (SDODWithin(), dtypes),\n    }\n\n    geometry_functions = {\n        'contains': SDOOperation('SDO_CONTAINS'),\n        'coveredby': SDOOperation('SDO_COVEREDBY'),\n        'covers': SDOOperation('SDO_COVERS'),\n        'disjoint': SDOGeomRelate('DISJOINT'),\n        'intersects': SDOOperation('SDO_OVERLAPBDYINTERSECT'),  # TODO: Is this really the same as ST_Intersects()?\n        'equals': SDOOperation('SDO_EQUAL'),\n        'exact': SDOOperation('SDO_EQUAL'),\n        'overlaps': SDOOperation('SDO_OVERLAPS'),\n        'same_as': SDOOperation('SDO_EQUAL'),\n        'relate': (SDORelate, six.string_types),  # Oracle uses a different syntax, e.g., 'mask=inside+touch'\n        'touches': SDOOperation('SDO_TOUCH'),\n        'within': SDOOperation('SDO_INSIDE'),\n    }\n    geometry_functions.update(distance_functions)\n\n    gis_terms = set(['isnull'])\n    gis_terms.update(geometry_functions)\n\n    truncate_params = {'relate': None}\n\n    def get_db_converters(self, internal_type):\n        converters = super(OracleOperations, self).get_db_converters(internal_type)\n        geometry_fields = (\n            'PointField', 'GeometryField', 'LineStringField',\n            'PolygonField', 'MultiPointField', 'MultiLineStringField',\n            'MultiPolygonField', 'GeometryCollectionField', 'GeomField',\n            'GMLField',\n        )\n        if internal_type in geometry_fields:\n            converters.append(self.convert_textfield_value)\n        return converters\n\n    def convert_extent(self, clob):\n        if clob:\n            # Generally, Oracle returns a polygon for the extent -- however,\n            # it can return a single point if there's only one Point in the\n            # table.\n            ext_geom = Geometry(clob.read())\n            gtype = str(ext_geom.geom_type)\n            if gtype == 'Polygon':\n                # Construct the 4-tuple from the coordinates in the polygon.\n                shell = ext_geom.shell\n                ll, ur = shell[0][:2], shell[2][:2]\n            elif gtype == 'Point':\n                ll = ext_geom.coords[:2]\n                ur = ll\n            else:\n                raise Exception('Unexpected geometry type returned for extent: %s' % gtype)\n            xmin, ymin = ll\n            xmax, ymax = ur\n            return (xmin, ymin, xmax, ymax)\n        else:\n            return None\n\n    def convert_geom(self, clob, geo_field):\n        if clob:\n            return Geometry(clob.read(), geo_field.srid)\n        else:\n            return None\n\n    def geo_db_type(self, f):\n        \"\"\"\n        Returns the geometry database type for Oracle.  Unlike other spatial\n        backends, no stored procedure is necessary and it's the same for all\n        geometry types.\n        \"\"\"\n        return 'MDSYS.SDO_GEOMETRY'\n\n    def get_distance(self, f, value, lookup_type):\n        \"\"\"\n        Returns the distance parameters given the value and the lookup type.\n        On Oracle, geometry columns with a geodetic coordinate system behave\n        implicitly like a geography column, and thus meters will be used as\n        the distance parameter on them.\n        \"\"\"\n        if not value:\n            return []\n        value = value[0]\n        if isinstance(value, Distance):\n            if f.geodetic(self.connection):\n                dist_param = value.m\n            else:\n                dist_param = getattr(value, Distance.unit_attname(f.units_name(self.connection)))\n        else:\n            dist_param = value\n\n        # dwithin lookups on Oracle require a special string parameter\n        # that starts with \"distance=\".\n        if lookup_type == 'dwithin':\n            dist_param = 'distance=%s' % dist_param\n\n        return [dist_param]\n\n    def get_geom_placeholder(self, f, value):\n        \"\"\"\n        Provides a proper substitution value for Geometries that are not in the\n        SRID of the field.  Specifically, this routine will substitute in the\n        SDO_CS.TRANSFORM() function call.\n        \"\"\"\n        if value is None:\n            return 'NULL'\n\n        def transform_value(val, srid):\n            return val.srid != srid\n\n        if hasattr(value, 'expression'):\n            if transform_value(value, f.srid):\n                placeholder = '%s(%%s, %s)' % (self.transform, f.srid)\n            else:\n                placeholder = '%s'\n            # No geometry value used for F expression, substitute in\n            # the column name instead.\n            return placeholder % self.get_expression_column(value)\n        else:\n            if transform_value(value, f.srid):\n                return '%s(SDO_GEOMETRY(%%s, %s), %s)' % (self.transform, value.srid, f.srid)\n            else:\n                return 'SDO_GEOMETRY(%%s, %s)' % f.srid\n\n    def spatial_lookup_sql(self, lvalue, lookup_type, value, field, qn):\n        \"Returns the SQL WHERE clause for use in Oracle spatial SQL construction.\"\n        geo_col, db_type = lvalue\n\n        # See if an Oracle Geometry function matches the lookup type next\n        lookup_info = self.geometry_functions.get(lookup_type, False)\n        if lookup_info:\n            # Lookup types that are tuples take tuple arguments, e.g., 'relate' and\n            # 'dwithin' lookup types.\n            if isinstance(lookup_info, tuple):\n                # First element of tuple is lookup type, second element is the type\n                # of the expected argument (e.g., str, float)\n                sdo_op, arg_type = lookup_info\n                geom = value[0]\n\n                # Ensuring that a tuple _value_ was passed in from the user\n                if not isinstance(value, tuple):\n                    raise ValueError('Tuple required for `%s` lookup type.' % lookup_type)\n                if len(value) != 2:\n                    raise ValueError('2-element tuple required for %s lookup type.' % lookup_type)\n\n                # Ensuring the argument type matches what we expect.\n                if not isinstance(value[1], arg_type):\n                    raise ValueError('Argument type should be %s, got %s instead.' % (arg_type, type(value[1])))\n\n                if lookup_type == 'relate':\n                    # The SDORelate class handles construction for these queries,\n                    # and verifies the mask argument.\n                    return sdo_op(value[1]).as_sql(geo_col, self.get_geom_placeholder(field, geom))\n                else:\n                    # Otherwise, just call the `as_sql` method on the SDOOperation instance.\n                    return sdo_op.as_sql(geo_col, self.get_geom_placeholder(field, geom))\n            else:\n                # Lookup info is a SDOOperation instance, whose `as_sql` method returns\n                # the SQL necessary for the geometry function call. For example:\n                #  SDO_CONTAINS(\"geoapp_country\".\"poly\", SDO_GEOMTRY('POINT(5 23)', 4326)) = 'TRUE'\n                return lookup_info.as_sql(geo_col, self.get_geom_placeholder(field, value))\n        elif lookup_type == 'isnull':\n            # Handling 'isnull' lookup type\n            return \"%s IS %sNULL\" % (geo_col, ('' if value else 'NOT ')), []\n\n        raise TypeError(\"Got invalid lookup_type: %s\" % repr(lookup_type))\n\n    def spatial_aggregate_sql(self, agg):\n        \"\"\"\n        Returns the spatial aggregate SQL template and function for the\n        given Aggregate instance.\n        \"\"\"\n        agg_name = agg.__class__.__name__.lower()\n        if agg_name == 'union':\n            agg_name += 'agg'\n        if agg.is_extent:\n            sql_template = '%(function)s(%(field)s)'\n        else:\n            sql_template = '%(function)s(SDOAGGRTYPE(%(field)s,%(tolerance)s))'\n        sql_function = getattr(self, agg_name)\n        return self.select % sql_template, sql_function\n\n    # Routines for getting the OGC-compliant models.\n    def geometry_columns(self):\n        from django.contrib.gis.db.backends.oracle.models import OracleGeometryColumns\n        return OracleGeometryColumns\n\n    def spatial_ref_sys(self):\n        from django.contrib.gis.db.backends.oracle.models import OracleSpatialRefSys\n        return OracleSpatialRefSys\n\n    def modify_insert_params(self, placeholders, params):\n        \"\"\"Drop out insert parameters for NULL placeholder. Needed for Oracle Spatial\n        backend due to #10888\n        \"\"\"\n        # This code doesn't work for bulk insert cases.\n        assert len(placeholders) == 1\n        return [[param for pholder, param\n                 in six.moves.zip(placeholders[0], params[0]) if pholder != 'NULL'], ]"
        }
      ]
    },
    {
      "pr_number": 6263,
      "pr_title": "Fixed #26324 -- Fixed DurationField with fractional seconds on SQLite.",
      "pr_body": "https://code.djangoproject.com/ticket/26324\n",
      "issue_id": 26324,
      "issue_title": "DurationField stores certain values incorrectly in sqlite",
      "issue_body": "When encoding certain timedelta values in a\nDurationField\n, saving the object to a sqlite database and then reading it again,\nDurationField\nreturns None.\nclass\nFoo\n(\nmodels\n.\nModel\n):\nbar\n=\nmodels\n.\nDurationField\n()\nFoo\n.\nobjects\n.\ncreate\n(\nbar\n=\ntimedelta\n(\nseconds\n=\n2.05\n))\nFoo\n.\nobjects\n.\ncreate\n(\nbar\n=\ntimedelta\n(\nseconds\n=\n3.05\n))\nprint\nstr\n(\nFoo\n.\nobjects\n.\nall\n()[\n0\n]\n.\nbar\n)\n# 'None'\nprint\nstr\n(\nFoo\n.\nobjects\n.\nall\n()[\n1\n]\n.\nbar\n)\n# '3.05'\nI can reproduce this bug with Django 1.8.5 and 1.9.3 using sqlite as database backend. It does not occur with MySQL, so it seems to be related to how sqlite stores bigints. It renders\nDurationField\nessentially useless with sqlite.",
      "issue_closed_at": "2016-03-10T18:15:57",
      "base_commit": "85a4844f8a8e628b90fa30ba7074f162a2d188ef",
      "changes": [
        {
          "file": "django/db/models/fields/__init__.py",
          "type": "function",
          "name": "get_db_prep_value",
          "class_name": "UUIDField",
          "code": "def get_db_prep_value(self, value, connection, prepared=False):\n        if value is None:\n            return None\n        if not isinstance(value, uuid.UUID):\n            try:\n                value = uuid.UUID(value)\n            except AttributeError:\n                raise TypeError(self.error_messages['invalid'] % {'value': value})\n\n        if connection.features.has_native_uuid_field:\n            return value\n        return value.hex"
        }
      ]
    },
    {
      "pr_number": 3792,
      "pr_title": "Fixed #24054 -- Enabled sqlsequencereset for apps with migrations.",
      "pr_body": "https://code.djangoproject.com/ticket/24054\n",
      "issue_id": 24054,
      "issue_title": "Enable sqlsequencereset for apps with migrations",
      "issue_body": "The command doesn't depend on the\nDatabaseCreation\nclass and it doesn't seem that the problem the command aims to solve is obsoleted by migrations.",
      "issue_closed_at": "2014-12-26T14:56:14",
      "base_commit": "1729a5250b052832540cd696df3ff0a0a77baddf",
      "changes": [
        {
          "file": "django/core/management/commands/sqlsequencereset.py",
          "type": "line",
          "name": "line 1",
          "code": "from __future__ import unicode_literals\n\nfrom django.core.management.base import AppCommand\nfrom django.core.management.sql import check_for_migrations\nfrom django.db import connections, DEFAULT_DB_ALIAS\n\n"
        },
        {
          "file": "django/core/management/commands/sqlsequencereset.py",
          "type": "function",
          "name": "handle_app_config",
          "class_name": "Command",
          "code": "def handle_app_config(self, app_config, **options):\n        if app_config.models_module is None:\n            return\n        connection = connections[options.get('database')]\n        check_for_migrations(app_config, connection)\n        models = app_config.get_models(include_auto_created=True)\n        statements = connection.ops.sequence_reset_sql(self.style, models)\n        return '\\n'.join(statements)"
        }
      ]
    }
  ]
}