{
  "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 \u200bpython -c works:\n$ python -c <<EOF \" \nimport django\ndef f():\n\t\tprint(django.__version__)\nf()\"\nEOF\n2.2.16\nHere's how \u200bpython -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 \u200busage of \u200bexec:\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": "",
      "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": "",
      "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": "",
      "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": "",
      "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": "",
      "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)"
        }
      ]
    }
  ]
}