{
  "original_problem": {
    "instance_id": "django__django-12113",
    "repo": "django/django",
    "created_at": "2019-11-20T17:49:06Z",
    "problem_statement": "admin_views.test_multidb fails with persistent test SQLite database.\nDescription\n\t \n\t\t(last modified by Mariusz Felisiak)\n\t \nI've tried using persistent SQLite databases for the tests (to make use of\n--keepdb), but at least some test fails with:\nsqlite3.OperationalError: database is locked\nThis is not an issue when only using TEST[\"NAME\"] with \"default\" (which is good enough in terms of performance).\ndiff --git i/tests/test_sqlite.py w/tests/test_sqlite.py\nindex f1b65f7d01..9ce4e32e14 100644\n--- i/tests/test_sqlite.py\n+++ w/tests/test_sqlite.py\n@@ -15,9 +15,15 @@\n DATABASES = {\n\t 'default': {\n\t\t 'ENGINE': 'django.db.backends.sqlite3',\n+\t\t'TEST': {\n+\t\t\t'NAME': 'test_default.sqlite3'\n+\t\t},\n\t },\n\t 'other': {\n\t\t 'ENGINE': 'django.db.backends.sqlite3',\n+\t\t'TEST': {\n+\t\t\t'NAME': 'test_other.sqlite3'\n+\t\t},\n\t }\n }\n% tests/runtests.py admin_views.test_multidb -v 3 --keepdb --parallel 1\n…\nOperations to perform:\n Synchronize unmigrated apps: admin_views, auth, contenttypes, messages, sessions, staticfiles\n Apply all migrations: admin, sites\nRunning pre-migrate handlers for application contenttypes\nRunning pre-migrate handlers for application auth\nRunning pre-migrate handlers for application sites\nRunning pre-migrate handlers for application sessions\nRunning pre-migrate handlers for application admin\nRunning pre-migrate handlers for application admin_views\nSynchronizing apps without migrations:\n Creating tables...\n\tRunning deferred SQL...\nRunning migrations:\n No migrations to apply.\nRunning post-migrate handlers for application contenttypes\nRunning post-migrate handlers for application auth\nRunning post-migrate handlers for application sites\nRunning post-migrate handlers for application sessions\nRunning post-migrate handlers for application admin\nRunning post-migrate handlers for application admin_views\nSystem check identified no issues (0 silenced).\nERROR\n======================================================================\nERROR: setUpClass (admin_views.test_multidb.MultiDatabaseTests)\n----------------------------------------------------------------------\nTraceback (most recent call last):\n File \"…/Vcs/django/django/db/backends/utils.py\", line 84, in _execute\n\treturn self.cursor.execute(sql, params)\n File \"…/Vcs/django/django/db/backends/sqlite3/base.py\", line 391, in execute\n\treturn Database.Cursor.execute(self, query, params)\nsqlite3.OperationalError: database is locked\nThe above exception was the direct cause of the following exception:\nTraceback (most recent call last):\n File \"…/Vcs/django/django/test/testcases.py\", line 1137, in setUpClass\n\tcls.setUpTestData()\n File \"…/Vcs/django/tests/admin_views/test_multidb.py\", line 40, in setUpTestData\n\tusername='admin', password='something', email='test@test.org',\n File \"…/Vcs/django/django/contrib/auth/models.py\", line 158, in create_superuser\n\treturn self._create_user(username, email, password, **extra_fields)\n File \"…/Vcs/django/django/contrib/auth/models.py\", line 141, in _create_user\n\tuser.save(using=self._db)\n File \"…/Vcs/django/django/contrib/auth/base_user.py\", line 66, in save\n\tsuper().save(*args, **kwargs)\n File \"…/Vcs/django/django/db/models/base.py\", line 741, in save\n\tforce_update=force_update, update_fields=update_fields)\n File \"…/Vcs/django/django/db/models/base.py\", line 779, in save_base\n\tforce_update, using, update_fields,\n File \"…/Vcs/django/django/db/models/base.py\", line 870, in _save_table\n\tresult = self._do_insert(cls._base_manager, using, fields, update_pk, raw)\n File \"…/Vcs/django/django/db/models/base.py\", line 908, in _do_insert\n\tusing=using, raw=raw)\n File \"…/Vcs/django/django/db/models/manager.py\", line 82, in manager_method\n\treturn getattr(self.get_queryset(), name)(*args, **kwargs)\n File \"…/Vcs/django/django/db/models/query.py\", line 1175, in _insert\n\treturn query.get_compiler(using=using).execute_sql(return_id)\n File \"…/Vcs/django/django/db/models/sql/compiler.py\", line 1321, in execute_sql\n\tcursor.execute(sql, params)\n File \"…/Vcs/django/django/db/backends/utils.py\", line 67, in execute\n\treturn self._execute_with_wrappers(sql, params, many=False, executor=self._execute)\n File \"…/Vcs/django/django/db/backends/utils.py\", line 76, in _execute_with_wrappers\n\treturn executor(sql, params, many, context)\n File \"…/Vcs/django/django/db/backends/utils.py\", line 84, in _execute\n\treturn self.cursor.execute(sql, params)\n File \"…/Vcs/django/django/db/utils.py\", line 89, in __exit__\n\traise dj_exc_value.with_traceback(traceback) from exc_value\n File \"…/Vcs/django/django/db/backends/utils.py\", line 84, in _execute\n\treturn self.cursor.execute(sql, params)\n File \"…/Vcs/django/django/db/backends/sqlite3/base.py\", line 391, in execute\n\treturn Database.Cursor.execute(self, query, params)\ndjango.db.utils.OperationalError: database is locked\n",
    "patch": "diff --git a/django/db/backends/sqlite3/creation.py b/django/db/backends/sqlite3/creation.py\n--- a/django/db/backends/sqlite3/creation.py\n+++ b/django/db/backends/sqlite3/creation.py\n@@ -98,4 +98,6 @@ def test_db_signature(self):\n         sig = [self.connection.settings_dict['NAME']]\n         if self.is_in_memory_db(test_database_name):\n             sig.append(self.connection.alias)\n+        else:\n+            sig.append(test_database_name)\n         return tuple(sig)\n"
  },
  "candidates_evaluated": 5,
  "judgment_result": {
    "candidates": [
      {
        "idx": 1,
        "id": "similar_30318",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "The issue focuses on import errors and error handling, which is unrelated to database locking or concurrency issues."
      },
      {
        "idx": 2,
        "id": "similar_26647",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "This issue deals with migration state management, which does not relate to database locking or concurrency problems."
      },
      {
        "idx": 3,
        "id": "similar_29897",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue is about foreign key resolution in migrations, not about database locking or concurrency."
      },
      {
        "idx": 4,
        "id": "similar_23071",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "This issue involves circular dependencies in migrations, which is unrelated to database locking or concurrency."
      },
      {
        "idx": 5,
        "id": "similar_24054",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "The issue concerns sequence resets in migrations, which does not relate to database locking or concurrency issues."
      }
    ]
  },
  "raw_summaries": [
    {
      "similar_issue": {
        "issue_title": "Add new system check message when custom error handler 'path.to.view' cannot be imported",
        "issue_body": "#29642\nadded checks for the signatures of custom error handlers.\nWhen the 'path.to.view' cannot be imported, it raises ModuleNotFoundError or ViewDoesNotExist, as seen in this Stack Overflow question:\n​\nhttps://stackoverflow.com/q/55481810/113962\nI suggest we catch the exception, and add another check code, e.g.\n* **urls.E008**: The custom ``handlerXXX`` view ``'path.to.view'`` cannot be imported.",
        "issue_id": 30318,
        "pr_number": 11169,
        "pr_title": "Fixed #30318 --  Added check for importability of arguments of custom error handler views.",
        "pr_body": "…mported\r\n\r\nThanks to Jon on Stack Overflow for reporting the issue.",
        "issue_closed_at": "2019-04-25T04:38:58",
        "base_commit": "fc9566d42daf28cdaa25a5db1b5ade253ceb064f"
      },
      "summary": "### Summary: This issue concerns the handling of import errors in custom error handlers within a web application framework. Specifically, when a custom error handler specified by a path such as 'path.to.view' cannot be imported, it previously led to exceptions like ModuleNotFoundError or ViewDoesNotExist without a clear system check message. The proposed solution involves introducing a new check code (e.g., urls.E008) to provide a more informative error message when such an import failure occurs, enhancing the framework's error handling capabilities.\n\n1. **Problem description in general terms**: The problem arises when a custom error handler, defined by a specific path, fails to import due to missing or incorrect module paths. This leads to exceptions that are not adequately communicated to the developer, making debugging difficult.\n\n2. **Key symptoms and behaviors observed**: The main symptom is the occurrence of import-related exceptions such as ModuleNotFoundError or ViewDoesNotExist when the system attempts to import a custom error handler. This issue is typically observed during application runtime or deployment.\n\n3. **Affected components or systems**: The issue primarily affects the URL resolving component of web application frameworks, particularly those that allow the customization of error handling views through specified paths.\n\n4. **Potential impact or severity**: The impact is moderate, as it affects the developer's ability to diagnose and fix configuration errors related to custom error handlers. Without informative error messages, developers may struggle to identify the root cause of the problem, potentially delaying the resolution process.\n\n5. **Relevant technical details abstracted for broader understanding**: The issue involves the system's inability to import a specified module, leading to a need for improved error reporting. The proposed solution includes modifying the URL resolver's functionality to include a new check code that provides a clear and specific error message when an import fails, aiding in faster troubleshooting and resolution.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: Add new system check message when custom error handler 'path.to.view' cannot be imported\n\nBody:\n#29642\nadded checks for the signatures of custom error handlers.\nWhen the 'path.to.view' cannot be imported, it raises ModuleNotFoundError or ViewDoesNotExist, as seen in this Stack Overflow question:\n​\nhttps://stackoverflow.com/q/55481810/113962\nI suggest we catch the exception, and add another check code, e.g.\n* **urls.E008**: The custom ``handlerXXX`` view ``'path.to.view'`` cannot be imported.\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\ndjango/urls/resolvers.py\n  line: line 15\n  function: URLResolver._check_custom_error_handlers\n"
    },
    {
      "similar_issue": {
        "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_id": 26647,
        "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_closed_at": "2016-05-26T12:29:12",
        "base_commit": "30d110ef43d8a3c50ea8ec4e4fe49bd2bb859530"
      },
      "summary": "### Summary:\n\nThis issue arises from a problem related to the handling of migrations in a software system, specifically involving the post-migrate signal and its interaction with content type models. When a migration is unapplied and then reapplied, the system may incorrectly reference an outdated model of the ContentType due to the way the migration executor manages state. This results in inconsistencies where an old model version, including obsolete fields, can persist in the application's state.\n\nKey symptoms include failing tests in the application where the migration sequence does not align correctly, causing the migration executor to utilize an outdated model state. This behavior is observed in scenarios where migrations that should have removed fields or made changes to models are improperly ordered, leading to unexpected outcomes during execution.\n\nThe affected components include the migration system, specifically the migration executor's handling of state and how it interprets the order of migrations. The issue primarily impacts systems relying heavily on Django's migration framework and can potentially affect any applications where migrations alter content type models.\n\nThe severity of the issue is significant, as it can lead to application crashes or incorrect application behavior due to reliance on outdated model states. This can hinder development and deployment processes, particularly in environments where frequent migration changes are necessary.\n\nTechnically, the problem is rooted in the migration executor's state management, which does not account for changes in model structure effectively across unapplied and reapplied migrations. The issue is resolved through code changes in the `django/db/migrations/executor.py` file, specifically within the `MigrationExecutor._migrate_all_forwards` function, ensuring that the migration state reflects the current model definitions accurately after migrations are applied.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: Post migrate signal old content type model\n\nBody:\nSince 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.\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\ndjango/db/migrations/executor.py\n  function: MigrationExecutor._migrate_all_forwards\n  function: MigrationExecutor._migrate_all_forwards\n"
    },
    {
      "similar_issue": {
        "issue_title": "Initial migration fails when referencing a custom user model from a sequence of at least two concrete ancestor models",
        "issue_body": "The following model fails on initial migration.\nfrom django.db import models\nfrom django.contrib.auth.models import (AbstractBaseUser)\n\nclass A(models.Model):\n    createdByUser = models.ForeignKey('User', related_name='creations+', verbose_name='creatorUser', blank=True, null=True, editable=False, on_delete=models.PROTECT)\n\nclass B(A):\n    pass\n\nclass User(AbstractBaseUser, B):\n    email = models.EmailField('email address', max_length=256, unique=True, db_index=True)\n    USERNAME_FIELD = 'email'\n\n    @property\n    def username(self):\n         return self.email\nsettings.py contains:\nAUTH_USER_MODEL = 'core.User'\nOutput of running the migrations:\nApplying core.0001_initial...Traceback (most recent call last):\n  File \"./manage.py\", line 13, in <module>\n    execute_from_command_line(sys.argv)\n  File \".../lib/python3.6/site-packages/django/core/management/__init__.py\", line 364, in execute_from_command_line\n    utility.execute()\n  File \".../lib/python3.6/site-packages/django/core/management/__init__.py\", line 356, in execute\n    self.fetch_command(subcommand).run_from_argv(self.argv)\n  File \".../lib/python3.6/site-packages/django/core/management/base.py\", line 283, in run_from_argv\n    self.execute(*args, **cmd_options)\n  File \".../lib/python3.6/site-packages/django/core/management/base.py\", line 330, in execute\n    output = self.handle(*args, **options)\n  File \".../lib/python3.6/site-packages/django/core/management/commands/migrate.py\", line 204, in handle\n    fake_initial=fake_initial,\n  File \".../lib/python3.6/site-packages/django/db/migrations/executor.py\", line 115, in migrate\n    state = self._migrate_all_forwards(state, plan, full_plan, fake=fake, fake_initial=fake_initial)\n  File \".../lib/python3.6/site-packages/django/db/migrations/executor.py\", line 145, in _migrate_all_forwards\n    state = self.apply_migration(state, migration, fake=fake, fake_initial=fake_initial)\n  File \".../lib/python3.6/site-packages/django/db/migrations/executor.py\", line 244, in apply_migration\n    state = migration.apply(state, schema_editor)\n  File \".../lib/python3.6/site-packages/django/db/migrations/migration.py\", line 129, in apply\n    operation.database_forwards(self.app_label, schema_editor, old_state, project_state)\n  File \".../lib/python3.6/site-packages/django/db/migrations/operations/fields.py\", line 88, in database_forwards\n    field,\n  File \".../lib/python3.6/site-packages/django/db/backends/base/schema.py\", line 431, in add_field\n    definition, params = self.column_sql(model, field, include_default=True)\n  File \".../lib/python3.6/site-packages/django/db/backends/base/schema.py\", line 160, in column_sql\n    db_params = field.db_parameters(connection=self.connection)\n  File \".../lib/python3.6/site-packages/django/db/models/fields/related.py\", line 994, in db_parameters\n    return {\"type\": self.db_type(connection), \"check\": self.db_check(connection)}\n  File \".../lib/python3.6/site-packages/django/db/models/fields/related.py\", line 991, in db_type\n    return self.target_field.rel_db_type(connection=connection)\n  File \".../lib/python3.6/site-packages/django/db/models/fields/related.py\", line 909, in target_field\n    return self.foreign_related_fields[0]\n  File \".../lib/python3.6/site-packages/django/db/models/fields/related.py\", line 653, in foreign_related_fields\n    return tuple(rhs_field for lhs_field, rhs_field in self.related_fields if rhs_field)\n  File \".../lib/python3.6/site-packages/django/db/models/fields/related.py\", line 640, in related_fields\n    self._related_fields = self.resolve_related_fields()\n  File \".../lib/python3.6/site-packages/django/db/models/fields/related.py\", line 625, in resolve_related_fields\n    raise ValueError('Related model %r cannot be resolved' % self.remote_field.model)\nValueError: Related model 'core.User' cannot be resolved\nNotably, this works fine with any of the following modifications:\nmodel B is removed, closing the chain\ncreatedByUser is moved to B or removed altogether\neither A or B is made abstract\nthe referenced model is not the custom user model\nThis is not just a matter of preference for concrete classes, as only a concrete class can be referenced through a foreign key.",
        "issue_id": 29897,
        "pr_number": 10577,
        "pr_title": "Fixed #29897 -- Adjusted auto-detector swappable MTI dependency resolution.",
        "pr_body": "https://code.djangoproject.com/ticket/29897",
        "issue_closed_at": "2018-10-29T10:54:36",
        "base_commit": "82353ef940ba661e8c4c1cbc47eb2f62192e4fbe"
      },
      "summary": "### Summary:\nThis issue is related to a failure in initial database migrations when using Django with a custom user model that inherits from a sequence of at least two concrete ancestor models. The problem arises specifically when a model includes a foreign key reference to a custom user model within a multi-level class inheritance hierarchy.\n\n1. **Problem Description in General Terms**:\n   The issue occurs during the migration process in a Django application, where the database schema is being set up for the first time. The problem specifically arises when a custom user model is involved in a class inheritance chain with at least two concrete classes, and a foreign key reference is made to this user model.\n\n2. **Key Symptoms and Behaviors Observed**:\n   When attempting to apply the initial migration, the process fails with a traceback error indicating that the related model 'core.User' cannot be resolved. This suggests a failure in correctly identifying and linking the custom user model in the migration's foreign key relationships.\n\n3. **Affected Components or Systems**:\n   - Django's migration system, particularly the components responsible for handling foreign key relationships and model inheritance.\n   - The custom user model configuration in Django, as defined in the `AUTH_USER_MODEL` setting.\n\n4. **Potential Impact or Severity**:\n   The issue is significant in that it prevents the successful application of initial migrations, which is a critical step in setting up a Django application. This could block the deployment of applications that rely on a custom user model with complex inheritance structures, potentially impacting development and production environments.\n\n5. **Relevant Technical Details Abstracted for Broader Understanding**:\n   - The problem is related to Django's handling of foreign key references in models with multi-level concrete class inheritance.\n   - The failure occurs during the resolution of related fields when the migration system attempts to identify the target model for the foreign key.\n   - Known workarounds include removing intermediate concrete classes, making classes abstract, or altering the foreign key reference to avoid the custom user model.\n\nChanges Summary:\nThe issue was addressed by modifying the `MigrationAutodetector._sort_migrations` function in the `django/db/migrations/autodetector.py` file.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: Initial migration fails when referencing a custom user model from a sequence of at least two concrete ancestor models\n\nBody:\nThe following model fails on initial migration.\nfrom django.db import models\nfrom django.contrib.auth.models import (AbstractBaseUser)\n\nclass A(models.Model):\n    createdByUser = models.ForeignKey('User', related_name='creations+', verbose_name='creatorUser', blank=True, null=True, editable=False, on_delete=models.PROTECT)\n\nclass B(A):\n    pass\n\nclass User(AbstractBaseUser, B):\n    email = models.EmailField('email address', max_length=256, unique=True, db_index=True)\n    USERNAME_FIELD = 'email'\n\n    @property\n    def username(self):\n         return self.email\nsettings.py contains:\nAUTH_USER_MODEL = 'core.User'\nOutput of running the migrations:\nApplying core.0001_initial...Traceback (most recent call last):\n  File \"./manage.py\", line 13, in <module>\n    execute_from_command_line(sys.argv)\n  File \".../lib/python3.6/site-packages/django/core/management/__init__.py\", line 364, in execute_from_command_line\n    utility.execute()\n  File \".../lib/python3.6/site-packages/django/core/management/__init__.py\", line 356, in execute\n    self.fetch_command(subcommand).run_from_argv(self.argv)\n  File \".../lib/python3.6/site-packages/django/core/management/base.py\", line 283, in run_from_argv\n    self.execute(*args, **cmd_options)\n  File \".../lib/python3.6/site-packages/django/core/management/base.py\", line 330, in execute\n    output = self.handle(*args, **options)\n  File \".../lib/python3.6/site-packages/django/core/management/commands/migrate.py\", line 204, in handle\n    fake_initial=fake_initial,\n  File \".../lib/python3.6/site-packages/django/db/migrations/executor.py\", line 115, in migrate\n    state = self._migrate_all_forwards(state, plan, full_plan, fake=fake, fake_initial=fake_initial)\n  File \".../lib/python3.6/site-packages/django/db/migrations/executor.py\", line 145, in _migrate_all_forwards\n    state = self.apply_migration(state, migration, fake=fake, fake_initial=fake_initial)\n  File \".../lib/python3.6/site-packages/django/db/migrations/executor.py\", line 244, in apply_migration\n    state = migration.apply(state, schema_editor)\n  File \".../lib/python3.6/site-packages/django/db/migrations/migration.py\", line 129, in apply\n    operation.database_forwards(self.app_label, schema_editor, old_state, project_state)\n  File \".../lib/python3.6/site-packages/django/db/migrations/operations/fields.py\", line 88, in database_forwards\n    field,\n  File \".../lib/python3.6/site-packages/django/db/backends/base/schema.py\", line 431, in add_field\n    definition, params = self.column_sql(model, field, include_default=True)\n  File \".../lib/python3.6/site-packages/django/db/backends/base/schema.py\", line 160, in column_sql\n    db_params = field.db_parameters(connection=self.connection)\n  File \".../lib/python3.6/site-packages/django/db/models/fields/related.py\", line 994, in db_parameters\n    return {\"type\": self.db_type(connection), \"check\": self.db_check(connection)}\n  File \".../lib/python3.6/site-packages/django/db/models/fields/related.py\", line 991, in db_type\n    return self.target_field.rel_db_type(connection=connection)\n  File \".../lib/python3.6/site-packages/django/db/models/fields/related.py\", line 909, in target_field\n    return self.foreign_related_fields[0]\n  File \".../lib/python3.6/site-packages/django/db/models/fields/related.py\", line 653, in foreign_related_fields\n    return tuple(rhs_field for lhs_field, rhs_field in self.related_fields if rhs_field)\n  File \".../lib/python3.6/site-packages/django/db/models/fields/related.py\", line 640, in related_fields\n    self._related_fields = self.resolve_related_fields()\n  File \".../lib/python3.6/site-packages/django/db/models/fields/related.py\", line 625, in resolve_related_fields\n    raise ValueError('Related model %r cannot be resolved' % self.remote_field.model)\nValueError: Related model 'core.User' cannot be resolved\nNotably, this works fine with any of the following modifications:\nmodel B is removed, closing the chain\ncreatedByUser is moved to B or removed altogether\neither A or B is made abstract\nthe referenced model is not the custom user model\nThis is not just a matter of preference for concrete classes, as only a concrete class can be referenced through a foreign key.\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\ndjango/db/migrations/autodetector.py\n  function: MigrationAutodetector._sort_migrations\n"
    },
    {
      "similar_issue": {
        "issue_title": "Can't create migration for apps that have ForeignKeys to each other",
        "issue_body": "ForeignKey's to other apps create a dependency on\n__latest__\nmigration of that app. Because of this we can't create migrations where we have ForeignKey relations that go both ways, because that would result in app1 depending on\n__latest__\nof app2 and app2 depending on\n__latest__\nof app1. Way to reproduce:\nCreate the following model in myapp1:\nclass Model1(models.Model):\n    field = models.CharField(max_length=10)\nAnd the following model in myapp2:\nclass Model2(models.Model):\n    field = models.CharField(max_length=10)\nWe run makemigations creating both initial migrations. We then add the following model in myapp1:\nclass Model3(models.Model):\n    model2 = models.ForeignKey('myapp2.Model2')\nWe run makemigrations again, this will create a myapp1 migration that depends on\n__latest__\nof myapp2.\nThen we add the following model to myapp2:\nclass Model4(models.Model):\n    model1 = models.ForeignKey('myapp1.Model1')\nWe then run makemigrations again, this will create a myapp2 migration that depends on\n__latest__\nof myapp1. Running migrate then gives us a circular dependency error:\ndjango.db.migrations.graph.CircularDependencyError: [('myapp1', u'0002_model3'), ('myapp2', u'0002_model4'), ('myapp1', u'0002_model3')]\nI think the correct way to create dependency would be to create an explicit dependency on the latest migration of the other app at the time of creating the new ForeigKey instead of using\n__latest__\n. This will mean that the second myapp1 migration will depend on myapp2's 0001_initial, and the second myapp2 migration will depend on myapp1's 0002_model3.\nI tested this and it seems to work fine.",
        "issue_id": 23071,
        "pr_number": 2938,
        "pr_title": "Fixed #23071 -- Use last migration's name in dependency to other app",
        "pr_body": "Changed the autodetector to lookup the name of the other app's last\nmigration in the graph and use that as dependency instead of using\n**latest**.\n",
        "issue_closed_at": "2014-07-25T10:54:21",
        "base_commit": "b4cf7e3d1de2d9700812872b04f6fe8eb88e8bff"
      },
      "summary": "### Summary: This issue is a circular dependency problem that arises when attempting to create database migrations in Django for applications that have bidirectional ForeignKey relationships. When two Django applications have models with ForeignKey fields that reference each other, a situation can occur where each application's migration becomes dependent on the latest migration of the other application. This creates a circular dependency, preventing the successful execution of migrations.\n\n1. **Problem description in general terms**: The core issue involves the creation of database migrations in Django when two applications have models with mutual ForeignKey relationships. The automatic migration system tries to resolve dependencies using the latest migration from each application, which results in a circular dependency that cannot be resolved, causing migration failures.\n\n2. **Key symptoms and behaviors observed**: The primary symptom is the occurrence of a CircularDependencyError when attempting to run migrations. This error indicates that there is a dependency loop between the migrations of the two applications involved, preventing Django from determining a valid order for applying the migrations.\n\n3. **Affected components or systems**: The affected components are the Django migration system, specifically the modules responsible for detecting changes and loading migrations: `django/db/migrations/autodetector.py` and `django/db/migrations/loader.py`. The problem impacts applications with models that have mutual ForeignKey dependencies.\n\n4. **Potential impact or severity**: The severity of this issue is moderate, as it blocks the deployment of database schema changes for affected applications. It can cause development delays and complicate the management of database migrations. However, the problem can be mitigated with a manual workaround of specifying explicit migration dependencies.\n\n5. **Any relevant technical details abstracted for broader understanding**: The technical issue stems from the use of `__latest__` as a dependency marker in migrations, which leads to circular references when two applications reference each other. The proposed solution is to explicitly specify the migration dependencies based on the current state of the other application at the time the ForeignKey is added, rather than relying on the latest migration reference. This approach prevents the formation of circular dependencies by grounding the migration dependencies to specific, known states.\n\nThe changes involve modifying the migration detection and loading logic to accommodate this explicit dependency approach, ensuring that migrations can be applied in a valid sequence without encountering circular dependency errors.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: Can't create migration for apps that have ForeignKeys to each other\n\nBody:\nForeignKey's to other apps create a dependency on\n__latest__\nmigration of that app. Because of this we can't create migrations where we have ForeignKey relations that go both ways, because that would result in app1 depending on\n__latest__\nof app2 and app2 depending on\n__latest__\nof app1. Way to reproduce:\nCreate the following model in myapp1:\nclass Model1(models.Model):\n    field = models.CharField(max_length=10)\nAnd the following model in myapp2:\nclass Model2(models.Model):\n    field = models.CharField(max_length=10)\nWe run makemigations creating both initial migrations. We then add the following model in myapp1:\nclass Model3(models.Model):\n    model2 = models.ForeignKey('myapp2.Model2')\nWe run makemigrations again, this will create a myapp1 migration that depends on\n__latest__\nof myapp2.\nThen we add the following model to myapp2:\nclass Model4(models.Model):\n    model1 = models.ForeignKey('myapp1.Model1')\nWe then run makemigrations again, this will create a myapp2 migration that depends on\n__latest__\nof myapp1. Running migrate then gives us a circular dependency error:\ndjango.db.migrations.graph.CircularDependencyError: [('myapp1', u'0002_model3'), ('myapp2', u'0002_model4'), ('myapp1', u'0002_model3')]\nI think the correct way to create dependency would be to create an explicit dependency on the latest migration of the other app at the time of creating the new ForeigKey instead of using\n__latest__\n. This will mean that the second myapp1 migration will depend on myapp2's 0001_initial, and the second myapp2 migration will depend on myapp1's 0002_model3.\nI tested this and it seems to work fine.\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\ndjango/db/migrations/autodetector.py\n  function: MigrationAutodetector._detect_changes\n\ndjango/db/migrations/loader.py\n  function: MigrationLoader.get_migration_by_prefix\n"
    },
    {
      "similar_issue": {
        "issue_title": "Enable sqlsequencereset for apps with migrations",
        "issue_body": "The command doesn't depend on the\nDatabaseCreation\nclass and it doesn't seem that the problem the command aims to solve is obsoleted by migrations.",
        "issue_id": 24054,
        "pr_number": 3792,
        "pr_title": "Fixed #24054 -- Enabled sqlsequencereset for apps with migrations.",
        "pr_body": "https://code.djangoproject.com/ticket/24054\n",
        "issue_closed_at": "2014-12-26T14:56:14",
        "base_commit": "1729a5250b052832540cd696df3ff0a0a77baddf"
      },
      "summary": "### Summary:\nThis issue is related to the functionality of the `sqlsequencereset` command within applications that utilize database migrations. In general terms, the problem arises from the command's design, which does not rely on the `DatabaseCreation` class and appears unaffected by the introduction of migrations. This suggests a potential oversight in adapting the command to work seamlessly with modern database migration practices.\n\nKey symptoms and behaviors observed include the command's inability to properly reset SQL sequences for applications that have undergone migrations, potentially leading to inconsistencies or failures in database operations that rely on sequence resets.\n\nThe affected component is the `sqlsequencereset` command located within the Django core management commands, specifically impacting applications that use Django's migration framework.\n\nThe potential impact is moderate to high, as it pertains to the core functionality of database sequence management, which is crucial for maintaining data integrity and ensuring correct database operations across applications using migrations.\n\nRelevant technical details abstracted for broader understanding include the independence of the `sqlsequencereset` command from the `DatabaseCreation` class, indicating that any assumptions about its deprecation due to migrations are incorrect. The resolution involved updating the implementation within `django/core/management/commands/sqlsequencereset.py`, particularly in the `Command.handle_app_config` function, to ensure compatibility with migration-enabled applications.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: Enable sqlsequencereset for apps with migrations\n\nBody:\nThe command doesn't depend on the\nDatabaseCreation\nclass and it doesn't seem that the problem the command aims to solve is obsoleted by migrations.\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\ndjango/core/management/commands/sqlsequencereset.py\n  line: line 1\n  function: Command.handle_app_config\n"
    }
  ]
}