Fixed #28001 -- Updated comment and tested context popping in ForNode.render().
This commit is contained in:
parent
351835f262
commit
dbfcedb499
|
@ -211,11 +211,9 @@ class ForNode(Node):
|
||||||
nodelist.append(node.render_annotated(context))
|
nodelist.append(node.render_annotated(context))
|
||||||
|
|
||||||
if pop_context:
|
if pop_context:
|
||||||
# The loop variables were pushed on to the context so pop them
|
# Pop the loop variables pushed on to the context to avoid
|
||||||
# off again. This is necessary because the tag lets the length
|
# the context ending up in an inconsistent state when other
|
||||||
# of loopvars differ to the length of each set of items and we
|
# tags (e.g., include and with) push data to context.
|
||||||
# don't want to leave any vars from the previous loop on the
|
|
||||||
# context.
|
|
||||||
context.pop()
|
context.pop()
|
||||||
return mark_safe(''.join(nodelist))
|
return mark_safe(''.join(nodelist))
|
||||||
|
|
||||||
|
|
|
@ -180,3 +180,20 @@ class ForTagTests(SimpleTestCase):
|
||||||
def test_for_tag_unpack14(self):
|
def test_for_tag_unpack14(self):
|
||||||
with self.assertRaisesMessage(ValueError, 'Need 2 values to unpack in for loop; got 1.'):
|
with self.assertRaisesMessage(ValueError, 'Need 2 values to unpack in for loop; got 1.'):
|
||||||
self.engine.render_to_string('for-tag-unpack14', {'items': (1, 2)})
|
self.engine.render_to_string('for-tag-unpack14', {'items': (1, 2)})
|
||||||
|
|
||||||
|
@setup({
|
||||||
|
'main': '{% with alpha=alpha.values %}{% include "base" %}{% endwith %}_'
|
||||||
|
'{% with alpha=alpha.extra %}{% include "base" %}{% endwith %}',
|
||||||
|
'base': '{% for x, y in alpha %}{{ x }}:{{ y }},{% endfor %}'
|
||||||
|
})
|
||||||
|
def test_for_tag_context(self):
|
||||||
|
"""
|
||||||
|
ForNode.render() pops the values it pushes to the context (#28001).
|
||||||
|
"""
|
||||||
|
output = self.engine.render_to_string('main', {
|
||||||
|
'alpha': {
|
||||||
|
'values': [('two', 2), ('four', 4)],
|
||||||
|
'extra': [('six', 6), ('eight', 8)],
|
||||||
|
},
|
||||||
|
})
|
||||||
|
self.assertEqual(output, 'two:2,four:4,_six:6,eight:8,')
|
||||||
|
|
Loading…
Reference in New Issue