mirror of
https://github.com/django/django.git
synced 2025-01-18 06:12:23 +00:00
655f524915
* Converted the ``libraries`` and ``builtins`` globals of ``django.template.base`` into properties of the Engine class. * Added a public API for explicit registration of libraries and builtins.
171 lines
6.6 KiB
Python
171 lines
6.6 KiB
Python
from django.core.cache import cache
|
|
from django.template import Context, Engine, TemplateSyntaxError
|
|
from django.test import SimpleTestCase, override_settings
|
|
|
|
from ..utils import setup
|
|
|
|
|
|
class CacheTagTests(SimpleTestCase):
|
|
libraries = {
|
|
'cache': 'django.templatetags.cache',
|
|
'custom': 'template_tests.templatetags.custom',
|
|
}
|
|
|
|
def tearDown(self):
|
|
cache.clear()
|
|
|
|
@setup({'cache03': '{% load cache %}{% cache 2 test %}cache03{% endcache %}'})
|
|
def test_cache03(self):
|
|
output = self.engine.render_to_string('cache03')
|
|
self.assertEqual(output, 'cache03')
|
|
|
|
@setup({
|
|
'cache03': '{% load cache %}{% cache 2 test %}cache03{% endcache %}',
|
|
'cache04': '{% load cache %}{% cache 2 test %}cache04{% endcache %}',
|
|
})
|
|
def test_cache04(self):
|
|
self.engine.render_to_string('cache03')
|
|
output = self.engine.render_to_string('cache04')
|
|
self.assertEqual(output, 'cache03')
|
|
|
|
@setup({'cache05': '{% load cache %}{% cache 2 test foo %}cache05{% endcache %}'})
|
|
def test_cache05(self):
|
|
output = self.engine.render_to_string('cache05', {'foo': 1})
|
|
self.assertEqual(output, 'cache05')
|
|
|
|
@setup({'cache06': '{% load cache %}{% cache 2 test foo %}cache06{% endcache %}'})
|
|
def test_cache06(self):
|
|
output = self.engine.render_to_string('cache06', {'foo': 2})
|
|
self.assertEqual(output, 'cache06')
|
|
|
|
@setup({
|
|
'cache05': '{% load cache %}{% cache 2 test foo %}cache05{% endcache %}',
|
|
'cache07': '{% load cache %}{% cache 2 test foo %}cache07{% endcache %}',
|
|
})
|
|
def test_cache07(self):
|
|
context = {'foo': 1}
|
|
self.engine.render_to_string('cache05', context)
|
|
output = self.engine.render_to_string('cache07', context)
|
|
self.assertEqual(output, 'cache05')
|
|
|
|
@setup({
|
|
'cache06': '{% load cache %}{% cache 2 test foo %}cache06{% endcache %}',
|
|
'cache08': '{% load cache %}{% cache time test foo %}cache08{% endcache %}',
|
|
})
|
|
def test_cache08(self):
|
|
"""
|
|
Allow first argument to be a variable.
|
|
"""
|
|
context = {'foo': 2, 'time': 2}
|
|
self.engine.render_to_string('cache06', context)
|
|
output = self.engine.render_to_string('cache08', context)
|
|
self.assertEqual(output, 'cache06')
|
|
|
|
# Raise exception if we don't have at least 2 args, first one integer.
|
|
@setup({'cache11': '{% load cache %}{% cache %}{% endcache %}'})
|
|
def test_cache11(self):
|
|
with self.assertRaises(TemplateSyntaxError):
|
|
self.engine.get_template('cache11')
|
|
|
|
@setup({'cache12': '{% load cache %}{% cache 1 %}{% endcache %}'})
|
|
def test_cache12(self):
|
|
with self.assertRaises(TemplateSyntaxError):
|
|
self.engine.get_template('cache12')
|
|
|
|
@setup({'cache13': '{% load cache %}{% cache foo bar %}{% endcache %}'})
|
|
def test_cache13(self):
|
|
with self.assertRaises(TemplateSyntaxError):
|
|
self.engine.render_to_string('cache13')
|
|
|
|
@setup({'cache14': '{% load cache %}{% cache foo bar %}{% endcache %}'})
|
|
def test_cache14(self):
|
|
with self.assertRaises(TemplateSyntaxError):
|
|
self.engine.render_to_string('cache14', {'foo': 'fail'})
|
|
|
|
@setup({'cache15': '{% load cache %}{% cache foo bar %}{% endcache %}'})
|
|
def test_cache15(self):
|
|
with self.assertRaises(TemplateSyntaxError):
|
|
self.engine.render_to_string('cache15', {'foo': []})
|
|
|
|
@setup({'cache16': '{% load cache %}{% cache 1 foo bar %}{% endcache %}'})
|
|
def test_cache16(self):
|
|
"""
|
|
Regression test for #7460.
|
|
"""
|
|
output = self.engine.render_to_string('cache16', {'foo': 'foo', 'bar': 'with spaces'})
|
|
self.assertEqual(output, '')
|
|
|
|
@setup({'cache17': '{% load cache %}{% cache 10 long_cache_key poem %}Some Content{% endcache %}'})
|
|
def test_cache17(self):
|
|
"""
|
|
Regression test for #11270.
|
|
"""
|
|
output = self.engine.render_to_string('cache17', {'poem': 'Oh freddled gruntbuggly/'
|
|
'Thy micturations are to me/'
|
|
'As plurdled gabbleblotchits/'
|
|
'On a lurgid bee/'
|
|
'That mordiously hath bitled out/'
|
|
'Its earted jurtles/'
|
|
'Into a rancid festering/'
|
|
'Or else I shall rend thee in the gobberwarts'
|
|
'with my blurglecruncheon/'
|
|
'See if I dont.'})
|
|
self.assertEqual(output, 'Some Content')
|
|
|
|
@setup({'cache18': '{% load cache custom %}{% cache 2|noop:"x y" cache18 %}cache18{% endcache %}'})
|
|
def test_cache18(self):
|
|
"""
|
|
Test whitespace in filter arguments
|
|
"""
|
|
output = self.engine.render_to_string('cache18')
|
|
self.assertEqual(output, 'cache18')
|
|
|
|
|
|
class CacheTests(SimpleTestCase):
|
|
|
|
@classmethod
|
|
def setUpClass(cls):
|
|
cls.engine = Engine(libraries={'cache': 'django.templatetags.cache'})
|
|
super(CacheTests, cls).setUpClass()
|
|
|
|
def test_cache_regression_20130(self):
|
|
t = self.engine.from_string('{% load cache %}{% cache 1 regression_20130 %}foo{% endcache %}')
|
|
cachenode = t.nodelist[1]
|
|
self.assertEqual(cachenode.fragment_name, 'regression_20130')
|
|
|
|
@override_settings(CACHES={
|
|
'default': {
|
|
'BACKEND': 'django.core.cache.backends.locmem.LocMemCache',
|
|
'LOCATION': 'default',
|
|
},
|
|
'template_fragments': {
|
|
'BACKEND': 'django.core.cache.backends.locmem.LocMemCache',
|
|
'LOCATION': 'fragments',
|
|
},
|
|
})
|
|
def test_cache_fragment_cache(self):
|
|
"""
|
|
When a cache called "template_fragments" is present, the cache tag
|
|
will use it in preference to 'default'
|
|
"""
|
|
t1 = self.engine.from_string('{% load cache %}{% cache 1 fragment %}foo{% endcache %}')
|
|
t2 = self.engine.from_string('{% load cache %}{% cache 1 fragment using="default" %}bar{% endcache %}')
|
|
|
|
ctx = Context()
|
|
o1 = t1.render(ctx)
|
|
o2 = t2.render(ctx)
|
|
|
|
self.assertEqual(o1, 'foo')
|
|
self.assertEqual(o2, 'bar')
|
|
|
|
def test_cache_missing_backend(self):
|
|
"""
|
|
When a cache that doesn't exist is specified, the cache tag will
|
|
raise a TemplateSyntaxError
|
|
'"""
|
|
t = self.engine.from_string('{% load cache %}{% cache 1 backend using="unknown" %}bar{% endcache %}')
|
|
|
|
ctx = Context()
|
|
with self.assertRaises(TemplateSyntaxError):
|
|
t.render(ctx)
|