{
  "original_problem": {
    "instance_id": "django__django-14730",
    "repo": "django/django",
    "created_at": "2021-08-03T04:27:52Z",
    "problem_statement": "Prevent developers from defining a related_name on symmetrical ManyToManyFields\nDescription\n\t\nIn ManyToManyField, if the symmetrical argument is passed, or if it's a self-referential ManyToMany relationship, the related field on the target model is not created. However, if a developer passes in the related_name not understanding this fact, they may be confused until they find the information about symmetrical relationship. Thus, it is proposed to raise an error when the user defines a ManyToManyField in this condition.\n",
    "patch": "diff --git a/django/db/models/fields/related.py b/django/db/models/fields/related.py\n--- a/django/db/models/fields/related.py\n+++ b/django/db/models/fields/related.py\n@@ -1258,6 +1258,16 @@ def _check_ignored_options(self, **kwargs):\n                 )\n             )\n \n+        if self.remote_field.symmetrical and self._related_name:\n+            warnings.append(\n+                checks.Warning(\n+                    'related_name has no effect on ManyToManyField '\n+                    'with a symmetrical relationship, e.g. to \"self\".',\n+                    obj=self,\n+                    id='fields.W345',\n+                )\n+            )\n+\n         return warnings\n \n     def _check_relationship_model(self, from_model=None, **kwargs):\n"
  },
  "candidates_evaluated": 5,
  "judgment_result": {
    "candidates": [
      {
        "idx": 1,
        "id": "similar_28871",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "The issue focuses on UI behavior and autocomplete functionality, which is unrelated to model field validation logic."
      },
      {
        "idx": 2,
        "id": "similar_25560",
        "decision": "Useful",
        "confidence": "High",
        "reason": "Both issues involve validation of the related_name attribute in Django models, focusing on preventing invalid configurations."
      },
      {
        "idx": 3,
        "id": "similar_25745",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue deals with model registration warnings, which is a different aspect of model management than field validation."
      },
      {
        "idx": 4,
        "id": "similar_27068",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "The issue is about form field data handling inconsistencies, unrelated to model field validation logic."
      },
      {
        "idx": 5,
        "id": "similar_31596",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue focuses on ForeignKey validation with custom managers, which is a different validation context than ManyToManyField related_name."
      }
    ]
  },
  "raw_summaries": [
    {
      "similar_issue": {
        "issue_title": "Autocomplete select for new lines in inline model do not open",
        "issue_body": "When a model has an Inline model, autocomplete select does not show for new rows.\nSelect box is is replaced with Select2 style, but clicking it does not show the select list.\nmodel.py\nclass\nItem\n(\nmodels\n.\nModel\n):\nname\n=\nmodels\n.\nCharField\n(\nmax_length\n=\n100\n)\nclass\nCategory\n(\nmodels\n.\nModel\n):\nname\n=\nmodels\n.\nCharField\n(\nmax_length\n=\n100\n)\ndef\n__str__\n(\nself\n):\nreturn\nself\n.\nname\nclass\nLineItem\n(\nmodels\n.\nModel\n):\nitem\n=\nmodels\n.\nForeignKey\n(\n'Item'\n,\non_delete\n=\nmodels\n.\nCASCADE\n)\ncategory\n=\nmodels\n.\nForeignKey\n(\n'Category'\n,\non_delete\n=\nmodels\n.\nCASCADE\n)\nadmin.py\nclass\nLineItemInline\n(\nadmin\n.\nTabularInline\n):\nmodel\n=\nLineItem\nextra\n=\n1\nautocomplete_fields\n=\n(\n'category'\n,)\n@admin\n.\nregister\n(\nItem\n)\nclass\nItemAdmin\n(\nadmin\n.\nModelAdmin\n):\nlist_display\n=\n(\n'name'\n,)\nsearch_fields\n=\n(\n'name'\n,)\ninlines\n=\n[\nLineItemInline\n]\n@admin\n.\nregister\n(\nCategory\n)\nclass\nCategoryAdmin\n(\nadmin\n.\nModelAdmin\n):\nlist_display\n=\n(\n'name'\n,)\nsearch_fields\n=\n(\n'name'\n,)\nGithub repo\nWith demo and instructions on how to reproduce\n​\nhttps://github.com/gotling/bug-django2-autocomplete",
        "issue_id": 28871,
        "pr_number": 9406,
        "pr_title": "Fixed #28871 -- Fixed initialization of autocomplete widgets in \"Add another\" inlines.",
        "pr_body": "https://code.djangoproject.com/ticket/28871",
        "issue_closed_at": "2017-12-01T21:42:03",
        "base_commit": "095c1aaa898bed40568009db836aa8434f1b983d"
      },
      "summary": "### Summary: \nThis issue pertains to a problem where autocomplete functionality in a Django admin interface does not work as expected for new rows in a tabular inline model setup. Specifically, when a model containing inline models is configured with Select2 for autocomplete fields, the dropdown list intended to provide autocomplete suggestions does not appear when the select box is clicked. This problem occurs in a Django application where the admin interface is customized using Select2 for better user experience.\n\n1. **Problem Description in General Terms**: Autocomplete functionality fails to activate for newly added rows in an inline model form within the Django admin interface. The select element, enhanced with Select2 for improved autocomplete, does not present its dropdown list, hindering user interaction.\n\n2. **Key Symptoms and Behaviors Observed**: \n   - The select box, intended for category selection in a line item inline form, fails to display the dropdown list when interacted with.\n   - The issue is specific to new rows added dynamically to the inline form within the admin interface.\n\n3. **Affected Components or Systems**: \n   - Django admin inline model forms, particularly those using Select2 for autocomplete fields.\n   - Backend model configuration involving ForeignKey relationships, where the autocomplete fields are specified.\n   \n4. **Potential Impact or Severity**: \n   - Users are unable to utilize the autocomplete feature for selecting categories in newly added inline items, potentially leading to inefficiencies and increased manual entry errors.\n   - This could affect the usability and user experience of the admin interface, especially in applications heavily reliant on dynamic form entries.\n\n5. **Relevant Technical Details Abstracted for Broader Understanding**: \n   - The issue involves Django's customization of admin forms using Select2 for autocomplete.\n   - Affected code components include the handling of ForeignKey fields in the admin's formfield generation functions and the initialization of the AutocompleteMixin.\n   - The problem was addressed by modifying the `BaseModelAdmin.formfield_for_foreignkey` and `BaseModelAdmin.formfield_for_manytomany` functions, as well as the `AutocompleteMixin.__init__` function within Django's admin options and widgets modules.",
      "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: Autocomplete select for new lines in inline model do not open\n\nBody:\nWhen a model has an Inline model, autocomplete select does not show for new rows.\nSelect box is is replaced with Select2 style, but clicking it does not show the select list.\nmodel.py\nclass\nItem\n(\nmodels\n.\nModel\n):\nname\n=\nmodels\n.\nCharField\n(\nmax_length\n=\n100\n)\nclass\nCategory\n(\nmodels\n.\nModel\n):\nname\n=\nmodels\n.\nCharField\n(\nmax_length\n=\n100\n)\ndef\n__str__\n(\nself\n):\nreturn\nself\n.\nname\nclass\nLineItem\n(\nmodels\n.\nModel\n):\nitem\n=\nmodels\n.\nForeignKey\n(\n'Item'\n,\non_delete\n=\nmodels\n.\nCASCADE\n)\ncategory\n=\nmodels\n.\nForeignKey\n(\n'Category'\n,\non_delete\n=\nmodels\n.\nCASCADE\n)\nadmin.py\nclass\nLineItemInline\n(\nadmin\n.\nTabularInline\n):\nmodel\n=\nLineItem\nextra\n=\n1\nautocomplete_fields\n=\n(\n'category'\n,)\n@admin\n.\nregister\n(\nItem\n)\nclass\nItemAdmin\n(\nadmin\n.\nModelAdmin\n):\nlist_display\n=\n(\n'name'\n,)\nsearch_fields\n=\n(\n'name'\n,)\ninlines\n=\n[\nLineItemInline\n]\n@admin\n.\nregister\n(\nCategory\n)\nclass\nCategoryAdmin\n(\nadmin\n.\nModelAdmin\n):\nlist_display\n=\n(\n'name'\n,)\nsearch_fields\n=\n(\n'name'\n,)\nGithub repo\nWith demo and instructions on how to reproduce\n​\nhttps://github.com/gotling/bug-django2-autocomplete\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/contrib/admin/options.py\n  function: BaseModelAdmin.formfield_for_foreignkey\n  function: BaseModelAdmin.formfield_for_manytomany\n\ndjango/contrib/admin/widgets.py\n  function: AutocompleteMixin.__init__\n"
    },
    {
      "similar_issue": {
        "issue_title": "Empty string related name should be invalid",
        "issue_body": "The actual model field check is\n​\nskipped\nif the\nrelated_name\nis an empty string when a warning should be raised since it's an invalid Python identifier.",
        "issue_id": 25560,
        "pr_number": 5437,
        "pr_title": "Fixed #25560 -- Made empty string related name invalid.",
        "pr_body": "Thanks to Ali Lotfi for the initial report and patch.\n",
        "issue_closed_at": "2015-10-16T13:18:21",
        "base_commit": "4dcc2a195595f8d7ddad45bc4baf98ffdeec7f41"
      },
      "summary": "### Summary:\nThis issue pertains to the validation of model field attributes in a software application, specifically dealing with the `related_name` attribute in a database model. The problem arises when the `related_name` is set to an empty string, which currently bypasses the validation checks. In general, an empty string is not a valid Python identifier, and as such, the system should issue a warning or error rather than skipping the validation.\n\n1. **Problem description in general terms:**\n   The software does not properly validate certain model field attributes when they are provided as empty strings, leading to potential misconfigurations that are not flagged to the developer.\n\n2. **Key symptoms and behaviors observed:**\n   The primary symptom is the absence of a warning or error message when an empty string is set as the `related_name` for a model field. This behavior results in the model field validation check being skipped, potentially allowing invalid identifiers to exist in the system.\n\n3. **Affected components or systems:**\n   The components affected by this issue are within the database model field validation logic of the application, specifically in the fields related to handling relationships between models, as seen in the files `django/db/models/fields/related.py` and `django/db/models/fields/reverse_related.py`.\n\n4. **Potential impact or severity:**\n   The impact of this issue could be moderate, as it may lead to developers unknowingly configuring model relationships incorrectly, which might cause unexpected behavior in the application. However, the severity is mitigated by the fact that it concerns a specific case of an empty string that could be manually checked by developers during review.\n\n5. **Any relevant technical details abstracted for broader understanding:**\n   The technical core of the issue involves the validation function `RelatedField._check_related_name_is_valid` in the `related.py` file and potentially the `ForeignObjectRel.get_db_prep_lookup` function in the `reverse_related.py` file. The fix involves ensuring that an empty string for `related_name` does not bypass validation checks and instead raises a warning or error to alert the developer to the invalid configuration.",
      "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: Empty string related name should be invalid\n\nBody:\nThe actual model field check is\n​\nskipped\nif the\nrelated_name\nis an empty string when a warning should be raised since it's an invalid Python identifier.\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/models/fields/related.py\n  function: RelatedField._check_related_name_is_valid\n\ndjango/db/models/fields/reverse_related.py\n  function: ForeignObjectRel.get_db_prep_lookup\n"
    },
    {
      "similar_issue": {
        "issue_title": "Fix RuntimeWarnings about model reloading in test suite",
        "issue_body": "Similar warnings to those reported in\n#24812\nare back in several apps:\norder_with_respect_to\n,\nforeign_object\n,\nschema\n.\nTo see the\norder_with_respect_to\nwarnings, you must also include\ncontenttypes_tests\n(these apps share models):\n$ python -Wall runtests.py order_with_respect_to contenttypes_tests\nExample:\n/home/tim/code/django/django/db/models/base.py:283: RuntimeWarning: Model 'order_with_respect_to.bar' was already registered. Reloading models is not advised as it can lead to inconsistencies, most notably with related models.\nWe should probably promote\nRuntimeWarning\nto \"error\" in\ntests/runtests.py\nto prevent future regressions.",
        "issue_id": 25745,
        "pr_number": 5657,
        "pr_title": "Ticket #25745 1.9 backport",
        "pr_body": "Will merge if CI pass.\n",
        "issue_closed_at": "2015-11-14T10:34:07",
        "base_commit": "84006fda55ffcaf272ca4fcd4addf7874302e884"
      },
      "summary": "### Summary:\nThis issue pertains to the reappearance of RuntimeWarnings related to model reloading within the Django test suite. Specifically, these warnings have been observed in multiple applications, such as `order_with_respect_to`, `foreign_object`, and `schema`. The warnings indicate that models are being registered multiple times, which is generally discouraged as it can result in inconsistencies, particularly concerning related models. The problem is illustrated through test runs that generate warnings when certain apps are included, suggesting that the issue is associated with specific model configurations shared among these applications.\n\nKey symptoms include RuntimeWarnings indicating that a model has been already registered, signaling potential problems with model reloading. These warnings are symptomatic of underlying issues in model registration logic, which can lead to broader system inconsistencies if not addressed.\n\nThe affected components are primarily within the Django framework's model registration and management system, as evidenced by the changes made in the `django/db/models/fields/related.py` file. Functions that handle the validation of related names and the existence of related models have been modified, indicating that the source of the warnings is related to these areas.\n\nThe potential impact of these warnings is significant. If left unresolved, they could lead to data integrity issues and application errors, particularly in systems relying heavily on model relationships. The warnings also pose a risk of regression in future test runs, highlighting the need for stricter error handling within the test suite to catch such issues early.\n\nFrom a technical perspective, the problem stems from the re-registration of models, which might be linked to specific model configurations or test setups. The suggestion to escalate RuntimeWarnings to errors during testing underscores the importance of maintaining strict model integrity and preventing similar issues from recurring.",
      "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: Fix RuntimeWarnings about model reloading in test suite\n\nBody:\nSimilar warnings to those reported in\n#24812\nare back in several apps:\norder_with_respect_to\n,\nforeign_object\n,\nschema\n.\nTo see the\norder_with_respect_to\nwarnings, you must also include\ncontenttypes_tests\n(these apps share models):\n$ python -Wall runtests.py order_with_respect_to contenttypes_tests\nExample:\n/home/tim/code/django/django/db/models/base.py:283: RuntimeWarning: Model 'order_with_respect_to.bar' was already registered. Reloading models is not advised as it can lead to inconsistencies, most notably with related models.\nWe should probably promote\nRuntimeWarning\nto \"error\" in\ntests/runtests.py\nto prevent future regressions.\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/models/fields/related.py\n  function: RelatedField._check_related_name_is_valid\n  function: RelatedField._check_relation_model_exists\n  function: ManyToManyField._check_relationship_model\n"
    },
    {
      "similar_issue": {
        "issue_title": "Acquire form's initial data more consistently",
        "issue_body": "In\nBoundField\n, sometimes initial data\n​\nhandles callables\n. While other times,\n​\nit doesn't\n. This can lead to a theoretical bug when the initial data is a callable, but the field is disabled.\nOther times, the initial callable is handled, but microseconds are\n​\nnot chopped\nleading to theoretical false positives that data has changed.\nInitial data should be handled more consistently across all cases.\nMarking as a bug due to the theoretical edge cases that can produce unexpected results. Noticed these inconsistencies while working on\n#27037\n.",
        "issue_id": 27068,
        "pr_number": 7097,
        "pr_title": "Fixed #27068 -- Unified form field initial data retrieval.",
        "pr_body": "https://code.djangoproject.com/ticket/27068\n",
        "issue_closed_at": "2016-08-18T19:51:32",
        "base_commit": "13857b45ca54a519a58361238442af84262c0d23"
      },
      "summary": "### Summary:\n\nThis issue pertains to inconsistent handling of initial data within a software component responsible for managing form fields. Specifically, the problem lies in the processing of initial data when it is provided as a callable. In certain scenarios, the system handles callable initial data correctly, while in others, it fails to do so, particularly when the form field is disabled. This inconsistency could lead to potential bugs where the callable data is not evaluated as expected. Additionally, there are instances where the system processes the initial callable data but fails to consistently truncate microseconds, potentially resulting in false positives when determining if data has changed.\n\nThe symptoms of this issue include unpredictable behavior in form data initialization, especially when dealing with callable initial values or when precise time data is involved. This inconsistency can produce erroneous results, particularly in edge cases, potentially leading to incorrect form submissions or data processing outcomes.\n\nThe affected components are primarily within the Django forms subsystem, specifically the BoundField and BaseForm classes. The functions within these classes responsible for managing field values and detecting changes were identified as needing adjustments to ensure consistent behavior.\n\nThe potential impact of this issue is moderate, as it can cause unexpected results in applications relying on form data consistency, particularly those utilizing callable initial values or requiring precise datetime comparisons. While these issues are theoretical and occur only in edge cases, they can undermine the reliability of form data handling in certain applications.\n\nThe technical resolution involved modifications to several functions within the Django forms codebase, ensuring that initial data is handled uniformly across all scenarios and that microsecond precision is consistently managed. This fix aims to standardize the behavior of form data handling, mitigating the risk of unexpected outcomes in applications using this framework.",
      "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: Acquire form's initial data more consistently\n\nBody:\nIn\nBoundField\n, sometimes initial data\n​\nhandles callables\n. While other times,\n​\nit doesn't\n. This can lead to a theoretical bug when the initial data is a callable, but the field is disabled.\nOther times, the initial callable is handled, but microseconds are\n​\nnot chopped\nleading to theoretical false positives that data has changed.\nInitial data should be handled more consistently across all cases.\nMarking as a bug due to the theoretical edge cases that can produce unexpected results. Noticed these inconsistencies while working on\n#27037\n.\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/forms/boundfield.py\n  function: BoundField.value\n  function: BoundField.id_for_label\n\ndjango/forms/forms.py\n  function: BaseForm._clean_fields\n  function: BaseForm.changed_data\n  function: BaseForm.visible_fields\n"
    },
    {
      "similar_issue": {
        "issue_title": "ForeignKey.validate() should validate using the base manager.",
        "issue_body": "ForeignKey.validate()\nshould validate using the base manager instead of the default manager.\nConsider the models:\nclass ArticleManager(models.Manage):\n    def get_queryset(self):\n        qs = super().get_queryset()\n        return qs.filter(archived=False)\n\nclass Article(models.Model):\n    title = models.CharField(max_length=100)\n    archived = models.BooleanField(default=False)\n\n    # Don't include archived articles by default.\n    objects = ArticleManager()\n\nclass FavoriteAricles(models.Model):\n    article = models.ForeignKey(Article, on_delete=models.CASCADE)\nIn the example, now consider a form that allows users to pick a favorite article including archived articles.\nclass FavoriteAriclesForm(forms.ModelForm):\n    class Meta:\n        model = FavoriteArticle\n        fields = '__all__'\n\n    def __init__(self, *args, **kwargs):\n        super().__init__(*args, **kwargs)\n        # Use the base manager instead of the default manager to allow archived articles.\n        self.fields['article'].queryset = Article._base_manager.all()\nThe above form will never validate as\nTrue\nwhen a user selects an archived article. This is because the ForeignKey validation always uses\n_default_manager\ninstead of\n_base_manager\n. The user facing error message is \"article instance with id 123 does not exist.\" (quite confusing to typical users). The code for this validation is here:\n​\nhttps://github.com/django/django/blob/94f63b926fd32d7a7b6e2591ef72aa8f040f25cc/django/db/models/fields/related.py#L917-L919\nThe\nFavoriteAriclesForm\nis specifically designed to use a different manager, but the ForeignKey validation makes this difficult.\nIn this example scenario, it is not acceptable to change the model's default manager as the default should avoid archived articles in other typical scenarios.\nSuggested solution: the ForeignKey validation should use the\n_base_manager\ninstead which does not include the default filters.",
        "issue_id": 31596,
        "pr_number": 13109,
        "pr_title": "Fixed #31596 -- Changed ForeignKey.validate() to use the base manager.",
        "pr_body": "Follow up from #12923 for which ~~GH seems~~ I seem to have _had a moment_...\r\n\r\n\r\ncc @jdufresne ",
        "issue_closed_at": "2020-06-25T04:36:37",
        "base_commit": "fbe82f82555bc25dccb476c749ca062f0b522be3"
      },
      "summary": "### Summary: This issue relates to the validation behavior of ForeignKey fields in Django models, particularly how they interact with custom managers that filter queryset results. The problem arises when ForeignKey.validate() relies on the default manager (_default_manager) rather than the base manager (_base_manager), which can lead to incorrect validation outcomes. This is especially problematic in scenarios where forms or other mechanisms need to include objects that are filtered out by the default manager. The key symptom is that archived objects, which might be excluded by default but are necessary for certain operations, trigger validation errors, leading to user confusion with inaccurate error messages indicating that specific object instances do not exist. The affected system component is Django's ForeignKey validation logic within the related field handling. The impact is significant in applications where specific object states (like archived status) need to be bypassed intentionally by custom forms or queries, leading to potential disruptions in user workflows and data handling. A technical solution involves updating the ForeignKey validation to leverage the base manager, allowing more flexible and accurate validation processes by bypassing default queryset filters.",
      "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: ForeignKey.validate() should validate using the base manager.\n\nBody:\nForeignKey.validate()\nshould validate using the base manager instead of the default manager.\nConsider the models:\nclass ArticleManager(models.Manage):\n    def get_queryset(self):\n        qs = super().get_queryset()\n        return qs.filter(archived=False)\n\nclass Article(models.Model):\n    title = models.CharField(max_length=100)\n    archived = models.BooleanField(default=False)\n\n    # Don't include archived articles by default.\n    objects = ArticleManager()\n\nclass FavoriteAricles(models.Model):\n    article = models.ForeignKey(Article, on_delete=models.CASCADE)\nIn the example, now consider a form that allows users to pick a favorite article including archived articles.\nclass FavoriteAriclesForm(forms.ModelForm):\n    class Meta:\n        model = FavoriteArticle\n        fields = '__all__'\n\n    def __init__(self, *args, **kwargs):\n        super().__init__(*args, **kwargs)\n        # Use the base manager instead of the default manager to allow archived articles.\n        self.fields['article'].queryset = Article._base_manager.all()\nThe above form will never validate as\nTrue\nwhen a user selects an archived article. This is because the ForeignKey validation always uses\n_default_manager\ninstead of\n_base_manager\n. The user facing error message is \"article instance with id 123 does not exist.\" (quite confusing to typical users). The code for this validation is here:\n​\nhttps://github.com/django/django/blob/94f63b926fd32d7a7b6e2591ef72aa8f040f25cc/django/db/models/fields/related.py#L917-L919\nThe\nFavoriteAriclesForm\nis specifically designed to use a different manager, but the ForeignKey validation makes this difficult.\nIn this example scenario, it is not acceptable to change the model's default manager as the default should avoid archived articles in other typical scenarios.\nSuggested solution: the ForeignKey validation should use the\n_base_manager\ninstead which does not include the default filters.\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/models/fields/related.py\n  function: ForeignKey.validate\n"
    }
  ]
}