{
  "Selected_candidate": {
    "pr_number": 14367,
    "pr_title": "Fixed #28935 -- Fixed display of errors in extended blocks.",
    "pr_body": "Fixed #27694 -- Exception debug info on correct template.",
    "issue_id": 28935,
    "issue_title": "Template error raised in an {% extends %} child template shows incorrect source location on debug page",
    "issue_body": "If an error occurs in the processing of a template tag on a template that extends another via\n{% extends %}\n, the \"Error during template rendering\" section of the debug page incorrectly shows an excerpt from the parent template rather than the child.\nTo reproduce:\nbase.html:\n{% block body %}{% endblock %}\nhome.html:\n{% extends \"base.html\" %}\n\n{% block body %}\n    {% include \"does_not_exist\" %}\n{% endblock %}\nviews.py:\nfrom django.shortcuts import render\n\ndef home(request):\n    return render(request, 'home.html')\nThe resulting error page displays:\nError during template rendering\nIn template /Users/matthew/Development/tbx/wagtail/debug/brokendebug/core/templates/base.html, error at line 0\n\ndoes_not_exist\n1\t{% block body %}{% endblock %}\n2\ninstead of the expected error output:\nError during template rendering\nIn template /Users/matthew/Development/tbx/wagtail/debug/brokendebug/core/templates/home.html, error at line 4\n\ndoes_not_exist\n1\t{% extends \"base.html\" %}\n2\t\n3\t{% block body %}\n4\t    {% include \"does_not_exist\" %}\n5\t{% endblock %}\n6\nBisecting shows that this bug was introduced in\n#27956\n(\ne643ba8bcf0b1da517cbab689ac157ee031202a3\n), which was a fix for the\nopposite\ncase: an error occurring on the parent template. (In the above test case, moving the line\n{% include \"does_not_exist\" %}\nto base.html turns it into a test case for\n#27956\n, and fails on pre-\ne643ba8bcf0b1da517cbab689ac157ee031202a3\nrevisions as expected.)",
    "issue_closed_at": "2021-07-02T05:20:43",
    "base_commit": "9f3cce172f6913c5ac74272fa5fc07f847b4e112",
    "changes": [
      {
        "file": "django/template/base.py",
        "type": "function",
        "name": "render_annotated",
        "class_name": "TextNode",
        "code": "def render_annotated(self, context):\n        \"\"\"\n        Return the given value.\n\n        The default implementation of this method handles exceptions raised\n        during rendering, which is not necessary for text nodes.\n        \"\"\"\n        return self.s"
      }
    ]
  },
  "Justification": "Candidate B is the most helpful because it involves errors during template rendering, similar to the rendering issue facing the CURRENT bug. Both reports discuss problems that arise when specific conditions in template processing lead to incorrect outputs. The nature of the error messages and how they relate to handling rendering logic in Django makes Candidate B particularly relevant as it identifies a specific incorrect display in the debug context that might parallel the problems happening with the `list_display` configuration in the CURRENT bug. This direct relevance to template errors provides actionable insights into debugging the error being faced currently.",
  "instance_id": "django__django-16816",
  "repo": "django/django",
  "created_at": "2023-04-30T15:37:43Z",
  "problem_statement": "Error E108 does not cover some cases\nDescription\n\t \n\t\t(last modified by Baha Sdtbekov)\n\t \nI have two models, Question and Choice. And if I write list_display = [\"choice\"] in QuestionAdmin, I get no errors.\nBut when I visit /admin/polls/question/, the following trace is returned:\nInternal Server Error: /admin/polls/question/\nTraceback (most recent call last):\n File \"/some/path/django/contrib/admin/utils.py\", line 334, in label_for_field\n\tfield = _get_non_gfk_field(model._meta, name)\n File \"/some/path/django/contrib/admin/utils.py\", line 310, in _get_non_gfk_field\n\traise FieldDoesNotExist()\ndjango.core.exceptions.FieldDoesNotExist\nDuring handling of the above exception, another exception occurred:\nTraceback (most recent call last):\n File \"/some/path/django/core/handlers/exception.py\", line 55, in inner\n\tresponse = get_response(request)\n File \"/some/path/django/core/handlers/base.py\", line 220, in _get_response\n\tresponse = response.render()\n File \"/some/path/django/template/response.py\", line 111, in render\n\tself.content = self.rendered_content\n File \"/some/path/django/template/response.py\", line 89, in rendered_content\n\treturn template.render(context, self._request)\n File \"/some/path/django/template/backends/django.py\", line 61, in render\n\treturn self.template.render(context)\n File \"/some/path/django/template/base.py\", line 175, in render\n\treturn self._render(context)\n File \"/some/path/django/template/base.py\", line 167, in _render\n\treturn self.nodelist.render(context)\n File \"/some/path/django/template/base.py\", line 1005, in render\n\treturn SafeString(\"\".join([node.render_annotated(context) for node in self]))\n File \"/some/path/django/template/base.py\", line 1005, in <listcomp>\n\treturn SafeString(\"\".join([node.render_annotated(context) for node in self]))\n File \"/some/path/django/template/base.py\", line 966, in render_annotated\n\treturn self.render(context)\n File \"/some/path/django/template/loader_tags.py\", line 157, in render\n\treturn compiled_parent._render(context)\n File \"/some/path/django/template/base.py\", line 167, in _render\n\treturn self.nodelist.render(context)\n File \"/some/path/django/template/base.py\", line 1005, in render\n\treturn SafeString(\"\".join([node.render_annotated(context) for node in self]))\n File \"/some/path/django/template/base.py\", line 1005, in <listcomp>\n\treturn SafeString(\"\".join([node.render_annotated(context) for node in self]))\n File \"/some/path/django/template/base.py\", line 966, in render_annotated\n\treturn self.render(context)\n File \"/some/path/django/template/loader_tags.py\", line 157, in render\n\treturn compiled_parent._render(context)\n File \"/some/path/django/template/base.py\", line 167, in _render\n\treturn self.nodelist.render(context)\n File \"/some/path/django/template/base.py\", line 1005, in render\n\treturn SafeString(\"\".join([node.render_annotated(context) for node in self]))\n File \"/some/path/django/template/base.py\", line 1005, in <listcomp>\n\treturn SafeString(\"\".join([node.render_annotated(context) for node in self]))\n File \"/some/path/django/template/base.py\", line 966, in render_annotated\n\treturn self.render(context)\n File \"/some/path/django/template/loader_tags.py\", line 63, in render\n\tresult = block.nodelist.render(context)\n File \"/some/path/django/template/base.py\", line 1005, in render\n\treturn SafeString(\"\".join([node.render_annotated(context) for node in self]))\n File \"/some/path/django/template/base.py\", line 1005, in <listcomp>\n\treturn SafeString(\"\".join([node.render_annotated(context) for node in self]))\n File \"/some/path/django/template/base.py\", line 966, in render_annotated\n\treturn self.render(context)\n File \"/some/path/django/template/loader_tags.py\", line 63, in render\n\tresult = block.nodelist.render(context)\n File \"/some/path/django/template/base.py\", line 1005, in render\n\treturn SafeString(\"\".join([node.render_annotated(context) for node in self]))\n File \"/some/path/django/template/base.py\", line 1005, in <listcomp>\n\treturn SafeString(\"\".join([node.render_annotated(context) for node in self]))\n File \"/some/path/django/template/base.py\", line 966, in render_annotated\n\treturn self.render(context)\n File \"/some/path/django/contrib/admin/templatetags/base.py\", line 45, in render\n\treturn super().render(context)\n File \"/some/path/django/template/library.py\", line 258, in render\n\t_dict = self.func(*resolved_args, **resolved_kwargs)\n File \"/some/path/django/contrib/admin/templatetags/admin_list.py\", line 326, in result_list\n\theaders = list(result_headers(cl))\n File \"/some/path/django/contrib/admin/templatetags/admin_list.py\", line 90, in result_headers\n\ttext, attr = label_for_field(\n File \"/some/path/django/contrib/admin/utils.py\", line 362, in label_for_field\n\traise AttributeError(message)\nAttributeError: Unable to lookup 'choice' on Question or QuestionAdmin\n[24/Apr/2023 15:43:32] \"GET /admin/polls/question/ HTTP/1.1\" 500 349913\nI suggest that error E108 be updated to cover this case as well\nFor reproduce see ​github\n",
  "patch": "diff --git a/django/contrib/admin/checks.py b/django/contrib/admin/checks.py\n--- a/django/contrib/admin/checks.py\n+++ b/django/contrib/admin/checks.py\n@@ -916,9 +916,10 @@ def _check_list_display_item(self, obj, item, label):\n                         id=\"admin.E108\",\n                     )\n                 ]\n-        if isinstance(field, models.ManyToManyField) or (\n-            getattr(field, \"rel\", None) and field.rel.field.many_to_one\n-        ):\n+        if (\n+            getattr(field, \"is_relation\", False)\n+            and (field.many_to_many or field.one_to_many)\n+        ) or (getattr(field, \"rel\", None) and field.rel.field.many_to_one):\n             return [\n                 checks.Error(\n                     f\"The value of '{label}' must not be a many-to-many field or a \"\n"
}