mirror of
				https://github.com/django/django.git
				synced 2025-10-25 06:36:07 +00:00 
			
		
		
		
	Fixed #21476 -- Cache tests make an incorrect use of HttpRequest
				
					
				
			Using `django.test.client.RequestFactory` solves the problem and cleans up all the `get_request` mess.
This commit is contained in:
		
				
					committed by
					
						 Baptiste Mispelon
						Baptiste Mispelon
					
				
			
			
				
	
			
			
			
						parent
						
							27f04e79b1
						
					
				
				
					commit
					2b4bed6dbd
				
			
							
								
								
									
										147
									
								
								tests/cache/tests.py
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										147
									
								
								tests/cache/tests.py
									
									
									
									
										vendored
									
									
								
							| @@ -185,16 +185,8 @@ class DummyCacheTests(unittest.TestCase): | |||||||
| class BaseCacheTests(object): | class BaseCacheTests(object): | ||||||
|     # A common set of tests to apply to all cache backends |     # A common set of tests to apply to all cache backends | ||||||
|  |  | ||||||
|     def _get_request_cache(self, path): |     def setUp(self): | ||||||
|         request = HttpRequest() |         self.factory = RequestFactory() | ||||||
|         request.META = { |  | ||||||
|             'SERVER_NAME': 'testserver', |  | ||||||
|             'SERVER_PORT': 80, |  | ||||||
|         } |  | ||||||
|         request.path = request.path_info = path |  | ||||||
|         request._cache_update_cache = True |  | ||||||
|         request.method = 'GET' |  | ||||||
|         return request |  | ||||||
|  |  | ||||||
|     def test_simple(self): |     def test_simple(self): | ||||||
|         # Simple cache set/get works |         # Simple cache set/get works | ||||||
| @@ -802,7 +794,8 @@ class BaseCacheTests(object): | |||||||
|         fetch_middleware = FetchFromCacheMiddleware() |         fetch_middleware = FetchFromCacheMiddleware() | ||||||
|         fetch_middleware.cache = self.cache |         fetch_middleware.cache = self.cache | ||||||
|  |  | ||||||
|         request = self._get_request_cache('/cache/test') |         request = self.factory.get('/cache/test') | ||||||
|  |         request._cache_update_cache = True | ||||||
|         get_cache_data = FetchFromCacheMiddleware().process_request(request) |         get_cache_data = FetchFromCacheMiddleware().process_request(request) | ||||||
|         self.assertEqual(get_cache_data, None) |         self.assertEqual(get_cache_data, None) | ||||||
|  |  | ||||||
| @@ -844,6 +837,7 @@ class DBCacheTests(BaseCacheTests, TransactionTestCase): | |||||||
|     backend_name = 'django.core.cache.backends.db.DatabaseCache' |     backend_name = 'django.core.cache.backends.db.DatabaseCache' | ||||||
|  |  | ||||||
|     def setUp(self): |     def setUp(self): | ||||||
|  |         self.factory = RequestFactory() | ||||||
|         # Spaces are used in the table name to ensure quoting/escaping is working |         # Spaces are used in the table name to ensure quoting/escaping is working | ||||||
|         self._table_name = 'test cache table' |         self._table_name = 'test cache table' | ||||||
|         management.call_command('createcachetable', verbosity=0, interactive=False) |         management.call_command('createcachetable', verbosity=0, interactive=False) | ||||||
| @@ -956,6 +950,7 @@ class LocMemCacheTests(unittest.TestCase, BaseCacheTests): | |||||||
|     backend_name = 'django.core.cache.backends.locmem.LocMemCache' |     backend_name = 'django.core.cache.backends.locmem.LocMemCache' | ||||||
|  |  | ||||||
|     def setUp(self): |     def setUp(self): | ||||||
|  |         self.factory = RequestFactory() | ||||||
|         self.cache = get_cache(self.backend_name, OPTIONS={'MAX_ENTRIES': 30}) |         self.cache = get_cache(self.backend_name, OPTIONS={'MAX_ENTRIES': 30}) | ||||||
|         self.prefix_cache = get_cache(self.backend_name, KEY_PREFIX='cacheprefix') |         self.prefix_cache = get_cache(self.backend_name, KEY_PREFIX='cacheprefix') | ||||||
|         self.v2_cache = get_cache(self.backend_name, VERSION=2) |         self.v2_cache = get_cache(self.backend_name, VERSION=2) | ||||||
| @@ -1018,6 +1013,7 @@ class LocMemCacheTests(unittest.TestCase, BaseCacheTests): | |||||||
| class MemcachedCacheTests(unittest.TestCase, BaseCacheTests): | class MemcachedCacheTests(unittest.TestCase, BaseCacheTests): | ||||||
|  |  | ||||||
|     def setUp(self): |     def setUp(self): | ||||||
|  |         self.factory = RequestFactory() | ||||||
|         for cache_key, cache in settings.CACHES.items(): |         for cache_key, cache in settings.CACHES.items(): | ||||||
|             if cache['BACKEND'].startswith('django.core.cache.backends.memcached.'): |             if cache['BACKEND'].startswith('django.core.cache.backends.memcached.'): | ||||||
|                 break |                 break | ||||||
| @@ -1066,6 +1062,7 @@ class FileBasedCacheTests(unittest.TestCase, BaseCacheTests): | |||||||
|     backend_name = 'django.core.cache.backends.filebased.FileBasedCache' |     backend_name = 'django.core.cache.backends.filebased.FileBasedCache' | ||||||
|  |  | ||||||
|     def setUp(self): |     def setUp(self): | ||||||
|  |         self.factory = RequestFactory() | ||||||
|         self.dirname = tempfile.mkdtemp() |         self.dirname = tempfile.mkdtemp() | ||||||
|         self.cache = get_cache(self.backend_name, LOCATION=self.dirname, OPTIONS={'MAX_ENTRIES': 30}) |         self.cache = get_cache(self.backend_name, LOCATION=self.dirname, OPTIONS={'MAX_ENTRIES': 30}) | ||||||
|         self.prefix_cache = get_cache(self.backend_name, LOCATION=self.dirname, KEY_PREFIX='cacheprefix') |         self.prefix_cache = get_cache(self.backend_name, LOCATION=self.dirname, KEY_PREFIX='cacheprefix') | ||||||
| @@ -1158,20 +1155,11 @@ class CacheUtils(TestCase): | |||||||
|     def setUp(self): |     def setUp(self): | ||||||
|         self.path = '/cache/test/' |         self.path = '/cache/test/' | ||||||
|         self.cache = get_cache('default') |         self.cache = get_cache('default') | ||||||
|  |         self.factory = RequestFactory() | ||||||
|  |  | ||||||
|     def tearDown(self): |     def tearDown(self): | ||||||
|         self.cache.clear() |         self.cache.clear() | ||||||
|  |  | ||||||
|     def _get_request(self, path, method='GET'): |  | ||||||
|         request = HttpRequest() |  | ||||||
|         request.META = { |  | ||||||
|             'SERVER_NAME': 'testserver', |  | ||||||
|             'SERVER_PORT': 80, |  | ||||||
|         } |  | ||||||
|         request.method = method |  | ||||||
|         request.path = request.path_info = "/cache/%s" % path |  | ||||||
|         return request |  | ||||||
|  |  | ||||||
|     def test_patch_vary_headers(self): |     def test_patch_vary_headers(self): | ||||||
|         headers = ( |         headers = ( | ||||||
|             # Initial vary, new headers, resulting vary. |             # Initial vary, new headers, resulting vary. | ||||||
| @@ -1193,35 +1181,35 @@ class CacheUtils(TestCase): | |||||||
|             self.assertEqual(response['Vary'], resulting_vary) |             self.assertEqual(response['Vary'], resulting_vary) | ||||||
|  |  | ||||||
|     def test_get_cache_key(self): |     def test_get_cache_key(self): | ||||||
|         request = self._get_request(self.path) |         request = self.factory.get(self.path) | ||||||
|         response = HttpResponse() |         response = HttpResponse() | ||||||
|         key_prefix = 'localprefix' |         key_prefix = 'localprefix' | ||||||
|         # Expect None if no headers have been set yet. |         # Expect None if no headers have been set yet. | ||||||
|         self.assertEqual(get_cache_key(request), None) |         self.assertEqual(get_cache_key(request), None) | ||||||
|         # Set headers to an empty list. |         # Set headers to an empty list. | ||||||
|         learn_cache_key(request, response) |         learn_cache_key(request, response) | ||||||
|         self.assertEqual(get_cache_key(request), 'views.decorators.cache.cache_page.settingsprefix.GET.a8c87a3d8c44853d7f79474f7ffe4ad5.d41d8cd98f00b204e9800998ecf8427e') |         self.assertEqual(get_cache_key(request), 'views.decorators.cache.cache_page.settingsprefix.GET.9fa0fd092afb73bdce204bb4f94d5804.d41d8cd98f00b204e9800998ecf8427e') | ||||||
|         # Verify that a specified key_prefix is taken into account. |         # Verify that a specified key_prefix is taken into account. | ||||||
|         learn_cache_key(request, response, key_prefix=key_prefix) |         learn_cache_key(request, response, key_prefix=key_prefix) | ||||||
|         self.assertEqual(get_cache_key(request, key_prefix=key_prefix), 'views.decorators.cache.cache_page.localprefix.GET.a8c87a3d8c44853d7f79474f7ffe4ad5.d41d8cd98f00b204e9800998ecf8427e') |         self.assertEqual(get_cache_key(request, key_prefix=key_prefix), 'views.decorators.cache.cache_page.localprefix.GET.9fa0fd092afb73bdce204bb4f94d5804.d41d8cd98f00b204e9800998ecf8427e') | ||||||
|  |  | ||||||
|     def test_get_cache_key_with_query(self): |     def test_get_cache_key_with_query(self): | ||||||
|         request = self._get_request(self.path + '?test=1') |         request = self.factory.get(self.path, {'test': 1}) | ||||||
|         response = HttpResponse() |         response = HttpResponse() | ||||||
|         # Expect None if no headers have been set yet. |         # Expect None if no headers have been set yet. | ||||||
|         self.assertEqual(get_cache_key(request), None) |         self.assertEqual(get_cache_key(request), None) | ||||||
|         # Set headers to an empty list. |         # Set headers to an empty list. | ||||||
|         learn_cache_key(request, response) |         learn_cache_key(request, response) | ||||||
|         # Verify that the querystring is taken into account. |         # Verify that the querystring is taken into account. | ||||||
|         self.assertEqual(get_cache_key(request), 'views.decorators.cache.cache_page.settingsprefix.GET.bd889c5a59603af44333ed21504db3cd.d41d8cd98f00b204e9800998ecf8427e') |         self.assertEqual(get_cache_key(request), 'views.decorators.cache.cache_page.settingsprefix.GET.d11198ba31883732b0de5786a80cc12b.d41d8cd98f00b204e9800998ecf8427e') | ||||||
|  |  | ||||||
|     def test_learn_cache_key(self): |     def test_learn_cache_key(self): | ||||||
|         request = self._get_request(self.path, 'HEAD') |         request = self.factory.head(self.path) | ||||||
|         response = HttpResponse() |         response = HttpResponse() | ||||||
|         response['Vary'] = 'Pony' |         response['Vary'] = 'Pony' | ||||||
|         # Make sure that the Vary header is added to the key hash |         # Make sure that the Vary header is added to the key hash | ||||||
|         learn_cache_key(request, response) |         learn_cache_key(request, response) | ||||||
|         self.assertEqual(get_cache_key(request), 'views.decorators.cache.cache_page.settingsprefix.GET.a8c87a3d8c44853d7f79474f7ffe4ad5.d41d8cd98f00b204e9800998ecf8427e') |         self.assertEqual(get_cache_key(request), 'views.decorators.cache.cache_page.settingsprefix.GET.9fa0fd092afb73bdce204bb4f94d5804.d41d8cd98f00b204e9800998ecf8427e') | ||||||
|  |  | ||||||
|     def test_patch_cache_control(self): |     def test_patch_cache_control(self): | ||||||
|         tests = ( |         tests = ( | ||||||
| @@ -1275,25 +1263,11 @@ class CacheHEADTest(TestCase): | |||||||
|     def setUp(self): |     def setUp(self): | ||||||
|         self.path = '/cache/test/' |         self.path = '/cache/test/' | ||||||
|         self.cache = get_cache('default') |         self.cache = get_cache('default') | ||||||
|  |         self.factory = RequestFactory() | ||||||
|  |  | ||||||
|     def tearDown(self): |     def tearDown(self): | ||||||
|         self.cache.clear() |         self.cache.clear() | ||||||
|  |  | ||||||
|     def _get_request(self, method): |  | ||||||
|         request = HttpRequest() |  | ||||||
|         request.META = { |  | ||||||
|             'SERVER_NAME': 'testserver', |  | ||||||
|             'SERVER_PORT': 80, |  | ||||||
|         } |  | ||||||
|         request.method = method |  | ||||||
|         request.path = request.path_info = self.path |  | ||||||
|         return request |  | ||||||
|  |  | ||||||
|     def _get_request_cache(self, method): |  | ||||||
|         request = self._get_request(method) |  | ||||||
|         request._cache_update_cache = True |  | ||||||
|         return request |  | ||||||
|  |  | ||||||
|     def _set_cache(self, request, msg): |     def _set_cache(self, request, msg): | ||||||
|         response = HttpResponse() |         response = HttpResponse() | ||||||
|         response.content = msg |         response.content = msg | ||||||
| @@ -1302,10 +1276,12 @@ class CacheHEADTest(TestCase): | |||||||
|     def test_head_caches_correctly(self): |     def test_head_caches_correctly(self): | ||||||
|         test_content = 'test content' |         test_content = 'test content' | ||||||
|  |  | ||||||
|         request = self._get_request_cache('HEAD') |         request = self.factory.head(self.path) | ||||||
|  |         request._cache_update_cache = True | ||||||
|         self._set_cache(request, test_content) |         self._set_cache(request, test_content) | ||||||
|  |  | ||||||
|         request = self._get_request('HEAD') |         request = self.factory.head(self.path) | ||||||
|  |         request._cache_update_cache = True | ||||||
|         get_cache_data = FetchFromCacheMiddleware().process_request(request) |         get_cache_data = FetchFromCacheMiddleware().process_request(request) | ||||||
|         self.assertNotEqual(get_cache_data, None) |         self.assertNotEqual(get_cache_data, None) | ||||||
|         self.assertEqual(test_content.encode(), get_cache_data.content) |         self.assertEqual(test_content.encode(), get_cache_data.content) | ||||||
| @@ -1313,10 +1289,11 @@ class CacheHEADTest(TestCase): | |||||||
|     def test_head_with_cached_get(self): |     def test_head_with_cached_get(self): | ||||||
|         test_content = 'test content' |         test_content = 'test content' | ||||||
|  |  | ||||||
|         request = self._get_request_cache('GET') |         request = self.factory.get(self.path) | ||||||
|  |         request._cache_update_cache = True | ||||||
|         self._set_cache(request, test_content) |         self._set_cache(request, test_content) | ||||||
|  |  | ||||||
|         request = self._get_request('HEAD') |         request = self.factory.head(self.path) | ||||||
|         get_cache_data = FetchFromCacheMiddleware().process_request(request) |         get_cache_data = FetchFromCacheMiddleware().process_request(request) | ||||||
|         self.assertNotEqual(get_cache_data, None) |         self.assertNotEqual(get_cache_data, None) | ||||||
|         self.assertEqual(test_content.encode(), get_cache_data.content) |         self.assertEqual(test_content.encode(), get_cache_data.content) | ||||||
| @@ -1339,38 +1316,14 @@ class CacheI18nTest(TestCase): | |||||||
|     def setUp(self): |     def setUp(self): | ||||||
|         self.path = '/cache/test/' |         self.path = '/cache/test/' | ||||||
|         self.cache = get_cache('default') |         self.cache = get_cache('default') | ||||||
|  |         self.factory = RequestFactory() | ||||||
|  |  | ||||||
|     def tearDown(self): |     def tearDown(self): | ||||||
|         self.cache.clear() |         self.cache.clear() | ||||||
|  |  | ||||||
|     def _get_request(self, method='GET'): |  | ||||||
|         request = HttpRequest() |  | ||||||
|         request.META = { |  | ||||||
|             'SERVER_NAME': 'testserver', |  | ||||||
|             'SERVER_PORT': 80, |  | ||||||
|         } |  | ||||||
|         request.method = method |  | ||||||
|         request.path = request.path_info = self.path |  | ||||||
|         return request |  | ||||||
|  |  | ||||||
|     def _get_request_cache(self, query_string=None): |  | ||||||
|         request = HttpRequest() |  | ||||||
|         request.META = { |  | ||||||
|             'SERVER_NAME': 'testserver', |  | ||||||
|             'SERVER_PORT': 80, |  | ||||||
|         } |  | ||||||
|         if query_string: |  | ||||||
|             request.META['QUERY_STRING'] = query_string |  | ||||||
|             request.GET = QueryDict(query_string) |  | ||||||
|         request.path = request.path_info = self.path |  | ||||||
|         request._cache_update_cache = True |  | ||||||
|         request.method = 'GET' |  | ||||||
|         request.session = {} |  | ||||||
|         return request |  | ||||||
|  |  | ||||||
|     @override_settings(USE_I18N=True, USE_L10N=False, USE_TZ=False) |     @override_settings(USE_I18N=True, USE_L10N=False, USE_TZ=False) | ||||||
|     def test_cache_key_i18n_translation(self): |     def test_cache_key_i18n_translation(self): | ||||||
|         request = self._get_request() |         request = self.factory.get(self.path) | ||||||
|         lang = translation.get_language() |         lang = translation.get_language() | ||||||
|         response = HttpResponse() |         response = HttpResponse() | ||||||
|         key = learn_cache_key(request, response) |         key = learn_cache_key(request, response) | ||||||
| @@ -1379,7 +1332,7 @@ class CacheI18nTest(TestCase): | |||||||
|         self.assertEqual(key, key2) |         self.assertEqual(key, key2) | ||||||
|  |  | ||||||
|     def check_accept_language_vary(self, accept_language, vary, reference_key): |     def check_accept_language_vary(self, accept_language, vary, reference_key): | ||||||
|         request = self._get_request() |         request = self.factory.get(self.path) | ||||||
|         request.META['HTTP_ACCEPT_LANGUAGE'] = accept_language |         request.META['HTTP_ACCEPT_LANGUAGE'] = accept_language | ||||||
|         request.META['HTTP_ACCEPT_ENCODING'] = 'gzip;q=1.0, identity; q=0.5, *;q=0' |         request.META['HTTP_ACCEPT_ENCODING'] = 'gzip;q=1.0, identity; q=0.5, *;q=0' | ||||||
|         response = HttpResponse() |         response = HttpResponse() | ||||||
| @@ -1393,7 +1346,7 @@ class CacheI18nTest(TestCase): | |||||||
|     def test_cache_key_i18n_translation_accept_language(self): |     def test_cache_key_i18n_translation_accept_language(self): | ||||||
|         lang = translation.get_language() |         lang = translation.get_language() | ||||||
|         self.assertEqual(lang, 'en') |         self.assertEqual(lang, 'en') | ||||||
|         request = self._get_request() |         request = self.factory.get(self.path) | ||||||
|         request.META['HTTP_ACCEPT_ENCODING'] = 'gzip;q=1.0, identity; q=0.5, *;q=0' |         request.META['HTTP_ACCEPT_ENCODING'] = 'gzip;q=1.0, identity; q=0.5, *;q=0' | ||||||
|         response = HttpResponse() |         response = HttpResponse() | ||||||
|         response['Vary'] = 'accept-encoding' |         response['Vary'] = 'accept-encoding' | ||||||
| @@ -1447,7 +1400,7 @@ class CacheI18nTest(TestCase): | |||||||
|  |  | ||||||
|     @override_settings(USE_I18N=False, USE_L10N=True, USE_TZ=False) |     @override_settings(USE_I18N=False, USE_L10N=True, USE_TZ=False) | ||||||
|     def test_cache_key_i18n_formatting(self): |     def test_cache_key_i18n_formatting(self): | ||||||
|         request = self._get_request() |         request = self.factory.get(self.path) | ||||||
|         lang = translation.get_language() |         lang = translation.get_language() | ||||||
|         response = HttpResponse() |         response = HttpResponse() | ||||||
|         key = learn_cache_key(request, response) |         key = learn_cache_key(request, response) | ||||||
| @@ -1457,7 +1410,7 @@ class CacheI18nTest(TestCase): | |||||||
|  |  | ||||||
|     @override_settings(USE_I18N=False, USE_L10N=False, USE_TZ=True) |     @override_settings(USE_I18N=False, USE_L10N=False, USE_TZ=True) | ||||||
|     def test_cache_key_i18n_timezone(self): |     def test_cache_key_i18n_timezone(self): | ||||||
|         request = self._get_request() |         request = self.factory.get(self.path) | ||||||
|         # This is tightly coupled to the implementation, |         # This is tightly coupled to the implementation, | ||||||
|         # but it's the most straightforward way to test the key. |         # but it's the most straightforward way to test the key. | ||||||
|         tz = force_text(timezone.get_current_timezone_name(), errors='ignore') |         tz = force_text(timezone.get_current_timezone_name(), errors='ignore') | ||||||
| @@ -1470,7 +1423,7 @@ class CacheI18nTest(TestCase): | |||||||
|  |  | ||||||
|     @override_settings(USE_I18N=False, USE_L10N=False) |     @override_settings(USE_I18N=False, USE_L10N=False) | ||||||
|     def test_cache_key_no_i18n(self): |     def test_cache_key_no_i18n(self): | ||||||
|         request = self._get_request() |         request = self.factory.get(self.path) | ||||||
|         lang = translation.get_language() |         lang = translation.get_language() | ||||||
|         tz = force_text(timezone.get_current_timezone_name(), errors='ignore') |         tz = force_text(timezone.get_current_timezone_name(), errors='ignore') | ||||||
|         tz = tz.encode('ascii', 'ignore').decode('ascii').replace(' ', '_') |         tz = tz.encode('ascii', 'ignore').decode('ascii').replace(' ', '_') | ||||||
| @@ -1488,7 +1441,7 @@ class CacheI18nTest(TestCase): | |||||||
|             def tzname(self, dt): |             def tzname(self, dt): | ||||||
|                 return self.name |                 return self.name | ||||||
|  |  | ||||||
|         request = self._get_request() |         request = self.factory.get(self.path) | ||||||
|         response = HttpResponse() |         response = HttpResponse() | ||||||
|         with timezone.override(CustomTzName()): |         with timezone.override(CustomTzName()): | ||||||
|             CustomTzName.name = 'Hora estándar de Argentina'.encode('UTF-8')  # UTF-8 string |             CustomTzName.name = 'Hora estándar de Argentina'.encode('UTF-8')  # UTF-8 string | ||||||
| @@ -1515,7 +1468,9 @@ class CacheI18nTest(TestCase): | |||||||
|             return UpdateCacheMiddleware().process_response(request, response) |             return UpdateCacheMiddleware().process_response(request, response) | ||||||
|  |  | ||||||
|         # cache with non empty request.GET |         # cache with non empty request.GET | ||||||
|         request = self._get_request_cache(query_string='foo=bar&other=true') |         request = self.factory.get(self.path, {'foo': 'bar', 'other': 'true'}) | ||||||
|  |         request._cache_update_cache = True | ||||||
|  |  | ||||||
|         get_cache_data = FetchFromCacheMiddleware().process_request(request) |         get_cache_data = FetchFromCacheMiddleware().process_request(request) | ||||||
|         # first access, cache must return None |         # first access, cache must return None | ||||||
|         self.assertEqual(get_cache_data, None) |         self.assertEqual(get_cache_data, None) | ||||||
| @@ -1528,7 +1483,8 @@ class CacheI18nTest(TestCase): | |||||||
|         self.assertNotEqual(get_cache_data, None) |         self.assertNotEqual(get_cache_data, None) | ||||||
|         self.assertEqual(get_cache_data.content, content.encode()) |         self.assertEqual(get_cache_data.content, content.encode()) | ||||||
|         # different QUERY_STRING, cache must be empty |         # different QUERY_STRING, cache must be empty | ||||||
|         request = self._get_request_cache(query_string='foo=bar&somethingelse=true') |         request = self.factory.get(self.path, {'foo': 'bar', 'somethingelse': 'true'}) | ||||||
|  |         request._cache_update_cache = True | ||||||
|         get_cache_data = FetchFromCacheMiddleware().process_request(request) |         get_cache_data = FetchFromCacheMiddleware().process_request(request) | ||||||
|         self.assertEqual(get_cache_data, None) |         self.assertEqual(get_cache_data, None) | ||||||
|  |  | ||||||
| @@ -1536,7 +1492,8 @@ class CacheI18nTest(TestCase): | |||||||
|         en_message = "Hello world!" |         en_message = "Hello world!" | ||||||
|         es_message = "Hola mundo!" |         es_message = "Hola mundo!" | ||||||
|  |  | ||||||
|         request = self._get_request_cache() |         request = self.factory.get(self.path) | ||||||
|  |         request._cache_update_cache = True | ||||||
|         set_cache(request, 'en', en_message) |         set_cache(request, 'en', en_message) | ||||||
|         get_cache_data = FetchFromCacheMiddleware().process_request(request) |         get_cache_data = FetchFromCacheMiddleware().process_request(request) | ||||||
|         # Check that we can recover the cache |         # Check that we can recover the cache | ||||||
| @@ -1551,7 +1508,8 @@ class CacheI18nTest(TestCase): | |||||||
|             get_cache_data = FetchFromCacheMiddleware().process_request(request) |             get_cache_data = FetchFromCacheMiddleware().process_request(request) | ||||||
|             self.assertFalse(get_cache_data.has_header('ETag')) |             self.assertFalse(get_cache_data.has_header('ETag')) | ||||||
|         # change the session language and set content |         # change the session language and set content | ||||||
|         request = self._get_request_cache() |         request = self.factory.get(self.path) | ||||||
|  |         request._cache_update_cache = True | ||||||
|         set_cache(request, 'es', es_message) |         set_cache(request, 'es', es_message) | ||||||
|         # change again the language |         # change again the language | ||||||
|         translation.activate('en') |         translation.activate('en') | ||||||
| @@ -1571,7 +1529,7 @@ class CacheI18nTest(TestCase): | |||||||
|         USE_ETAGS=True, |         USE_ETAGS=True, | ||||||
|     ) |     ) | ||||||
|     def test_middleware_doesnt_cache_streaming_response(self): |     def test_middleware_doesnt_cache_streaming_response(self): | ||||||
|         request = self._get_request() |         request = self.factory.get(self.path) | ||||||
|         get_cache_data = FetchFromCacheMiddleware().process_request(request) |         get_cache_data = FetchFromCacheMiddleware().process_request(request) | ||||||
|         self.assertIsNone(get_cache_data) |         self.assertIsNone(get_cache_data) | ||||||
|  |  | ||||||
| @@ -1845,20 +1803,11 @@ class TestWithTemplateResponse(TestCase): | |||||||
|     def setUp(self): |     def setUp(self): | ||||||
|         self.path = '/cache/test/' |         self.path = '/cache/test/' | ||||||
|         self.cache = get_cache('default') |         self.cache = get_cache('default') | ||||||
|  |         self.factory = RequestFactory() | ||||||
|  |  | ||||||
|     def tearDown(self): |     def tearDown(self): | ||||||
|         self.cache.clear() |         self.cache.clear() | ||||||
|  |  | ||||||
|     def _get_request(self, path, method='GET'): |  | ||||||
|         request = HttpRequest() |  | ||||||
|         request.META = { |  | ||||||
|             'SERVER_NAME': 'testserver', |  | ||||||
|             'SERVER_PORT': 80, |  | ||||||
|         } |  | ||||||
|         request.method = method |  | ||||||
|         request.path = request.path_info = "/cache/%s" % path |  | ||||||
|         return request |  | ||||||
|  |  | ||||||
|     def test_patch_vary_headers(self): |     def test_patch_vary_headers(self): | ||||||
|         headers = ( |         headers = ( | ||||||
|             # Initial vary, new headers, resulting vary. |             # Initial vary, new headers, resulting vary. | ||||||
| @@ -1880,27 +1829,27 @@ class TestWithTemplateResponse(TestCase): | |||||||
|             self.assertEqual(response['Vary'], resulting_vary) |             self.assertEqual(response['Vary'], resulting_vary) | ||||||
|  |  | ||||||
|     def test_get_cache_key(self): |     def test_get_cache_key(self): | ||||||
|         request = self._get_request(self.path) |         request = self.factory.get(self.path) | ||||||
|         response = TemplateResponse(HttpResponse(), Template("This is a test")) |         response = TemplateResponse(HttpResponse(), Template("This is a test")) | ||||||
|         key_prefix = 'localprefix' |         key_prefix = 'localprefix' | ||||||
|         # Expect None if no headers have been set yet. |         # Expect None if no headers have been set yet. | ||||||
|         self.assertEqual(get_cache_key(request), None) |         self.assertEqual(get_cache_key(request), None) | ||||||
|         # Set headers to an empty list. |         # Set headers to an empty list. | ||||||
|         learn_cache_key(request, response) |         learn_cache_key(request, response) | ||||||
|         self.assertEqual(get_cache_key(request), 'views.decorators.cache.cache_page.settingsprefix.GET.a8c87a3d8c44853d7f79474f7ffe4ad5.d41d8cd98f00b204e9800998ecf8427e') |         self.assertEqual(get_cache_key(request), 'views.decorators.cache.cache_page.settingsprefix.GET.9fa0fd092afb73bdce204bb4f94d5804.d41d8cd98f00b204e9800998ecf8427e') | ||||||
|         # Verify that a specified key_prefix is taken into account. |         # Verify that a specified key_prefix is taken into account. | ||||||
|         learn_cache_key(request, response, key_prefix=key_prefix) |         learn_cache_key(request, response, key_prefix=key_prefix) | ||||||
|         self.assertEqual(get_cache_key(request, key_prefix=key_prefix), 'views.decorators.cache.cache_page.localprefix.GET.a8c87a3d8c44853d7f79474f7ffe4ad5.d41d8cd98f00b204e9800998ecf8427e') |         self.assertEqual(get_cache_key(request, key_prefix=key_prefix), 'views.decorators.cache.cache_page.localprefix.GET.9fa0fd092afb73bdce204bb4f94d5804.d41d8cd98f00b204e9800998ecf8427e') | ||||||
|  |  | ||||||
|     def test_get_cache_key_with_query(self): |     def test_get_cache_key_with_query(self): | ||||||
|         request = self._get_request(self.path + '?test=1') |         request = self.factory.get(self.path, {'test': 1}) | ||||||
|         response = TemplateResponse(HttpResponse(), Template("This is a test")) |         response = TemplateResponse(HttpResponse(), Template("This is a test")) | ||||||
|         # Expect None if no headers have been set yet. |         # Expect None if no headers have been set yet. | ||||||
|         self.assertEqual(get_cache_key(request), None) |         self.assertEqual(get_cache_key(request), None) | ||||||
|         # Set headers to an empty list. |         # Set headers to an empty list. | ||||||
|         learn_cache_key(request, response) |         learn_cache_key(request, response) | ||||||
|         # Verify that the querystring is taken into account. |         # Verify that the querystring is taken into account. | ||||||
|         self.assertEqual(get_cache_key(request), 'views.decorators.cache.cache_page.settingsprefix.GET.bd889c5a59603af44333ed21504db3cd.d41d8cd98f00b204e9800998ecf8427e') |         self.assertEqual(get_cache_key(request), 'views.decorators.cache.cache_page.settingsprefix.GET.d11198ba31883732b0de5786a80cc12b.d41d8cd98f00b204e9800998ecf8427e') | ||||||
|  |  | ||||||
|     @override_settings(USE_ETAGS=False) |     @override_settings(USE_ETAGS=False) | ||||||
|     def test_without_etag(self): |     def test_without_etag(self): | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user