{
    "Selected_candidate": {
        "pr_number": 8926,
        "pr_title": "Fixed #28493 -- Made migrations autodetector find dependencies for model renaming.",
        "pr_body": "https://code.djangoproject.com/ticket/28493",
        "issue_id": 28493,
        "issue_title": "Foreign keys break on migration if models are renamed in a different app",
        "issue_body": "Steps to reproduce:\nCreate app\na\n, with a model called\nA\n. Run\nmakemigrations a\nCreate app\nb\n, with a model called\nB\n. Give\nB\na\nForeignKey\nto\nA\n. Run\nmakemigrations b\nRename model\nA\nto\nAa\n. Run\nmakemigrations a\nRun\nmigrate\nExpected behaviour:\nThe migration completes successfully\nActual behaviour:\nMigration\n0001\non\nb\nis run after migration\n0002\non\na\n, and the migration fails with the following error:\nraise ValueError('Related model %r cannot be resolved' % self.remote_field.model)\nValueError: Related model u'a.A' cannot be resolved",
        "issue_closed_at": "2017-09-04T14:40:14",
        "base_commit": "3f2b1d926bb3a72b4c3d2cd958455ebb9b4ca458",
        "changes": [
            {
                "file": "django/db/migrations/autodetector.py",
                "type": "function",
                "name": "generate_renamed_models",
                "class_name": "MigrationAutodetector",
                "code": "def generate_renamed_models(self):\n        \"\"\"\n        Find any renamed models, generate the operations for them, and remove\n        the old entry from the model lists. Must be run before other\n        model-level generation.\n        \"\"\"\n        self.renamed_models = {}\n        self.renamed_models_rel = {}\n        added_models = self.new_model_keys - self.old_model_keys\n        for app_label, model_name in sorted(added_models):\n            model_state = self.to_state.models[app_label, model_name]\n            model_fields_def = self.only_relation_agnostic_fields(model_state.fields)\n\n            removed_models = self.old_model_keys - self.new_model_keys\n            for rem_app_label, rem_model_name in removed_models:\n                if rem_app_label == app_label:\n                    rem_model_state = self.from_state.models[rem_app_label, rem_model_name]\n                    rem_model_fields_def = self.only_relation_agnostic_fields(rem_model_state.fields)\n                    if model_fields_def == rem_model_fields_def:\n                        if self.questioner.ask_rename_model(rem_model_state, model_state):\n                            self.add_operation(\n                                app_label,\n                                operations.RenameModel(\n                                    old_name=rem_model_state.name,\n                                    new_name=model_state.name,\n                                )\n                            )\n                            self.renamed_models[app_label, model_name] = rem_model_name\n                            renamed_models_rel_key = '%s.%s' % (rem_model_state.app_label, rem_model_state.name)\n                            self.renamed_models_rel[renamed_models_rel_key] = '%s.%s' % (\n                                model_state.app_label,\n                                model_state.name,\n                            )\n                            self.old_model_keys.remove((rem_app_label, rem_model_name))\n                            self.old_model_keys.add((app_label, model_name))\n                            break"
            }
        ]
    },
    "Justification": "Candidate E is the most helpful report as it specifically addresses an issue that arises when models are renamed in a different app, which closely relates to the CURRENT bug involving migration failures due to existing entries in the `auth_permission` table after a model has been renamed. Both bug reports are concerned with how Django handles migrations when the database schema has changed, and the fix described in Candidate E directly improves the migration process for scenarios similar to the one described in the CURRENT bug. These shared themes of model renaming and migration integrity make Candidate E particularly relevant for debugging the CURRENT bug."
}