Changed django.utils.log.log_response() to take exception instance.

There's little point retrieving a fresh reference to the exception in
the legacy tuple format, when it's all available via the exception
instance we already have.
This commit is contained in:
Adam Johnson 2022-01-12 12:04:14 +00:00 committed by Mariusz Felisiak
parent d05ab13c56
commit 90cf963264
3 changed files with 11 additions and 8 deletions

View File

@ -64,7 +64,7 @@ def response_for_exception(request, exc):
'Forbidden (Permission denied): %s', request.path, 'Forbidden (Permission denied): %s', request.path,
response=response, response=response,
request=request, request=request,
exc_info=sys.exc_info(), exception=exc,
) )
elif isinstance(exc, MultiPartParserError): elif isinstance(exc, MultiPartParserError):
@ -73,7 +73,7 @@ def response_for_exception(request, exc):
'Bad request (Unable to parse request body): %s', request.path, 'Bad request (Unable to parse request body): %s', request.path,
response=response, response=response,
request=request, request=request,
exc_info=sys.exc_info(), exception=exc,
) )
elif isinstance(exc, BadRequest): elif isinstance(exc, BadRequest):
@ -85,7 +85,7 @@ def response_for_exception(request, exc):
'%s: %s', str(exc), request.path, '%s: %s', str(exc), request.path,
response=response, response=response,
request=request, request=request,
exc_info=sys.exc_info(), exception=exc,
) )
elif isinstance(exc, SuspiciousOperation): elif isinstance(exc, SuspiciousOperation):
if isinstance(exc, (RequestDataTooBig, TooManyFieldsSent)): if isinstance(exc, (RequestDataTooBig, TooManyFieldsSent)):
@ -113,7 +113,7 @@ def response_for_exception(request, exc):
'%s: %s', response.reason_phrase, request.path, '%s: %s', response.reason_phrase, request.path,
response=response, response=response,
request=request, request=request,
exc_info=sys.exc_info(), exception=exc,
) )
# Force a TemplateResponse to be rendered. # Force a TemplateResponse to be rendered.

View File

@ -199,7 +199,7 @@ class ServerFormatter(logging.Formatter):
return self._fmt.find('{server_time}') >= 0 return self._fmt.find('{server_time}') >= 0
def log_response(message, *args, response=None, request=None, logger=request_logger, level=None, exc_info=None): def log_response(message, *args, response=None, request=None, logger=request_logger, level=None, exception=None):
""" """
Log errors based on HttpResponse status. Log errors based on HttpResponse status.
@ -209,8 +209,8 @@ def log_response(message, *args, response=None, request=None, logger=request_log
""" """
# Check if the response has already been logged. Multiple requests to log # Check if the response has already been logged. Multiple requests to log
# the same response can be received in some cases, e.g., when the # the same response can be received in some cases, e.g., when the
# response is the result of an exception and is logged at the time the # response is the result of an exception and is logged when the exception
# exception is caught so that the exc_info can be recorded. # is caught, to record the exception.
if getattr(response, '_has_been_logged', False): if getattr(response, '_has_been_logged', False):
return return
@ -228,6 +228,6 @@ def log_response(message, *args, response=None, request=None, logger=request_log
'status_code': response.status_code, 'status_code': response.status_code,
'request': request, 'request': request,
}, },
exc_info=exc_info, exc_info=exception,
) )
response._has_been_logged = True response._has_been_logged = True

View File

@ -400,6 +400,9 @@ Miscellaneous
:meth:`~.SimpleTestCase.assertFormsetError` is deprecated. Use ``errors=[]`` :meth:`~.SimpleTestCase.assertFormsetError` is deprecated. Use ``errors=[]``
instead. instead.
* The ``exc_info`` argument of the undocumented
``django.utils.log.log_response()`` function is replaced by ``exception``.
Features removed in 4.1 Features removed in 4.1
======================= =======================