Commit 0cdb09d4 authored by Aymeric Augustin's avatar Aymeric Augustin
Browse files

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.
parent ed220c4c
Loading
Loading
Loading
Loading
+7 −1
Original line number Diff line number Diff line
@@ -45,5 +45,11 @@ class Template(object):
            if request is None:
                context = Context(context)
            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)
+25 −0
Original line number Diff line number Diff line
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

@@ -7,3 +10,25 @@ class DjangoTemplatesTests(TemplateStringsTests):

    engine_class = DjangoTemplates
    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')