{
  "Selected_candidate": {
    "pr_number": 10416,
    "pr_title": "Fixed #29673 -- Reset URLconf at the end of request processing",
    "pr_body": "Fixes [ticket 29673](https://code.djangoproject.com/ticket/29673)\r\n\r\nWe attach a signal handler to request_finished, and reset the URLconf. Before this change, the URLconf is not reset until the start of the next request.",
    "issue_id": 29673,
    "issue_title": "Thread urlconf isn't reset after response complete",
    "issue_body": "When setting the urlconf on a request (e.g. in middleware for handling multiple domains pointing to the same Django app), it's not reset until the start of the next request. Since urlconf is threadlocal, this causes problems when running a suite of tests, even if the tests pass when ran individually. For example:\nDjango test client makes a request that triggers a middleware to change the urlconf\nreverse\nis called with no\nurlconf\nkwarg, expecting to be given the urlconf specified by\nROOT_URLCONF\ntest throws\nNoReverseMatch\nI took this problem to the IRC and found that another person recently messaged about the same thing:\n​\nhttps://botbot.me/freenode/django/2018-08-07/?msg=103000008&page=3",
    "issue_closed_at": "2018-09-26T14:35:46",
    "base_commit": "e40e7026cad400d720963aea0ba156a19f83b058",
    "changes": [
      {
        "file": "django/core/handlers/base.py",
        "type": "line",
        "name": "line 3",
        "code": "\nfrom django.conf import settings\nfrom django.core.exceptions import ImproperlyConfigured, MiddlewareNotUsed\nfrom django.db import connections, transaction\nfrom django.urls import get_resolver, set_urlconf\nfrom django.utils.log import log_response"
      },
      {
        "file": "django/core/handlers/base.py",
        "type": "function",
        "name": "process_exception_by_middleware",
        "class_name": "BaseHandler",
        "code": "def process_exception_by_middleware(self, exception, request):\n        \"\"\"\n        Pass the exception to the exception middleware. If no middleware\n        return a response for this exception, raise it.\n        \"\"\"\n        for middleware_method in self._exception_middleware:\n            response = middleware_method(request, exception)\n            if response:\n                return response\n        raise"
      }
    ]
  },
  "Justification": "Candidate A is the most helpful because it directly involves the handling of exceptions and uses a logging mechanism similar to what is suggested for `Signal.send_robust()`. Both bugs address issues related to logging and error management, making the insights from Candidate A particularly relevant to enhancing the logging capabilities in the CURRENT bug report. Furthermore, it deals with changes in Django's request handling which could shed light on effective logging practices across different methods.",
  "instance_id": "django__django-13768",
  "repo": "django/django",
  "created_at": "2020-12-12T07:34:48Z",
  "problem_statement": "Log exceptions handled in Signal.send_robust()\nDescription\n\t\nAs pointed out by ​Haki Benita on Twitter, by default Signal.send_robust() doesn't have any log messages for exceptions raised in receivers. Since Django logs exceptions in other similar situations, such as missing template variables, I think it would be worth adding a logger.exception() call in the except clause of send_robust() . Users would then see such exceptions in their error handling tools, e.g. Sentry, and be able to figure out what action to take from there. Ultimately any *expected* exception should be caught with a try in the receiver function.\n",
  "patch": "diff --git a/django/dispatch/dispatcher.py b/django/dispatch/dispatcher.py\n--- a/django/dispatch/dispatcher.py\n+++ b/django/dispatch/dispatcher.py\n@@ -1,3 +1,4 @@\n+import logging\n import threading\n import warnings\n import weakref\n@@ -5,6 +6,8 @@\n from django.utils.deprecation import RemovedInDjango40Warning\n from django.utils.inspect import func_accepts_kwargs\n \n+logger = logging.getLogger('django.dispatch')\n+\n \n def _make_id(target):\n     if hasattr(target, '__func__'):\n@@ -208,6 +211,12 @@ def send_robust(self, sender, **named):\n             try:\n                 response = receiver(signal=self, sender=sender, **named)\n             except Exception as err:\n+                logger.error(\n+                    'Error calling %s in Signal.send_robust() (%s)',\n+                    receiver.__qualname__,\n+                    err,\n+                    exc_info=err,\n+                )\n                 responses.append((receiver, err))\n             else:\n                 responses.append((receiver, response))\n"
}