{
  "Selected_candidate": {
    "pr_number": 8439,
    "pr_title": "Fixed #28105 -- Prevent illegal dict construction in BaseGeometryWidget.",
    "pr_body": "",
    "issue_id": 28105,
    "issue_title": "BaseGeometryWidget.get_context() crashes if attrs contains the name of an existing key",
    "issue_body": "In\ncontrib.gis.forms.widgets\nthere is this part (line 67 in current master):\ncontext = self.build_attrs(self.attrs, dict(\n    name=name,\n    module='geodjango_%s' % name.replace('-', '_'),  # JS-safe\n    serialized=self.serialize(value),\n    geom_type=gdal.OGRGeomType(self.attrs['geom_type']),\n    STATIC_URL=settings.STATIC_URL,\n    LANGUAGE_BIDI=translation.get_language_bidi(),\n    **attrs\n))\nIf\nattrs\nalso contains a key 'geom_type' this leads to an inevitable crash.\nThis should probaly be something like:\ncontext_kwargs = attrs.copy()\ncontext_kwargs.update(dict(\n    name=name,\n    module='geodjango_%s' % name.replace('-', '_'),  # JS-safe\n    serialized=self.serialize(value),\n    geom_type=gdal.OGRGeomType(self.attrs['geom_type']),\n    STATIC_URL=settings.STATIC_URL,\n    LANGUAGE_BIDI=translation.get_language_bidi(),\n))\nCurrently this causes django-bootstrap3 to fail for Django 1.11.",
    "issue_closed_at": "2017-04-30T20:13:52",
    "base_commit": "1ebd295082bb0e6b230cf3bc39fd04bee71c2bd7",
    "changes": [
      {
        "file": "django/contrib/gis/forms/widgets.py",
        "type": "function",
        "name": "get_context",
        "class_name": "BaseGeometryWidget",
        "code": "def get_context(self, name, value, attrs):\n        context = super().get_context(name, value, attrs)\n        # If a string reaches here (via a validation error on another\n        # field) then just reconstruct the Geometry.\n        if value and isinstance(value, str):\n            value = self.deserialize(value)\n\n        if value:\n            # Check that srid of value and map match\n            if value.srid and value.srid != self.map_srid:\n                try:\n                    ogr = value.ogr\n                    ogr.transform(self.map_srid)\n                    value = ogr\n                except gdal.GDALException as err:\n                    logger.error(\n                        \"Error transforming geometry from srid '%s' to srid '%s' (%s)\",\n                        value.srid, self.map_srid, err\n                    )\n\n        if attrs is None:\n            attrs = {}\n\n        context.update(self.build_attrs(self.attrs, dict(\n            name=name,\n            module='geodjango_%s' % name.replace('-', '_'),  # JS-safe\n            serialized=self.serialize(value),\n            geom_type=gdal.OGRGeomType(self.attrs['geom_type']),\n            STATIC_URL=settings.STATIC_URL,\n            LANGUAGE_BIDI=translation.get_language_bidi(),\n            **attrs\n        )))\n        return context"
      }
    ]
  },
  "Justification": "Candidate E is most helpful because it deals with a specific case of handling attributes and crashes in widget rendering, which indicates a direct interaction with the data being processed. The CURRENT bug report concerns header management and exceptions that arise due to invalid inputs (empty strings), so candidate E's context of fixing attribute handling could lead to resolving similar unexpected behaviors in the header context. Additionally, both bugs involve dealing with the handling of specific input values that are integral to their respective functionalities, which aligns well in terms of debugging strategies.",
  "instance_id": "django__django-15498",
  "repo": "django/django",
  "created_at": "2022-03-10T19:47:15Z",
  "problem_statement": "Fix handling empty string for If-Modified-Since header\nDescription\n\t\nEmpty string used to be ignored for If-Modified-Since header, but now raises exception since d6aff369ad3.\nFix handling empty string for If-Modified-Since header\nDescription\n\t\nEmpty string used to be ignored for If-Modified-Since header, but now raises exception since d6aff369ad3.\n",
  "patch": "diff --git a/django/views/static.py b/django/views/static.py\n--- a/django/views/static.py\n+++ b/django/views/static.py\n@@ -129,12 +129,14 @@ def was_modified_since(header=None, mtime=0, size=0):\n         if header is None:\n             raise ValueError\n         matches = re.match(r\"^([^;]+)(; length=([0-9]+))?$\", header, re.IGNORECASE)\n+        if matches is None:\n+            raise ValueError\n         header_mtime = parse_http_date(matches[1])\n         header_len = matches[3]\n         if header_len and int(header_len) != size:\n             raise ValueError\n         if int(mtime) > header_mtime:\n             raise ValueError\n-    except (AttributeError, ValueError, OverflowError):\n+    except (ValueError, OverflowError):\n         return True\n     return False\n"
}