{
  "Selected_candidate": {
    "pr_number": 9874,
    "pr_title": "Fixed #29322 -- Made admin check all ModelAdmin fieldsets for duplicates.",
    "pr_body": "Duplicate fields were only detected if they were in the same fieldset.\r\n\r\nhttp://code.djangoproject.com/ticket/29322",
    "issue_id": 29322,
    "issue_title": "admin.E012: Duplicate fields in admin fieldset only recognizes duplicates if they are in the same fieldset",
    "issue_body": "",
    "issue_closed_at": "2018-04-13T10:09:11",
    "base_commit": "0b66c3b442875627fa6daef4ac1e90900d74290b",
    "changes": [
      {
        "file": "django/contrib/admin/checks.py",
        "type": "function",
        "name": "_check_fieldsets",
        "class_name": "BaseModelAdminChecks",
        "code": "def _check_fieldsets(self, obj):\n        \"\"\" Check that fieldsets is properly formatted and doesn't contain\n        duplicates. \"\"\"\n\n        if obj.fieldsets is None:\n            return []\n        elif not isinstance(obj.fieldsets, (list, tuple)):\n            return must_be('a list or tuple', option='fieldsets', obj=obj, id='admin.E007')\n        else:\n            return list(chain.from_iterable(\n                self._check_fieldsets_item(obj, obj.model, fieldset, 'fieldsets[%d]' % index)\n                for index, fieldset in enumerate(obj.fieldsets)\n            ))"
      },
      {
        "file": "django/contrib/admin/checks.py",
        "type": "function",
        "name": "_check_fieldsets_item",
        "class_name": "BaseModelAdminChecks",
        "code": "def _check_fieldsets_item(self, obj, model, fieldset, label):\n        \"\"\" Check an item of `fieldsets`, i.e. check that this is a pair of a\n        set name and a dictionary containing \"fields\" key. \"\"\"\n\n        if not isinstance(fieldset, (list, tuple)):\n            return must_be('a list or tuple', option=label, obj=obj, id='admin.E008')\n        elif len(fieldset) != 2:\n            return must_be('of length 2', option=label, obj=obj, id='admin.E009')\n        elif not isinstance(fieldset[1], dict):\n            return must_be('a dictionary', option='%s[1]' % label, obj=obj, id='admin.E010')\n        elif 'fields' not in fieldset[1]:\n            return [\n                checks.Error(\n                    \"The value of '%s[1]' must contain the key 'fields'.\" % label,\n                    obj=obj.__class__,\n                    id='admin.E011',\n                )\n            ]\n        elif not isinstance(fieldset[1]['fields'], (list, tuple)):\n            return must_be('a list or tuple', option=\"%s[1]['fields']\" % label, obj=obj, id='admin.E008')\n\n        fields = flatten(fieldset[1]['fields'])\n        if len(fields) != len(set(fields)):\n            return [\n                checks.Error(\n                    \"There are duplicate field(s) in '%s[1]'.\" % label,\n                    obj=obj.__class__,\n                    id='admin.E012',\n                )\n            ]\n        return list(chain.from_iterable(\n            self._check_field_spec(obj, model, fieldset_fields, '%s[1][\"fields\"]' % label)\n            for fieldset_fields in fieldset[1]['fields']\n        ))"
      }
    ]
  },
  "Justification": "Candidate B is the most helpful because it addresses issues with duplicate fields in admin, specifically in how choices are validated in forms, similar to the problem with duplicate options arising from `limit_choices_to` in the CURRENT bug. Both issues involve form-related functionality and validation checks dealing with models, suggesting overlapping areas in the codebase. The patch type relates closely, focusing on fixing validation logic, which could provide insights on mitigating the duplicate options in the current scenario.",
  "instance_id": "django__django-13315",
  "repo": "django/django",
  "created_at": "2020-08-17T04:24:39Z",
  "problem_statement": "limit_choices_to on a ForeignKey can render duplicate options in formfield\nDescription\n\t\nIf you pass a Q object as limit_choices_to on a ForeignKey field involving a join, you may end up with duplicate options in your form.\nSee regressiontest in patch for a clear view on the problem.\n",
  "patch": "diff --git a/django/forms/models.py b/django/forms/models.py\n--- a/django/forms/models.py\n+++ b/django/forms/models.py\n@@ -97,10 +97,18 @@ def model_to_dict(instance, fields=None, exclude=None):\n \n def apply_limit_choices_to_to_formfield(formfield):\n     \"\"\"Apply limit_choices_to to the formfield's queryset if needed.\"\"\"\n+    from django.db.models import Exists, OuterRef, Q\n     if hasattr(formfield, 'queryset') and hasattr(formfield, 'get_limit_choices_to'):\n         limit_choices_to = formfield.get_limit_choices_to()\n-        if limit_choices_to is not None:\n-            formfield.queryset = formfield.queryset.complex_filter(limit_choices_to)\n+        if limit_choices_to:\n+            complex_filter = limit_choices_to\n+            if not isinstance(complex_filter, Q):\n+                complex_filter = Q(**limit_choices_to)\n+            complex_filter &= Q(pk=OuterRef('pk'))\n+            # Use Exists() to avoid potential duplicates.\n+            formfield.queryset = formfield.queryset.filter(\n+                Exists(formfield.queryset.model._base_manager.filter(complex_filter)),\n+            )\n \n \n def fields_for_model(model, fields=None, exclude=None, widgets=None,\n"
}