{
  "Selected_candidate": {
    "pr_number": 14071,
    "pr_title": "Fixed #32494 -- Adjusted system check for raw_id_fields to warn about Field.attname.",
    "pr_body": "https://code.djangoproject.com/ticket/32494",
    "issue_id": 32494,
    "issue_title": "Admin's raw_id_field check admin.E002 doesn't catch .attname mis-references",
    "issue_body": "Since\nadmin.E002\nrelies on\nmodels.Options.get_field\nwhich allows retrieval of fields by both\nname\nand\nattname\nreferring to fields by\nattname\nwhile only\nname\n​\nis taken into consideration\nallows the check to pass while\nraw_id_fields\nis not honoured.\ne.g.\nclass\nBookAdmin\n(\nModelAdmin\n):\nraw_id_fields\n=\n[\n'author_id'\n]\npasses\nadmin.E002\nbut the\nauthor\nfield won't use the\nraw_id\nfeature.\nThe\n_check_raw_id_fields_item\nmethod should also make sure to check\nfield.name == field_name\non field retrieval success and\nreturn refer_to_missing_field(field=field_name, option=label, obj=obj, id='admin.E002')\nwhen it's not the case.",
    "issue_closed_at": "2021-03-04T02:21:27",
    "base_commit": "a9cf954e6174450057ea1065aa2ccbbd12f59b65",
    "changes": [
      {
        "file": "django/contrib/admin/checks.py",
        "type": "function",
        "name": "_check_raw_id_fields_item",
        "class_name": "BaseModelAdminChecks",
        "code": "def _check_raw_id_fields_item(self, obj, field_name, label):\n        \"\"\" Check an item of `raw_id_fields`, i.e. check that field named\n        `field_name` exists in model `model` and is a ForeignKey or a\n        ManyToManyField. \"\"\"\n\n        try:\n            field = obj.model._meta.get_field(field_name)\n        except FieldDoesNotExist:\n            return refer_to_missing_field(field=field_name, option=label, obj=obj, id='admin.E002')\n        else:\n            if not field.many_to_many and not isinstance(field, models.ForeignKey):\n                return must_be('a foreign key or a many-to-many field', option=label, obj=obj, id='admin.E003')\n            else:\n                return []"
      },
      {
        "file": "django/contrib/admin/checks.py",
        "type": "function",
        "name": "must_inherit_from",
        "class_name": null,
        "code": "def must_inherit_from(parent, option, obj, id):\n    return [\n        checks.Error(\n            \"The value of '%s' must inherit from '%s'.\" % (option, parent),\n            obj=obj.__class__,\n            id=id,\n        ),\n    ]"
      }
    ]
  },
  "Justification": "Candidate E is the most helpful because it directly relates to the Django Admin Site, similar to the CURRENT bug, which also pertains to the admin functionality. The bug in Candidate E discusses a validation system for raw_id_fields that is also a part of the Admin interface, making it relevant to the admin's behavior regarding ForeignKey fields. The structural similarities in handling fields and generating URLs (even though it's a different contextual issue) could illuminate the underlying mechanism affecting the URL generation in the CURRENT bug. Furthermore, the fix involves system checks which may offer insights into any potential side effects stemming from modifications made to the admin features, just as seen in the CURRENT issue.",
  "instance_id": "django__django-14855",
  "repo": "django/django",
  "created_at": "2021-09-14T01:27:01Z",
  "problem_statement": "Wrong URL generated by get_admin_url for readonly field in custom Admin Site\nDescription\n\t\nWhen a model containing a ForeignKey field is viewed (or edited) in a custom Admin Site, and that ForeignKey field is listed in readonly_fields, the url generated for the link is /admin/... instead of /custom-admin/....\nThis appears to be caused by the following line in django.contrib.admin.helpers get_admin_url:\nurl = reverse(url_name, args=[quote(remote_obj.pk)])\nOther parts of the admin use the current_app keyword parameter to identify the correct current name of the Admin Site. (See django.contrib.admin.options.ModelAdmin response_add as just one example)\nI have been able to correct this specific issue by replacing the above line with:\nurl = reverse(\n\turl_name,\n\targs=[quote(remote_obj.pk)],\n\tcurrent_app=self.model_admin.admin_site.name\n)\nHowever, I don't know if there are any side effects and I have not yet run the full suite of tests on this. Mostly looking for feedback whether I'm on the right track.\n",
  "patch": "diff --git a/django/contrib/admin/helpers.py b/django/contrib/admin/helpers.py\n--- a/django/contrib/admin/helpers.py\n+++ b/django/contrib/admin/helpers.py\n@@ -209,7 +209,11 @@ def get_admin_url(self, remote_field, remote_obj):\n             remote_field.model._meta.model_name,\n         )\n         try:\n-            url = reverse(url_name, args=[quote(remote_obj.pk)])\n+            url = reverse(\n+                url_name,\n+                args=[quote(remote_obj.pk)],\n+                current_app=self.model_admin.admin_site.name,\n+            )\n             return format_html('<a href=\"{}\">{}</a>', url, remote_obj)\n         except NoReverseMatch:\n             return str(remote_obj)\n"
}