Fixed #24847 -- Prevented items set on a RequestContext from being lost.
Backport of 300e8baf94
from master
This commit is contained in:
parent
d411586866
commit
7ee6043dba
|
@ -219,7 +219,13 @@ class RequestContext(Context):
|
||||||
self.request = request
|
self.request = request
|
||||||
self._processors = () if processors is None else tuple(processors)
|
self._processors = () if processors is None else tuple(processors)
|
||||||
self._processors_index = len(self.dicts)
|
self._processors_index = len(self.dicts)
|
||||||
self.update({}) # placeholder for context processors output
|
|
||||||
|
# placeholder for context processors output
|
||||||
|
self.update({})
|
||||||
|
|
||||||
|
# empty dict for any new modifications
|
||||||
|
# (so that context processors don't overwrite them)
|
||||||
|
self.update({})
|
||||||
|
|
||||||
@contextmanager
|
@contextmanager
|
||||||
def bind_template(self, template):
|
def bind_template(self, template):
|
||||||
|
|
|
@ -22,3 +22,6 @@ Bugfixes
|
||||||
|
|
||||||
* Reverted an optimization to the CSRF template context processor which caused
|
* Reverted an optimization to the CSRF template context processor which caused
|
||||||
a regression (:ticket:`24836`).
|
a regression (:ticket:`24836`).
|
||||||
|
|
||||||
|
* Fixed a regression which caused template context processors to overwrite
|
||||||
|
variables set on a ``RequestContext`` after it's created (:ticket:`24847`).
|
||||||
|
|
|
@ -134,8 +134,8 @@ class RequestContextTests(SimpleTestCase):
|
||||||
request = RequestFactory().get('/')
|
request = RequestFactory().get('/')
|
||||||
ctx = RequestContext(request, {})
|
ctx = RequestContext(request, {})
|
||||||
# The stack should now contain 3 items:
|
# The stack should now contain 3 items:
|
||||||
# [builtins, supplied context, context processor]
|
# [builtins, supplied context, context processor, empty dict]
|
||||||
self.assertEqual(len(ctx.dicts), 3)
|
self.assertEqual(len(ctx.dicts), 4)
|
||||||
|
|
||||||
def test_context_comparable(self):
|
def test_context_comparable(self):
|
||||||
# Create an engine without any context processors.
|
# Create an engine without any context processors.
|
||||||
|
@ -149,3 +149,10 @@ class RequestContextTests(SimpleTestCase):
|
||||||
RequestContext(request, dict_=test_data),
|
RequestContext(request, dict_=test_data),
|
||||||
RequestContext(request, dict_=test_data),
|
RequestContext(request, dict_=test_data),
|
||||||
)
|
)
|
||||||
|
|
||||||
|
def test_modify_context_and_render(self):
|
||||||
|
template = Template('{{ foo }}')
|
||||||
|
request = RequestFactory().get('/')
|
||||||
|
context = RequestContext(request, {})
|
||||||
|
context['foo'] = 'foo'
|
||||||
|
self.assertEqual(template.render(context), 'foo')
|
||||||
|
|
Loading…
Reference in New Issue