mirror of
				https://github.com/django/django.git
				synced 2025-10-25 14:46:09 +00:00 
			
		
		
		
	Made context take priority over context processors.
This is the expected behavior, but given RequestContext's tortuous implementation, a straightforward use of its API results in the opposite. This commits fixes a regression that must have happened at different points in the multiple templates engine refactor for different features.
This commit is contained in:
		| @@ -45,5 +45,11 @@ class Template(object): | |||||||
|             if request is None: |             if request is None: | ||||||
|                 context = Context(context) |                 context = Context(context) | ||||||
|             else: |             else: | ||||||
|                 context = RequestContext(request, context) |                 # The following pattern is required to ensure values from | ||||||
|  |                 # context override those from template context processors. | ||||||
|  |                 original_context = context | ||||||
|  |                 context = RequestContext(request) | ||||||
|  |                 if original_context: | ||||||
|  |                     context.push(original_context) | ||||||
|  |  | ||||||
|         return self.template.render(context) |         return self.template.render(context) | ||||||
|   | |||||||
| @@ -1,4 +1,7 @@ | |||||||
| from django.template.backends.django import DjangoTemplates | from django.template.backends.django import DjangoTemplates | ||||||
|  | from django.test import RequestFactory | ||||||
|  |  | ||||||
|  | from template_tests.test_response import test_processor_name | ||||||
|  |  | ||||||
| from .test_dummy import TemplateStringsTests | from .test_dummy import TemplateStringsTests | ||||||
|  |  | ||||||
| @@ -7,3 +10,25 @@ class DjangoTemplatesTests(TemplateStringsTests): | |||||||
|  |  | ||||||
|     engine_class = DjangoTemplates |     engine_class = DjangoTemplates | ||||||
|     backend_name = 'django' |     backend_name = 'django' | ||||||
|  |  | ||||||
|  |     def test_context_has_priority_over_template_context_processors(self): | ||||||
|  |         # See ticket #23789. | ||||||
|  |         engine = DjangoTemplates({ | ||||||
|  |             'DIRS': [], | ||||||
|  |             'APP_DIRS': False, | ||||||
|  |             'NAME': 'django', | ||||||
|  |             'OPTIONS': { | ||||||
|  |                 'context_processors': [test_processor_name], | ||||||
|  |             }, | ||||||
|  |         }) | ||||||
|  |  | ||||||
|  |         template = engine.from_string('{{ processors }}') | ||||||
|  |         request = RequestFactory().get('/') | ||||||
|  |  | ||||||
|  |         # Check that context processors run | ||||||
|  |         content = template.render({}, request) | ||||||
|  |         self.assertEqual(content, 'yes') | ||||||
|  |  | ||||||
|  |         # Check that context overrides context processors | ||||||
|  |         content = template.render({'processors': 'no'}, request) | ||||||
|  |         self.assertEqual(content, 'no') | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user