{
  "Selected_candidate": {
    "pr_number": 7036,
    "pr_title": "Fixed #27024 -- Prevented logging error with empty string as geometry widget value",
    "pr_body": "Thanks Gavin Wahl for the report.\n",
    "issue_id": 27024,
    "issue_title": "BaseGeometryWidget logs a false positive: Error creating geometry from value ''",
    "issue_body": "When using a form with a PointField (or presumably anything using BaseGeometryWidget), if you\nDon't fill out the map field\nCause a ValidationError for another field\nSubmit the form\nThis error-level message will be logged:\nError creating geometry from value ''\nThere should not be any error logged because there is no error. Maybe\nBaseGeometryWidget.deserialize\nneeds to check for\nEMPTY_VALUES\n?",
    "issue_closed_at": "2016-08-08T09:25:25",
    "base_commit": "2a11d2d7a7d5c6609c85dbc631fad6b8a8645a64",
    "changes": [
      {
        "file": "django/contrib/gis/admin/widgets.py",
        "type": "function",
        "name": "render",
        "class_name": "OpenLayersWidget",
        "code": "def render(self, name, value, attrs=None):\n        # Update the template parameters with any attributes passed in.\n        if attrs:\n            self.params.update(attrs)\n            self.params['editable'] = self.params['modifiable']\n        else:\n            self.params['editable'] = True\n\n        # Defaulting the WKT value to a blank string -- this\n        # will be tested in the JavaScript and the appropriate\n        # interface will be constructed.\n        self.params['wkt'] = ''\n\n        # If a string reaches here (via a validation error on another\n        # field) then just reconstruct the Geometry.\n        if isinstance(value, six.string_types):\n            try:\n                value = GEOSGeometry(value)\n            except (GEOSException, ValueError) as err:\n                logger.error(\"Error creating geometry from value '%s' (%s)\", value, err)\n                value = None\n\n        if (value and value.geom_type.upper() != self.geom_type and\n                self.geom_type != 'GEOMETRY'):\n            value = None\n\n        # Constructing the dictionary of the map options.\n        self.params['map_options'] = self.map_options()\n\n        # Constructing the JavaScript module name using the name of\n        # the GeometryField (passed in via the `attrs` keyword).\n        # Use the 'name' attr for the field name (rather than 'field')\n        self.params['name'] = name\n        # note: we must switch out dashes for underscores since js\n        # functions are created using the module variable\n        js_safe_name = self.params['name'].replace('-', '_')\n        self.params['module'] = 'geodjango_%s' % js_safe_name\n\n        if value:\n            # Transforming the geometry to the projection used on the\n            # OpenLayers map.\n            srid = self.params['srid']\n            if value.srid != srid:\n                try:\n                    ogr = value.ogr\n                    ogr.transform(srid)\n                    wkt = ogr.wkt\n                except GDALException as err:\n                    logger.error(\n                        \"Error transforming geometry from srid '%s' to srid '%s' (%s)\",\n                        value.srid, srid, err\n                    )\n                    wkt = ''\n            else:\n                wkt = value.wkt\n\n            # Setting the parameter WKT with that of the transformed\n            # geometry.\n            self.params['wkt'] = wkt\n\n        self.params.update(geo_context)\n        return loader.render_to_string(self.template, self.params)"
      },
      {
        "file": "django/contrib/gis/forms/widgets.py",
        "type": "function",
        "name": "deserialize",
        "class_name": "BaseGeometryWidget",
        "code": "def deserialize(self, value):\n        try:\n            return GEOSGeometry(value, self.map_srid)\n        except (GEOSException, ValueError) as err:\n            logger.error(\"Error creating geometry from value '%s' (%s)\", value, err)\n        return None"
      }
    ]
  },
  "Justification": "Candidate A is the most helpful because it shares a structural similarity with the CURRENT bug report regarding empty values in form rendering. Both bugs involve issues with handling empty or irrelevant attributes in forms, leading to exceptions during template rendering. While Candidate A addresses a false positive error log with an empty value, the underlying theme of mismanagement of empty values aligns with the CURRENT bug, where the KeyError is raised due to improper handling of the 'empty_permitted' keyword argument. This relevance in the nature of the errors and the context of form handling makes Candidate A particularly useful for identifying potential solutions and debugging strategies for the CURRENT bug.",
  "instance_id": "django__django-16041",
  "repo": "django/django",
  "created_at": "2022-09-09T10:07:29Z",
  "problem_statement": "Rendering empty_form crashes when empty_permitted is passed to form_kwargs\nDescription\n\t\nIssue\nWhen explicitly setting form_kwargs = {'empty_permitted':True} or form_kwargs = {'empty_permitted':False} , a KeyError occurs when rendering a template that uses a formset's empty_form.\nExpected Behavior\nempty_permitted is ignored for formset.empty_form since empty_permitted is irrelevant for empty_form, as empty_form is not meant to be used to pass data and therefore does not need to be validated.\nSteps to Reproduce\n# views.py\nfrom django.shortcuts import render\nfrom .models import MyModel\ndef test_view(request):\n\tcontext = {}\n\tff = modelformset_factory(MyModel, fields = ['a_field'])\n\tcontext['formset'] = ff(\n\t\tqueryset = MyModel.objects.none(),\n\t\tform_kwargs = {'empty_permitted':True} # or form_kwargs = {'empty_permitted':False}\n\t)\n\treturn render(request, 'my_app/my_model_formset.html', context)\n# urls.py\nfrom django.urls import path, include\nfrom .views import test_view\nurlpatterns = [\n\tpath('test', test_view)\n]\n# my_model_formset.html\n{% extends \"my_app/base.html\" %}\n{% block content %}\n<form id=\"my-form\" method=\"post\">\n {% csrf_token %}\n {{ formset }}\n <input type=\"submit\" value=\"Save\">\n</form>\n{{ formset.empty_form }}\n{% endblock %}\n",
  "patch": "diff --git a/django/forms/formsets.py b/django/forms/formsets.py\n--- a/django/forms/formsets.py\n+++ b/django/forms/formsets.py\n@@ -257,14 +257,15 @@ def extra_forms(self):\n \n     @property\n     def empty_form(self):\n-        form = self.form(\n-            auto_id=self.auto_id,\n-            prefix=self.add_prefix(\"__prefix__\"),\n-            empty_permitted=True,\n-            use_required_attribute=False,\n+        form_kwargs = {\n             **self.get_form_kwargs(None),\n-            renderer=self.renderer,\n-        )\n+            \"auto_id\": self.auto_id,\n+            \"prefix\": self.add_prefix(\"__prefix__\"),\n+            \"empty_permitted\": True,\n+            \"use_required_attribute\": False,\n+            \"renderer\": self.renderer,\n+        }\n+        form = self.form(**form_kwargs)\n         self.add_fields(form, None)\n         return form\n \n"
}