mirror of
				https://github.com/django/django.git
				synced 2025-10-24 22:26:08 +00:00 
			
		
		
		
	Fixed #3162 -- Added coded to catch and rethrow exceptions that are thrown by the views visited by the test client. Thanks, Ben <afternoon@uk2.net>.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@4482 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
		| @@ -4,6 +4,7 @@ from django.contrib.sites.models import Site | ||||
| from django.template import Context, loader | ||||
| from django.core import validators | ||||
| from django import oldforms | ||||
| from django.utils.translation import gettext as _ | ||||
|  | ||||
| class UserCreationForm(oldforms.Manipulator): | ||||
|     "A form that creates a user, with no privileges, from the given username and password." | ||||
|   | ||||
| @@ -1,7 +1,9 @@ | ||||
| import sys | ||||
| from cStringIO import StringIO | ||||
| from django.conf import settings | ||||
| from django.core.handlers.base import BaseHandler | ||||
| from django.core.handlers.wsgi import WSGIRequest | ||||
| from django.core.signals import got_request_exception | ||||
| from django.dispatch import dispatcher | ||||
| from django.http import urlencode, SimpleCookie | ||||
| from django.test import signals | ||||
| @@ -100,6 +102,14 @@ class Client: | ||||
|         self.defaults = defaults | ||||
|         self.cookies = SimpleCookie() | ||||
|         self.session = {} | ||||
|         self.exc_info = None | ||||
|          | ||||
|     def store_exc_info(self, *args, **kwargs): | ||||
|         """ | ||||
|         Utility method that can be used to store exceptions when they are | ||||
|         generated by a view. | ||||
|         """ | ||||
|         self.exc_info = sys.exc_info() | ||||
|  | ||||
|     def request(self, **request): | ||||
|         """ | ||||
| @@ -128,6 +138,9 @@ class Client: | ||||
|         on_template_render = curry(store_rendered_templates, data) | ||||
|         dispatcher.connect(on_template_render, signal=signals.template_rendered) | ||||
|  | ||||
|         # Capture exceptions created by the handler | ||||
|         dispatcher.connect(self.store_exc_info, signal=got_request_exception) | ||||
|  | ||||
|         response = self.handler(environ) | ||||
|  | ||||
|         # Add any rendered template detail to the response | ||||
| @@ -142,6 +155,11 @@ class Client: | ||||
|             else: | ||||
|                 setattr(response, detail, None) | ||||
|  | ||||
|         # Look for a signalled exception and reraise it | ||||
|         if self.exc_info: | ||||
|             raise self.exc_info[1], None, self.exc_info[2] | ||||
|          | ||||
|         # Update persistent cookie and session data | ||||
|         if response.cookies: | ||||
|             self.cookies.update(response.cookies) | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user