Sent got_request_exception signal before handle_uncaught_exception

In some cases (notably Python 3), when handle_uncaught_exception was
itself raising an exception, the got_request_exception was storing
the latter exception instead of the original exception.
This commit is contained in:
Claude Paroz 2012-08-15 10:37:06 +02:00
parent 31ae103a15
commit 64531df5df
1 changed files with 5 additions and 9 deletions

View File

@ -152,10 +152,8 @@ class BaseHandler(object):
callback, param_dict = resolver.resolve404() callback, param_dict = resolver.resolve404()
response = callback(request, **param_dict) response = callback(request, **param_dict)
except: except:
try:
response = self.handle_uncaught_exception(request, resolver, sys.exc_info())
finally:
signals.got_request_exception.send(sender=self.__class__, request=request) signals.got_request_exception.send(sender=self.__class__, request=request)
response = self.handle_uncaught_exception(request, resolver, sys.exc_info())
except exceptions.PermissionDenied: except exceptions.PermissionDenied:
logger.warning( logger.warning(
'Forbidden (Permission denied): %s', request.path, 'Forbidden (Permission denied): %s', request.path,
@ -167,12 +165,10 @@ class BaseHandler(object):
callback, param_dict = resolver.resolve403() callback, param_dict = resolver.resolve403()
response = callback(request, **param_dict) response = callback(request, **param_dict)
except: except:
try:
response = self.handle_uncaught_exception(request,
resolver, sys.exc_info())
finally:
signals.got_request_exception.send( signals.got_request_exception.send(
sender=self.__class__, request=request) sender=self.__class__, request=request)
response = self.handle_uncaught_exception(request,
resolver, sys.exc_info())
except SystemExit: except SystemExit:
# Allow sys.exit() to actually exit. See tickets #1023 and #4701 # Allow sys.exit() to actually exit. See tickets #1023 and #4701
raise raise