Fixed #20130 -- Regression in {% cache %} template tag.

This commit is contained in:
Baptiste Mispelon 2013-03-25 09:10:32 +01:00 committed by Florian Apolloner
parent 465b01f065
commit 5080311998
2 changed files with 6 additions and 1 deletions

View File

@ -59,5 +59,5 @@ def do_cache(parser, token):
raise TemplateSyntaxError("'%r' tag requires at least 2 arguments." % tokens[0]) raise TemplateSyntaxError("'%r' tag requires at least 2 arguments." % tokens[0])
return CacheNode(nodelist, return CacheNode(nodelist,
parser.compile_filter(tokens[1]), parser.compile_filter(tokens[1]),
parser.compile_filter(tokens[2]), tokens[2], # fragment_name can't be a variable.
[parser.compile_filter(token) for token in tokens[3:]]) [parser.compile_filter(token) for token in tokens[3:]])

View File

@ -441,6 +441,11 @@ class Templates(TestCase):
output1 = template.render(Context({'foo': range(3), 'get_value': lambda: next(gen1)})) output1 = template.render(Context({'foo': range(3), 'get_value': lambda: next(gen1)}))
self.assertEqual(output1, '[0,1,2,3]', 'Expected [0,1,2,3] in first template, got {0}'.format(output1)) self.assertEqual(output1, '[0,1,2,3]', 'Expected [0,1,2,3] in first template, got {0}'.format(output1))
def test_cache_regression_20130(self):
t = Template('{% load cache %}{% cache 1 regression_20130 %}foo{% endcache %}')
cachenode = t.nodelist[1]
self.assertEqual(cachenode.fragment_name, 'regression_20130')
def test_ifchanged_render_once(self): def test_ifchanged_render_once(self):
""" Test for ticket #19890. The content of ifchanged template tag was """ Test for ticket #19890. The content of ifchanged template tag was
rendered twice.""" rendered twice."""