{
    "Selected_candidate": {
        "pr_number": 6642,
        "pr_title": "Fixed #26647 -- Included the state of all applied migrations when migrating forward.",
        "pr_body": "Thanks Jasper Maes for the detailed report.\n",
        "issue_id": 26647,
        "issue_title": "Post migrate signal old content type model",
        "issue_body": "Since the post migrate signal has the apps argument and the update_contenttypes and create_permissions listeners use this apps argument to detect the ContentType model, there can be a bug when unapplying a migration and then applying it again. The listeners will use an old model with ContentType.name still present because this in the apps of the state that the migration executor returned.\nI made a\n​\ntestproject\nwere the error is replicated.\nThe tests for the first app will fail, but not for the second app. I tracked this down to the migration executor were in the crashing app the migrations are in front of the migration that removes the ContentType.name field in the full_plan variable, so the executor returns a state not including this ContentType model change.\nIf someone can push me in the right direction I am willing to make a patch for this issue.",
        "issue_closed_at": "2016-05-26T12:29:12",
        "base_commit": "30d110ef43d8a3c50ea8ec4e4fe49bd2bb859530",
        "changes": [
            {
                "file": "django/db/migrations/executor.py",
                "type": "function",
                "name": "_migrate_all_forwards",
                "class_name": "MigrationExecutor",
                "code": "def _migrate_all_forwards(self, plan, full_plan, fake, fake_initial):\n        \"\"\"\n        Take a list of 2-tuples of the form (migration instance, False) and\n        apply them in the order they occur in the full_plan.\n        \"\"\"\n        migrations_to_run = {m[0] for m in plan}\n        state = self._create_project_state()\n        applied_migrations = {\n            self.loader.graph.nodes[key] for key in self.loader.applied_migrations\n            if key in self.loader.graph.nodes\n        }\n        for migration, _ in full_plan:\n            if not migrations_to_run:\n                # We remove every migration that we applied from this set so\n                # that we can bail out once the last migration has been applied\n                # and don't always run until the very end of the migration\n                # process.\n                break\n            if migration in migrations_to_run:\n                if 'apps' not in state.__dict__:\n                    if self.progress_callback:\n                        self.progress_callback(\"render_start\")\n                    state.apps  # Render all -- performance critical\n                    if self.progress_callback:\n                        self.progress_callback(\"render_success\")\n                state = self.apply_migration(state, migration, fake=fake, fake_initial=fake_initial)\n                migrations_to_run.remove(migration)\n            elif migration in applied_migrations:\n                # Only mutate the state if the migration is actually applied\n                # to make sure the resulting state doesn't include changes\n                # from unrelated migrations.\n                migration.mutate_state(state, preserve=False)\n\n        return state"
            },
            {
                "file": "django/db/migrations/executor.py",
                "type": "function",
                "name": "_migrate_all_forwards",
                "class_name": "MigrationExecutor",
                "code": "def _migrate_all_forwards(self, plan, full_plan, fake, fake_initial):\n        \"\"\"\n        Take a list of 2-tuples of the form (migration instance, False) and\n        apply them in the order they occur in the full_plan.\n        \"\"\"\n        migrations_to_run = {m[0] for m in plan}\n        state = self._create_project_state()\n        applied_migrations = {\n            self.loader.graph.nodes[key] for key in self.loader.applied_migrations\n            if key in self.loader.graph.nodes\n        }\n        for migration, _ in full_plan:\n            if not migrations_to_run:\n                # We remove every migration that we applied from this set so\n                # that we can bail out once the last migration has been applied\n                # and don't always run until the very end of the migration\n                # process.\n                break\n            if migration in migrations_to_run:\n                if 'apps' not in state.__dict__:\n                    if self.progress_callback:\n                        self.progress_callback(\"render_start\")\n                    state.apps  # Render all -- performance critical\n                    if self.progress_callback:\n                        self.progress_callback(\"render_success\")\n                state = self.apply_migration(state, migration, fake=fake, fake_initial=fake_initial)\n                migrations_to_run.remove(migration)\n            elif migration in applied_migrations:\n                # Only mutate the state if the migration is actually applied\n                # to make sure the resulting state doesn't include changes\n                # from unrelated migrations.\n                migration.mutate_state(state, preserve=False)\n\n        return state"
            }
        ]
    },
    "Justification": "Candidate A is the most helpful because it directly involves the migration executor, which is a key component of the CURRENT bug's focus on sqlmigrate and transaction handling. Both bugs deal with the migration process in Django, and the solution for Candidate A involved changes to the migration executor's behavior, which aligns closely with the necessary fix for the CURRENT bug regarding the output of sqlmigrate. The involvement of similar files, the fix type related to migration handling, and shared structural issues in migration processing make this candidate exceptionally relevant for debugging the CURRENT bug."
}