{
  "Selected_candidate": {
    "pr_number": 15034,
    "pr_title": "Fixed #33234 -- Fixed autodetector crash for proxy models inheriting from non-model class.",
    "pr_body": "ticket-33234\r\n\r\nRegression in aa4acc164d1247c0de515c959f7b09648b57dc42.\r\n\r\nThanks Kevin Marsh for the report.",
    "issue_id": 33234,
    "issue_title": "Migrations autodetector breaking with proxy models inheriting from mixin",
    "issue_body": "So I've run into an issue with the new automigrations feature in Django 4.0b1 (and 4.0a1)  relating to proxy models inheriting from a non-Model class.\nFor examples given these three models:\nfrom\ndjango.db\nimport\nmodels\nclass\nMyMixin\n:\n...\nclass\nMyBaseModel\n(\nmodels\n.\nModel\n):\n...\nclass\nMyProxyModel\n(\nMyMixin\n,\nMyBaseModel\n):\nclass\nMeta\n:\nproxy\n=\nTrue\nRunning\nmigrate\n/\nmakemigrations\nwill result in\nMyProxyModel\ncrashing when it tries running\n_find_concrete_model_from_proxy\n:\nFile \"/some/annonymized/path/django/core/management/commands/makemigrations.py\", line 172, in handle\n    changes = autodetector.changes(\n  File \"/some/annonymized/path/django/db/migrations/autodetector.py\", line 43, in changes\n    changes = self._detect_changes(convert_apps, graph)\n  File \"/some/annonymized/path/django/db/migrations/autodetector.py\", line 156, in _detect_changes\n    self.to_state.resolve_fields_and_relations()\n  File \"/some/annonymized/path/django/db/migrations/state.py\", line 449, in resolve_fields_and_relations\n    concretes, proxies = self._get_concrete_models_mapping_and_proxy_models()\n  File \"/some/annonymized/path/django/db/migrations/state.py\", line 470, in _get_concrete_models_mapping_and_proxy_models\n    concrete_models_mapping[model_key] = self._find_concrete_model_from_proxy(\n  File \"/some/annonymized/path/django/db/migrations/state.py\", line 479, in _find_concrete_model_from_proxy\n    base_key = make_model_tuple(base)\n  File \"/some/annonymized/path/django/db/models/utils.py\", line 18, in make_model_tuple\n    model_tuple = model._meta.app_label, model._meta.model_name\nAttributeError: type object 'MyMixin' has no attribute '_meta'\nChanging\nMyMixin\nto inherit from\nmodels.Model\nprevents this crash but might not always be possible depending on how the user is using that mixin. Or if we've decided that all inheritance for proxy models must be from\nmodels.Model\nthen that should be flagged up more explicitly to developers (eg. checking for it in\nModelBase.__new__\nor something).",
    "issue_closed_at": "2021-11-02T14:10:58",
    "base_commit": "073b7b5915fdfb89a144e81173176ee13ff92a25",
    "changes": [
      {
        "file": "django/db/migrations/state.py",
        "type": "function",
        "name": "_get_concrete_models_mapping_and_proxy_models",
        "class_name": "ProjectState",
        "code": "def _get_concrete_models_mapping_and_proxy_models(self):\n        concrete_models_mapping = {}\n        proxy_models = {}\n        # Split models to proxy and concrete models.\n        for model_key, model_state in self.models.items():\n            if model_state.options.get('proxy'):\n                proxy_models[model_key] = model_state\n                # Find a concrete model for the proxy.\n                concrete_models_mapping[model_key] = self._find_concrete_model_from_proxy(\n                    proxy_models, model_state,\n                )\n            else:\n                concrete_models_mapping[model_key] = model_key\n        return concrete_models_mapping, proxy_models"
      }
    ]
  },
  "Justification": "Candidate A is the most relevant because it directly involves proxy models, which is a core aspect of the CURRENT bug report. Both bugs relate to how Django handles models, particularly proxy models inheriting from non-standard classes. This structural similarity and the context of management commands make it highly applicable for identifying potential misconfigurations or behaviors in the CURRENT bug's traceback. The patch also addresses underlying issues with model relationships, which can provide insights for debugging the query logic in the CURRENT bug.",
  "instance_id": "django__django-15814",
  "repo": "django/django",
  "created_at": "2022-07-03T19:10:56Z",
  "problem_statement": "QuerySet.only() after select_related() crash on proxy models.\nDescription\n\t\nWhen I optimize a query using select_related() and only() methods from the proxy model I encounter an error:\nWindows 10; Python 3.10; Django 4.0.5\nTraceback (most recent call last):\n File \"D:\\study\\django_college\\manage.py\", line 22, in <module>\n\tmain()\n File \"D:\\study\\django_college\\manage.py\", line 18, in main\n\texecute_from_command_line(sys.argv)\n File \"D:\\Anaconda3\\envs\\django\\lib\\site-packages\\django\\core\\management\\__init__.py\", line 446, in execute_from_command_line\n\tutility.execute()\n File \"D:\\Anaconda3\\envs\\django\\lib\\site-packages\\django\\core\\management\\__init__.py\", line 440, in execute\n\tself.fetch_command(subcommand).run_from_argv(self.argv)\n File \"D:\\Anaconda3\\envs\\django\\lib\\site-packages\\django\\core\\management\\base.py\", line 414, in run_from_argv\n\tself.execute(*args, **cmd_options)\n File \"D:\\Anaconda3\\envs\\django\\lib\\site-packages\\django\\core\\management\\base.py\", line 460, in execute\n\toutput = self.handle(*args, **options)\n File \"D:\\study\\django_college\\project\\users\\management\\commands\\test_proxy.py\", line 9, in handle\n\tobjs = list(AnotherModel.objects.select_related(\"custom\").only(\"custom__name\").all())\n File \"D:\\Anaconda3\\envs\\django\\lib\\site-packages\\django\\db\\models\\query.py\", line 302, in __len__\n\tself._fetch_all()\n File \"D:\\Anaconda3\\envs\\django\\lib\\site-packages\\django\\db\\models\\query.py\", line 1507, in _fetch_all\n\tself._result_cache = list(self._iterable_class(self))\n File \"D:\\Anaconda3\\envs\\django\\lib\\site-packages\\django\\db\\models\\query.py\", line 71, in __iter__\n\trelated_populators = get_related_populators(klass_info, select, db)\n File \"D:\\Anaconda3\\envs\\django\\lib\\site-packages\\django\\db\\models\\query.py\", line 2268, in get_related_populators\n\trel_cls = RelatedPopulator(rel_klass_info, select, db)\n File \"D:\\Anaconda3\\envs\\django\\lib\\site-packages\\django\\db\\models\\query.py\", line 2243, in __init__\n\tself.pk_idx = self.init_list.index(self.model_cls._meta.pk.attname)\nValueError: 'id' is not in list\nModels:\nclass CustomModel(models.Model):\n\tname = models.CharField(max_length=16)\nclass ProxyCustomModel(CustomModel):\n\tclass Meta:\n\t\tproxy = True\nclass AnotherModel(models.Model):\n\tcustom = models.ForeignKey(\n\t\tProxyCustomModel,\n\t\ton_delete=models.SET_NULL,\n\t\tnull=True,\n\t\tblank=True,\n\t)\nCommand:\nclass Command(BaseCommand):\n\tdef handle(self, *args, **options):\n\t\tlist(AnotherModel.objects.select_related(\"custom\").only(\"custom__name\").all())\nAt django/db/models/sql/query.py in 745 line there is snippet:\nopts = cur_model._meta\nIf I replace it by \nopts = cur_model._meta.concrete_model._meta\nall works as expected.\n",
  "patch": "diff --git a/django/db/models/sql/query.py b/django/db/models/sql/query.py\n--- a/django/db/models/sql/query.py\n+++ b/django/db/models/sql/query.py\n@@ -748,6 +748,7 @@ def deferred_to_data(self, target):\n                     cur_model = source.related_model\n                 else:\n                     cur_model = source.remote_field.model\n+                cur_model = cur_model._meta.concrete_model\n                 opts = cur_model._meta\n                 # Even if we're \"just passing through\" this model, we must add\n                 # both the current model's pk and the related reference field\n"
}