mirror of
				https://github.com/django/django.git
				synced 2025-10-24 22:26:08 +00:00 
			
		
		
		
	When using assertRedirect(), allow the caller to specify relative URLs and
automatically fill in the hostname and scheme (host can be passed in, if different from the default). git-svn-id: http://code.djangoproject.com/svn/django/trunk@6661 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
		| @@ -1,6 +1,6 @@ | |||||||
| import re | import re | ||||||
| import unittest | import unittest | ||||||
| from urlparse import urlsplit | from urlparse import urlsplit, urlunsplit | ||||||
|  |  | ||||||
| from django.http import QueryDict | from django.http import QueryDict | ||||||
| from django.db import transaction | from django.db import transaction | ||||||
| @@ -74,7 +74,7 @@ class TestCase(unittest.TestCase): | |||||||
|         super(TestCase, self).__call__(result) |         super(TestCase, self).__call__(result) | ||||||
|  |  | ||||||
|     def assertRedirects(self, response, expected_url, status_code=302, |     def assertRedirects(self, response, expected_url, status_code=302, | ||||||
|                         target_status_code=200): |                         target_status_code=200, host=None): | ||||||
|         """Asserts that a response redirected to a specific URL, and that the |         """Asserts that a response redirected to a specific URL, and that the | ||||||
|         redirect URL can be loaded. |         redirect URL can be loaded. | ||||||
|  |  | ||||||
| @@ -86,6 +86,10 @@ class TestCase(unittest.TestCase): | |||||||
|              " (expected %d)" % (response.status_code, status_code))) |              " (expected %d)" % (response.status_code, status_code))) | ||||||
|         url = response['Location'] |         url = response['Location'] | ||||||
|         scheme, netloc, path, query, fragment = urlsplit(url) |         scheme, netloc, path, query, fragment = urlsplit(url) | ||||||
|  |         e_scheme, e_netloc, e_path, e_query, e_fragment = urlsplit(expected_url) | ||||||
|  |         if not (e_scheme or e_netloc): | ||||||
|  |             expected_url = urlunsplit(('http', host or 'testserver', e_path, | ||||||
|  |                     e_query, e_fragment)) | ||||||
|         self.assertEqual(url, expected_url, |         self.assertEqual(url, expected_url, | ||||||
|             "Response redirected to '%s', expected '%s'" % (url, expected_url)) |             "Response redirected to '%s', expected '%s'" % (url, expected_url)) | ||||||
|  |  | ||||||
|   | |||||||
| @@ -83,13 +83,16 @@ class ClientTest(TestCase): | |||||||
|     def test_redirect(self): |     def test_redirect(self): | ||||||
|         "GET a URL that redirects elsewhere" |         "GET a URL that redirects elsewhere" | ||||||
|         response = self.client.get('/test_client/redirect_view/') |         response = self.client.get('/test_client/redirect_view/') | ||||||
|         # Check that the response was a 302 (redirect) |         # Check that the response was a 302 (redirect) and that | ||||||
|         self.assertRedirects(response, 'http://testserver/test_client/get_view/') |         # assertRedirect() understands to put an implicit http://testserver/ in | ||||||
|  |         # front of non-absolute URLs. | ||||||
|  |         self.assertRedirects(response, '/test_client/get_view/') | ||||||
|  |  | ||||||
|         client_providing_host = Client(HTTP_HOST='django.testserver') |         host = 'django.testserver' | ||||||
|  |         client_providing_host = Client(HTTP_HOST=host) | ||||||
|         response = client_providing_host.get('/test_client/redirect_view/') |         response = client_providing_host.get('/test_client/redirect_view/') | ||||||
|         # Check that the response was a 302 (redirect) with absolute URI |         # Check that the response was a 302 (redirect) with absolute URI | ||||||
|         self.assertRedirects(response, 'http://django.testserver/test_client/get_view/') |         self.assertRedirects(response, '/test_client/get_view/', host=host) | ||||||
|  |  | ||||||
|     def test_redirect_with_query(self): |     def test_redirect_with_query(self): | ||||||
|         "GET a URL that redirects with given GET parameters" |         "GET a URL that redirects with given GET parameters" | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user