mirror of
				https://github.com/django/django.git
				synced 2025-10-26 07:06:08 +00:00 
			
		
		
		
	Updated template tests to create their own engine.
This continues work to treat Django templates as a library.
This commit is contained in:
		| @@ -1,5 +1,5 @@ | |||||||
| from django.core.cache import cache | from django.core.cache import cache | ||||||
| from django.template import Context, Template, TemplateSyntaxError | from django.template import Context, Engine, TemplateSyntaxError | ||||||
| from django.test import SimpleTestCase, override_settings | from django.test import SimpleTestCase, override_settings | ||||||
|  |  | ||||||
| from ..utils import setup | from ..utils import setup | ||||||
| @@ -119,8 +119,13 @@ class CacheTagTests(SimpleTestCase): | |||||||
|  |  | ||||||
| class CacheTests(SimpleTestCase): | class CacheTests(SimpleTestCase): | ||||||
|  |  | ||||||
|  |     @classmethod | ||||||
|  |     def setUpClass(cls): | ||||||
|  |         cls.engine = Engine() | ||||||
|  |         super(CacheTests, cls).setUpClass() | ||||||
|  |  | ||||||
|     def test_cache_regression_20130(self): |     def test_cache_regression_20130(self): | ||||||
|         t = Template('{% load cache %}{% cache 1 regression_20130 %}foo{% endcache %}') |         t = self.engine.from_string('{% load cache %}{% cache 1 regression_20130 %}foo{% endcache %}') | ||||||
|         cachenode = t.nodelist[1] |         cachenode = t.nodelist[1] | ||||||
|         self.assertEqual(cachenode.fragment_name, 'regression_20130') |         self.assertEqual(cachenode.fragment_name, 'regression_20130') | ||||||
|  |  | ||||||
| @@ -139,8 +144,8 @@ class CacheTests(SimpleTestCase): | |||||||
|         When a cache called "template_fragments" is present, the cache tag |         When a cache called "template_fragments" is present, the cache tag | ||||||
|         will use it in preference to 'default' |         will use it in preference to 'default' | ||||||
|         """ |         """ | ||||||
|         t1 = Template('{% load cache %}{% cache 1 fragment %}foo{% endcache %}') |         t1 = self.engine.from_string('{% load cache %}{% cache 1 fragment %}foo{% endcache %}') | ||||||
|         t2 = Template('{% load cache %}{% cache 1 fragment using="default" %}bar{% endcache %}') |         t2 = self.engine.from_string('{% load cache %}{% cache 1 fragment using="default" %}bar{% endcache %}') | ||||||
|  |  | ||||||
|         ctx = Context() |         ctx = Context() | ||||||
|         o1 = t1.render(ctx) |         o1 = t1.render(ctx) | ||||||
| @@ -154,7 +159,7 @@ class CacheTests(SimpleTestCase): | |||||||
|         When a cache that doesn't exist is specified, the cache tag will |         When a cache that doesn't exist is specified, the cache tag will | ||||||
|         raise a TemplateSyntaxError |         raise a TemplateSyntaxError | ||||||
|         '""" |         '""" | ||||||
|         t = Template('{% load cache %}{% cache 1 backend using="unknown" %}bar{% endcache %}') |         t = self.engine.from_string('{% load cache %}{% cache 1 backend using="unknown" %}bar{% endcache %}') | ||||||
|  |  | ||||||
|         ctx = Context() |         ctx = Context() | ||||||
|         with self.assertRaises(TemplateSyntaxError): |         with self.assertRaises(TemplateSyntaxError): | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| from django.template import Context, Template | from django.template import Context, Engine | ||||||
| from django.test import SimpleTestCase | from django.test import SimpleTestCase | ||||||
|  |  | ||||||
| from ..utils import setup | from ..utils import setup | ||||||
| @@ -157,11 +157,19 @@ class IfChangedTagTests(SimpleTestCase): | |||||||
|  |  | ||||||
| class IfChangedTests(SimpleTestCase): | class IfChangedTests(SimpleTestCase): | ||||||
|  |  | ||||||
|  |     @classmethod | ||||||
|  |     def setUpClass(cls): | ||||||
|  |         cls.engine = Engine() | ||||||
|  |         super(IfChangedTests, cls).setUpClass() | ||||||
|  |  | ||||||
|     def test_ifchanged_concurrency(self): |     def test_ifchanged_concurrency(self): | ||||||
|         """ |         """ | ||||||
|         #15849 -- ifchanged should be thread-safe. |         #15849 -- ifchanged should be thread-safe. | ||||||
|         """ |         """ | ||||||
|         template = Template('[0{% for x in foo %},{% with var=get_value %}{% ifchanged %}{{ var }}{% endifchanged %}{% endwith %}{% endfor %}]') |         template = self.engine.from_string( | ||||||
|  |             '[0{% for x in foo %},{% with var=get_value %}{% ifchanged %}' | ||||||
|  |             '{{ var }}{% endifchanged %}{% endwith %}{% endfor %}]' | ||||||
|  |         ) | ||||||
|  |  | ||||||
|         # Using generator to mimic concurrency. |         # Using generator to mimic concurrency. | ||||||
|         # The generator is not passed to the 'for' loop, because it does a list(values) |         # The generator is not passed to the 'for' loop, because it does a list(values) | ||||||
| @@ -184,6 +192,6 @@ class IfChangedTests(SimpleTestCase): | |||||||
|         """ |         """ | ||||||
|         #19890. The content of ifchanged template tag was rendered twice. |         #19890. The content of ifchanged template tag was rendered twice. | ||||||
|         """ |         """ | ||||||
|         template = Template('{% ifchanged %}{% cycle "1st time" "2nd time" %}{% endifchanged %}') |         template = self.engine.from_string('{% ifchanged %}{% cycle "1st time" "2nd time" %}{% endifchanged %}') | ||||||
|         output = template.render(Context({})) |         output = template.render(Context({})) | ||||||
|         self.assertEqual(output, '1st time') |         self.assertEqual(output, '1st time') | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| from django.template import ( | from django.template import ( | ||||||
|     Context, Template, TemplateDoesNotExist, TemplateSyntaxError, engines, |     Context, Engine, TemplateDoesNotExist, TemplateSyntaxError, | ||||||
| ) | ) | ||||||
| from django.test import SimpleTestCase, override_settings | from django.test import SimpleTestCase | ||||||
|  |  | ||||||
| from ..utils import setup | from ..utils import setup | ||||||
| from .test_basic import basic_templates | from .test_basic import basic_templates | ||||||
| @@ -205,110 +205,69 @@ class IncludeTagTests(SimpleTestCase): | |||||||
|  |  | ||||||
| class IncludeTests(SimpleTestCase): | class IncludeTests(SimpleTestCase): | ||||||
|  |  | ||||||
|     # Test the base loader class via the app loader. load_template |  | ||||||
|     # from base is used by all shipped loaders excepting cached, |  | ||||||
|     # which has its own test. |  | ||||||
|     @override_settings(TEMPLATES=[{ |  | ||||||
|         'BACKEND': 'django.template.backends.django.DjangoTemplates', |  | ||||||
|         'APP_DIRS': True, |  | ||||||
|         'OPTIONS': { |  | ||||||
|             # Enable debug, otherwise the exception raised during |  | ||||||
|             # {% include %} processing will be suppressed. |  | ||||||
|             'debug': True, |  | ||||||
|         } |  | ||||||
|     }]) |  | ||||||
|     def test_include_missing_template(self): |     def test_include_missing_template(self): | ||||||
|         """ |         """ | ||||||
|         Tests that the correct template is identified as not existing |         Tests that the correct template is identified as not existing | ||||||
|         when {% include %} specifies a template that does not exist. |         when {% include %} specifies a template that does not exist. | ||||||
|         """ |         """ | ||||||
|         template = engines['django'].get_template('test_include_error.html') |         engine = Engine(app_dirs=True, debug=True) | ||||||
|  |         template = engine.get_template('test_include_error.html') | ||||||
|         with self.assertRaises(TemplateDoesNotExist) as e: |         with self.assertRaises(TemplateDoesNotExist) as e: | ||||||
|             template.render() |             template.render(Context()) | ||||||
|         self.assertEqual(e.exception.args[0], 'missing.html') |         self.assertEqual(e.exception.args[0], 'missing.html') | ||||||
|  |  | ||||||
|     # Test the base loader class via the app loader. load_template |  | ||||||
|     # from base is used by all shipped loaders excepting cached, |  | ||||||
|     # which has its own test. |  | ||||||
|     @override_settings(TEMPLATES=[{ |  | ||||||
|         'BACKEND': 'django.template.backends.django.DjangoTemplates', |  | ||||||
|         'APP_DIRS': True, |  | ||||||
|         'OPTIONS': { |  | ||||||
|             # Enable debug, otherwise the exception raised during |  | ||||||
|             # {% include %} processing will be suppressed. |  | ||||||
|             'debug': True, |  | ||||||
|         } |  | ||||||
|     }]) |  | ||||||
|     def test_extends_include_missing_baseloader(self): |     def test_extends_include_missing_baseloader(self): | ||||||
|         """ |         """ | ||||||
|         #12787 -- Tests that the correct template is identified as not existing |         #12787 -- Tests that the correct template is identified as not existing | ||||||
|         when {% extends %} specifies a template that does exist, but that |         when {% extends %} specifies a template that does exist, but that | ||||||
|         template has an {% include %} of something that does not exist. |         template has an {% include %} of something that does not exist. | ||||||
|         """ |         """ | ||||||
|         template = engines['django'].get_template('test_extends_error.html') |         engine = Engine(app_dirs=True, debug=True) | ||||||
|  |         template = engine.get_template('test_extends_error.html') | ||||||
|         with self.assertRaises(TemplateDoesNotExist) as e: |         with self.assertRaises(TemplateDoesNotExist) as e: | ||||||
|             template.render() |             template.render(Context()) | ||||||
|         self.assertEqual(e.exception.args[0], 'missing.html') |         self.assertEqual(e.exception.args[0], 'missing.html') | ||||||
|  |  | ||||||
|     @override_settings(TEMPLATES=[{ |  | ||||||
|         'BACKEND': 'django.template.backends.django.DjangoTemplates', |  | ||||||
|         'OPTIONS': { |  | ||||||
|             'debug': True, |  | ||||||
|             'loaders': [ |  | ||||||
|                 ('django.template.loaders.cached.Loader', [ |  | ||||||
|                     'django.template.loaders.app_directories.Loader', |  | ||||||
|                 ]), |  | ||||||
|             ], |  | ||||||
|         }, |  | ||||||
|     }]) |  | ||||||
|     def test_extends_include_missing_cachedloader(self): |     def test_extends_include_missing_cachedloader(self): | ||||||
|         """ |         """ | ||||||
|         Test the cache loader separately since it overrides load_template. |         Test the cache loader separately since it overrides load_template. | ||||||
|         """ |         """ | ||||||
|  |         engine = Engine(debug=True, loaders=[ | ||||||
|  |             ('django.template.loaders.cached.Loader', [ | ||||||
|  |                 'django.template.loaders.app_directories.Loader', | ||||||
|  |             ]), | ||||||
|  |         ]) | ||||||
|  |  | ||||||
|         template = engines['django'].get_template('test_extends_error.html') |         template = engine.get_template('test_extends_error.html') | ||||||
|         with self.assertRaises(TemplateDoesNotExist) as e: |         with self.assertRaises(TemplateDoesNotExist) as e: | ||||||
|             template.render() |             template.render(Context()) | ||||||
|         self.assertEqual(e.exception.args[0], 'missing.html') |         self.assertEqual(e.exception.args[0], 'missing.html') | ||||||
|  |  | ||||||
|         # Repeat to ensure it still works when loading from the cache |         # Repeat to ensure it still works when loading from the cache | ||||||
|         template = engines['django'].get_template('test_extends_error.html') |         template = engine.get_template('test_extends_error.html') | ||||||
|         with self.assertRaises(TemplateDoesNotExist) as e: |         with self.assertRaises(TemplateDoesNotExist) as e: | ||||||
|             template.render() |             template.render(Context()) | ||||||
|         self.assertEqual(e.exception.args[0], 'missing.html') |         self.assertEqual(e.exception.args[0], 'missing.html') | ||||||
|  |  | ||||||
|     def test_include_template_argument(self): |     def test_include_template_argument(self): | ||||||
|         """ |         """ | ||||||
|         Support any render() supporting object |         Support any render() supporting object | ||||||
|         """ |         """ | ||||||
|  |         engine = Engine() | ||||||
|         ctx = Context({ |         ctx = Context({ | ||||||
|             'tmpl': Template('This worked!'), |             'tmpl': engine.from_string('This worked!'), | ||||||
|         }) |         }) | ||||||
|         outer_tmpl = Template('{% include tmpl %}') |         outer_tmpl = engine.from_string('{% include tmpl %}') | ||||||
|         output = outer_tmpl.render(ctx) |         output = outer_tmpl.render(ctx) | ||||||
|         self.assertEqual(output, 'This worked!') |         self.assertEqual(output, 'This worked!') | ||||||
|  |  | ||||||
|     @override_settings(TEMPLATES=[{ |  | ||||||
|         'BACKEND': 'django.template.backends.django.DjangoTemplates', |  | ||||||
|         'OPTIONS': { |  | ||||||
|             'debug': True, |  | ||||||
|         }, |  | ||||||
|     }]) |  | ||||||
|     def test_include_immediate_missing(self): |     def test_include_immediate_missing(self): | ||||||
|         """ |         """ | ||||||
|         #16417 -- Include tags pointing to missing templates should not raise |         #16417 -- Include tags pointing to missing templates should not raise | ||||||
|         an error at parsing time. |         an error at parsing time. | ||||||
|         """ |         """ | ||||||
|         template = Template('{% include "this_does_not_exist.html" %}') |         Engine(debug=True).from_string('{% include "this_does_not_exist.html" %}') | ||||||
|         self.assertIsInstance(template, Template) |  | ||||||
|  |  | ||||||
|     @override_settings(TEMPLATES=[{ |  | ||||||
|         'BACKEND': 'django.template.backends.django.DjangoTemplates', |  | ||||||
|         'APP_DIRS': True, |  | ||||||
|         'OPTIONS': { |  | ||||||
|             'debug': True, |  | ||||||
|         }, |  | ||||||
|     }]) |  | ||||||
|     def test_include_recursive(self): |     def test_include_recursive(self): | ||||||
|         comments = [ |         comments = [ | ||||||
|             { |             { | ||||||
| @@ -322,9 +281,9 @@ class IncludeTests(SimpleTestCase): | |||||||
|                 ] |                 ] | ||||||
|             } |             } | ||||||
|         ] |         ] | ||||||
|  |         engine = Engine(app_dirs=True) | ||||||
|         t = engines['django'].get_template('recursive_include.html') |         t = engine.get_template('recursive_include.html') | ||||||
|         self.assertEqual( |         self.assertEqual( | ||||||
|             "Recursion!  A1  Recursion!  B1   B2   B3  Recursion!  C1", |             "Recursion!  A1  Recursion!  B1   B2   B3  Recursion!  C1", | ||||||
|             t.render({'comments': comments}).replace(' ', '').replace('\n', ' ').strip(), |             t.render(Context({'comments': comments})).replace(' ', '').replace('\n', ' ').strip(), | ||||||
|         ) |         ) | ||||||
|   | |||||||
| @@ -1,9 +1,9 @@ | |||||||
| import operator | import operator | ||||||
|  |  | ||||||
| from django.template import Library | from django.template import Engine, Library | ||||||
| from django.template.loader import get_template |  | ||||||
| from django.utils import six | from django.utils import six | ||||||
|  |  | ||||||
|  | engine = Engine(app_dirs=True) | ||||||
| register = Library() | register = Library() | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -14,7 +14,7 @@ def inclusion_no_params(): | |||||||
| inclusion_no_params.anything = "Expected inclusion_no_params __dict__" | inclusion_no_params.anything = "Expected inclusion_no_params __dict__" | ||||||
|  |  | ||||||
|  |  | ||||||
| @register.inclusion_tag(get_template('inclusion.html')) | @register.inclusion_tag(engine.get_template('inclusion.html')) | ||||||
| def inclusion_no_params_from_template(): | def inclusion_no_params_from_template(): | ||||||
|     """Expected inclusion_no_params_from_template __doc__""" |     """Expected inclusion_no_params_from_template __doc__""" | ||||||
|     return {"result": "inclusion_no_params_from_template - Expected result"} |     return {"result": "inclusion_no_params_from_template - Expected result"} | ||||||
| @@ -28,7 +28,7 @@ def inclusion_one_param(arg): | |||||||
| inclusion_one_param.anything = "Expected inclusion_one_param __dict__" | inclusion_one_param.anything = "Expected inclusion_one_param __dict__" | ||||||
|  |  | ||||||
|  |  | ||||||
| @register.inclusion_tag(get_template('inclusion.html')) | @register.inclusion_tag(engine.get_template('inclusion.html')) | ||||||
| def inclusion_one_param_from_template(arg): | def inclusion_one_param_from_template(arg): | ||||||
|     """Expected inclusion_one_param_from_template __doc__""" |     """Expected inclusion_one_param_from_template __doc__""" | ||||||
|     return {"result": "inclusion_one_param_from_template - Expected result: %s" % arg} |     return {"result": "inclusion_one_param_from_template - Expected result: %s" % arg} | ||||||
| @@ -42,7 +42,7 @@ def inclusion_explicit_no_context(arg): | |||||||
| inclusion_explicit_no_context.anything = "Expected inclusion_explicit_no_context __dict__" | inclusion_explicit_no_context.anything = "Expected inclusion_explicit_no_context __dict__" | ||||||
|  |  | ||||||
|  |  | ||||||
| @register.inclusion_tag(get_template('inclusion.html'), takes_context=False) | @register.inclusion_tag(engine.get_template('inclusion.html'), takes_context=False) | ||||||
| def inclusion_explicit_no_context_from_template(arg): | def inclusion_explicit_no_context_from_template(arg): | ||||||
|     """Expected inclusion_explicit_no_context_from_template __doc__""" |     """Expected inclusion_explicit_no_context_from_template __doc__""" | ||||||
|     return {"result": "inclusion_explicit_no_context_from_template - Expected result: %s" % arg} |     return {"result": "inclusion_explicit_no_context_from_template - Expected result: %s" % arg} | ||||||
| @@ -56,7 +56,7 @@ def inclusion_no_params_with_context(context): | |||||||
| inclusion_no_params_with_context.anything = "Expected inclusion_no_params_with_context __dict__" | inclusion_no_params_with_context.anything = "Expected inclusion_no_params_with_context __dict__" | ||||||
|  |  | ||||||
|  |  | ||||||
| @register.inclusion_tag(get_template('inclusion.html'), takes_context=True) | @register.inclusion_tag(engine.get_template('inclusion.html'), takes_context=True) | ||||||
| def inclusion_no_params_with_context_from_template(context): | def inclusion_no_params_with_context_from_template(context): | ||||||
|     """Expected inclusion_no_params_with_context_from_template __doc__""" |     """Expected inclusion_no_params_with_context_from_template __doc__""" | ||||||
|     return {"result": "inclusion_no_params_with_context_from_template - Expected result (context value: %s)" % context['value']} |     return {"result": "inclusion_no_params_with_context_from_template - Expected result (context value: %s)" % context['value']} | ||||||
| @@ -70,7 +70,7 @@ def inclusion_params_and_context(context, arg): | |||||||
| inclusion_params_and_context.anything = "Expected inclusion_params_and_context __dict__" | inclusion_params_and_context.anything = "Expected inclusion_params_and_context __dict__" | ||||||
|  |  | ||||||
|  |  | ||||||
| @register.inclusion_tag(get_template('inclusion.html'), takes_context=True) | @register.inclusion_tag(engine.get_template('inclusion.html'), takes_context=True) | ||||||
| def inclusion_params_and_context_from_template(context, arg): | def inclusion_params_and_context_from_template(context, arg): | ||||||
|     """Expected inclusion_params_and_context_from_template __doc__""" |     """Expected inclusion_params_and_context_from_template __doc__""" | ||||||
|     return {"result": "inclusion_params_and_context_from_template - Expected result (context value: %s): %s" % (context['value'], arg)} |     return {"result": "inclusion_params_and_context_from_template - Expected result (context value: %s): %s" % (context['value'], arg)} | ||||||
| @@ -84,7 +84,7 @@ def inclusion_two_params(one, two): | |||||||
| inclusion_two_params.anything = "Expected inclusion_two_params __dict__" | inclusion_two_params.anything = "Expected inclusion_two_params __dict__" | ||||||
|  |  | ||||||
|  |  | ||||||
| @register.inclusion_tag(get_template('inclusion.html')) | @register.inclusion_tag(engine.get_template('inclusion.html')) | ||||||
| def inclusion_two_params_from_template(one, two): | def inclusion_two_params_from_template(one, two): | ||||||
|     """Expected inclusion_two_params_from_template __doc__""" |     """Expected inclusion_two_params_from_template __doc__""" | ||||||
|     return {"result": "inclusion_two_params_from_template - Expected result: %s, %s" % (one, two)} |     return {"result": "inclusion_two_params_from_template - Expected result: %s, %s" % (one, two)} | ||||||
| @@ -98,7 +98,7 @@ def inclusion_one_default(one, two='hi'): | |||||||
| inclusion_one_default.anything = "Expected inclusion_one_default __dict__" | inclusion_one_default.anything = "Expected inclusion_one_default __dict__" | ||||||
|  |  | ||||||
|  |  | ||||||
| @register.inclusion_tag(get_template('inclusion.html')) | @register.inclusion_tag(engine.get_template('inclusion.html')) | ||||||
| def inclusion_one_default_from_template(one, two='hi'): | def inclusion_one_default_from_template(one, two='hi'): | ||||||
|     """Expected inclusion_one_default_from_template __doc__""" |     """Expected inclusion_one_default_from_template __doc__""" | ||||||
|     return {"result": "inclusion_one_default_from_template - Expected result: %s, %s" % (one, two)} |     return {"result": "inclusion_one_default_from_template - Expected result: %s, %s" % (one, two)} | ||||||
| @@ -112,7 +112,7 @@ def inclusion_unlimited_args(one, two='hi', *args): | |||||||
| inclusion_unlimited_args.anything = "Expected inclusion_unlimited_args __dict__" | inclusion_unlimited_args.anything = "Expected inclusion_unlimited_args __dict__" | ||||||
|  |  | ||||||
|  |  | ||||||
| @register.inclusion_tag(get_template('inclusion.html')) | @register.inclusion_tag(engine.get_template('inclusion.html')) | ||||||
| def inclusion_unlimited_args_from_template(one, two='hi', *args): | def inclusion_unlimited_args_from_template(one, two='hi', *args): | ||||||
|     """Expected inclusion_unlimited_args_from_template __doc__""" |     """Expected inclusion_unlimited_args_from_template __doc__""" | ||||||
|     return {"result": "inclusion_unlimited_args_from_template - Expected result: %s" % (', '.join(six.text_type(arg) for arg in [one, two] + list(args)))} |     return {"result": "inclusion_unlimited_args_from_template - Expected result: %s" % (', '.join(six.text_type(arg) for arg in [one, two] + list(args)))} | ||||||
| @@ -126,7 +126,7 @@ def inclusion_only_unlimited_args(*args): | |||||||
| inclusion_only_unlimited_args.anything = "Expected inclusion_only_unlimited_args __dict__" | inclusion_only_unlimited_args.anything = "Expected inclusion_only_unlimited_args __dict__" | ||||||
|  |  | ||||||
|  |  | ||||||
| @register.inclusion_tag(get_template('inclusion.html')) | @register.inclusion_tag(engine.get_template('inclusion.html')) | ||||||
| def inclusion_only_unlimited_args_from_template(*args): | def inclusion_only_unlimited_args_from_template(*args): | ||||||
|     """Expected inclusion_only_unlimited_args_from_template __doc__""" |     """Expected inclusion_only_unlimited_args_from_template __doc__""" | ||||||
|     return {"result": "inclusion_only_unlimited_args_from_template - Expected result: %s" % (', '.join(six.text_type(arg) for arg in args))} |     return {"result": "inclusion_only_unlimited_args_from_template - Expected result: %s" % (', '.join(six.text_type(arg) for arg in args))} | ||||||
|   | |||||||
| @@ -2,11 +2,16 @@ from __future__ import unicode_literals | |||||||
|  |  | ||||||
| from unittest import TestCase | from unittest import TestCase | ||||||
|  |  | ||||||
| from django import template | from django.template import Context, Engine | ||||||
|  |  | ||||||
|  |  | ||||||
| class CallableVariablesTests(TestCase): | class CallableVariablesTests(TestCase): | ||||||
|  |  | ||||||
|  |     @classmethod | ||||||
|  |     def setUpClass(cls): | ||||||
|  |         cls.engine = Engine() | ||||||
|  |         super(CallableVariablesTests, cls).setUpClass() | ||||||
|  |  | ||||||
|     def test_callable(self): |     def test_callable(self): | ||||||
|  |  | ||||||
|         class Doodad(object): |         class Doodad(object): | ||||||
| @@ -19,12 +24,12 @@ class CallableVariablesTests(TestCase): | |||||||
|                 return {"the_value": self.value} |                 return {"the_value": self.value} | ||||||
|  |  | ||||||
|         my_doodad = Doodad(42) |         my_doodad = Doodad(42) | ||||||
|         c = template.Context({"my_doodad": my_doodad}) |         c = Context({"my_doodad": my_doodad}) | ||||||
|  |  | ||||||
|         # We can't access ``my_doodad.value`` in the template, because |         # We can't access ``my_doodad.value`` in the template, because | ||||||
|         # ``my_doodad.__call__`` will be invoked first, yielding a dictionary |         # ``my_doodad.__call__`` will be invoked first, yielding a dictionary | ||||||
|         # without a key ``value``. |         # without a key ``value``. | ||||||
|         t = template.Template('{{ my_doodad.value }}') |         t = self.engine.from_string('{{ my_doodad.value }}') | ||||||
|         self.assertEqual(t.render(c), '') |         self.assertEqual(t.render(c), '') | ||||||
|  |  | ||||||
|         # We can confirm that the doodad has been called |         # We can confirm that the doodad has been called | ||||||
| @@ -32,7 +37,7 @@ class CallableVariablesTests(TestCase): | |||||||
|  |  | ||||||
|         # But we can access keys on the dict that's returned |         # But we can access keys on the dict that's returned | ||||||
|         # by ``__call__``, instead. |         # by ``__call__``, instead. | ||||||
|         t = template.Template('{{ my_doodad.the_value }}') |         t = self.engine.from_string('{{ my_doodad.the_value }}') | ||||||
|         self.assertEqual(t.render(c), '42') |         self.assertEqual(t.render(c), '42') | ||||||
|         self.assertEqual(my_doodad.num_calls, 2) |         self.assertEqual(my_doodad.num_calls, 2) | ||||||
|  |  | ||||||
| @@ -50,13 +55,13 @@ class CallableVariablesTests(TestCase): | |||||||
|                 return {"the_value": self.value} |                 return {"the_value": self.value} | ||||||
|  |  | ||||||
|         my_doodad = Doodad(42) |         my_doodad = Doodad(42) | ||||||
|         c = template.Context({"my_doodad": my_doodad}) |         c = Context({"my_doodad": my_doodad}) | ||||||
|  |  | ||||||
|         # Since ``my_doodad.alters_data`` is True, the template system will not |         # Since ``my_doodad.alters_data`` is True, the template system will not | ||||||
|         # try to call our doodad but will use string_if_invalid |         # try to call our doodad but will use string_if_invalid | ||||||
|         t = template.Template('{{ my_doodad.value }}') |         t = self.engine.from_string('{{ my_doodad.value }}') | ||||||
|         self.assertEqual(t.render(c), '') |         self.assertEqual(t.render(c), '') | ||||||
|         t = template.Template('{{ my_doodad.the_value }}') |         t = self.engine.from_string('{{ my_doodad.the_value }}') | ||||||
|         self.assertEqual(t.render(c), '') |         self.assertEqual(t.render(c), '') | ||||||
|  |  | ||||||
|         # Double-check that the object was really never called during the |         # Double-check that the object was really never called during the | ||||||
| @@ -77,15 +82,15 @@ class CallableVariablesTests(TestCase): | |||||||
|                 return {"the_value": self.value} |                 return {"the_value": self.value} | ||||||
|  |  | ||||||
|         my_doodad = Doodad(42) |         my_doodad = Doodad(42) | ||||||
|         c = template.Context({"my_doodad": my_doodad}) |         c = Context({"my_doodad": my_doodad}) | ||||||
|  |  | ||||||
|         # Since ``my_doodad.do_not_call_in_templates`` is True, the template |         # Since ``my_doodad.do_not_call_in_templates`` is True, the template | ||||||
|         # system will not try to call our doodad.  We can access its attributes |         # system will not try to call our doodad.  We can access its attributes | ||||||
|         # as normal, and we don't have access to the dict that it returns when |         # as normal, and we don't have access to the dict that it returns when | ||||||
|         # called. |         # called. | ||||||
|         t = template.Template('{{ my_doodad.value }}') |         t = self.engine.from_string('{{ my_doodad.value }}') | ||||||
|         self.assertEqual(t.render(c), '42') |         self.assertEqual(t.render(c), '42') | ||||||
|         t = template.Template('{{ my_doodad.the_value }}') |         t = self.engine.from_string('{{ my_doodad.the_value }}') | ||||||
|         self.assertEqual(t.render(c), '') |         self.assertEqual(t.render(c), '') | ||||||
|  |  | ||||||
|         # Double-check that the object was really never called during the |         # Double-check that the object was really never called during the | ||||||
| @@ -110,11 +115,11 @@ class CallableVariablesTests(TestCase): | |||||||
|                 return {"the_value": self.value} |                 return {"the_value": self.value} | ||||||
|  |  | ||||||
|         my_doodad = Doodad(42) |         my_doodad = Doodad(42) | ||||||
|         c = template.Context({"my_doodad": my_doodad}) |         c = Context({"my_doodad": my_doodad}) | ||||||
|  |  | ||||||
|         t = template.Template('{{ my_doodad.value }}') |         t = self.engine.from_string('{{ my_doodad.value }}') | ||||||
|         self.assertEqual(t.render(c), '42') |         self.assertEqual(t.render(c), '42') | ||||||
|         t = template.Template('{{ my_doodad.the_value }}') |         t = self.engine.from_string('{{ my_doodad.the_value }}') | ||||||
|         self.assertEqual(t.render(c), '') |         self.assertEqual(t.render(c), '') | ||||||
|  |  | ||||||
|         # Double-check that the object was really never called during the |         # Double-check that the object was really never called during the | ||||||
|   | |||||||
| @@ -2,10 +2,10 @@ | |||||||
|  |  | ||||||
| from django.http import HttpRequest | from django.http import HttpRequest | ||||||
| from django.template import ( | from django.template import ( | ||||||
|     Context, RequestContext, Template, Variable, VariableDoesNotExist, |     Context, Engine, RequestContext, Variable, VariableDoesNotExist, | ||||||
| ) | ) | ||||||
| from django.template.context import RenderContext | from django.template.context import RenderContext | ||||||
| from django.test import RequestFactory, SimpleTestCase, override_settings | from django.test import RequestFactory, SimpleTestCase | ||||||
|  |  | ||||||
|  |  | ||||||
| class ContextTests(SimpleTestCase): | class ContextTests(SimpleTestCase): | ||||||
| @@ -131,25 +131,20 @@ class ContextTests(SimpleTestCase): | |||||||
|  |  | ||||||
| class RequestContextTests(SimpleTestCase): | class RequestContextTests(SimpleTestCase): | ||||||
|  |  | ||||||
|     @override_settings(TEMPLATES=[{ |  | ||||||
|         'BACKEND': 'django.template.backends.django.DjangoTemplates', |  | ||||||
|         'OPTIONS': { |  | ||||||
|             'loaders': [ |  | ||||||
|                 ('django.template.loaders.locmem.Loader', { |  | ||||||
|                     'child': '{{ var|default:"none" }}', |  | ||||||
|                 }), |  | ||||||
|             ], |  | ||||||
|         }, |  | ||||||
|     }]) |  | ||||||
|     def test_include_only(self): |     def test_include_only(self): | ||||||
|         """ |         """ | ||||||
|         #15721 -- ``{% include %}`` and ``RequestContext`` should work |         #15721 -- ``{% include %}`` and ``RequestContext`` should work | ||||||
|         together. |         together. | ||||||
|         """ |         """ | ||||||
|  |         engine = Engine(loaders=[ | ||||||
|  |             ('django.template.loaders.locmem.Loader', { | ||||||
|  |                 'child': '{{ var|default:"none" }}', | ||||||
|  |             }), | ||||||
|  |         ]) | ||||||
|         request = RequestFactory().get('/') |         request = RequestFactory().get('/') | ||||||
|         ctx = RequestContext(request, {'var': 'parent'}) |         ctx = RequestContext(request, {'var': 'parent'}) | ||||||
|         self.assertEqual(Template('{% include "child" %}').render(ctx), 'parent') |         self.assertEqual(engine.from_string('{% include "child" %}').render(ctx), 'parent') | ||||||
|         self.assertEqual(Template('{% include "child" only %}').render(ctx), 'none') |         self.assertEqual(engine.from_string('{% include "child" only %}').render(ctx), 'none') | ||||||
|  |  | ||||||
|     def test_stack_size(self): |     def test_stack_size(self): | ||||||
|         """ |         """ | ||||||
|   | |||||||
| @@ -2,7 +2,7 @@ from __future__ import unicode_literals | |||||||
|  |  | ||||||
| import os | import os | ||||||
|  |  | ||||||
| from django.template import Context, Engine, Template, TemplateSyntaxError | from django.template import Context, Engine, TemplateSyntaxError | ||||||
| from django.template.base import Node | from django.template.base import Node | ||||||
| from django.test import SimpleTestCase, ignore_warnings | from django.test import SimpleTestCase, ignore_warnings | ||||||
| from django.test.utils import extend_sys_path | from django.test.utils import extend_sys_path | ||||||
| @@ -15,7 +15,7 @@ from .utils import ROOT | |||||||
| class CustomFilterTests(SimpleTestCase): | class CustomFilterTests(SimpleTestCase): | ||||||
|  |  | ||||||
|     def test_filter(self): |     def test_filter(self): | ||||||
|         t = Template("{% load custom %}{{ string|trim:5 }}") |         t = Engine().from_string("{% load custom %}{{ string|trim:5 }}") | ||||||
|         self.assertEqual( |         self.assertEqual( | ||||||
|             t.render(Context({"string": "abcdefghijklmnopqrstuvwxyz"})), |             t.render(Context({"string": "abcdefghijklmnopqrstuvwxyz"})), | ||||||
|             "abcde" |             "abcde" | ||||||
| @@ -24,6 +24,11 @@ class CustomFilterTests(SimpleTestCase): | |||||||
|  |  | ||||||
| class TagTestCase(SimpleTestCase): | class TagTestCase(SimpleTestCase): | ||||||
|  |  | ||||||
|  |     @classmethod | ||||||
|  |     def setUpClass(cls): | ||||||
|  |         cls.engine = Engine(app_dirs=True) | ||||||
|  |         super(TagTestCase, cls).setUpClass() | ||||||
|  |  | ||||||
|     def verify_tag(self, tag, name): |     def verify_tag(self, tag, name): | ||||||
|         self.assertEqual(tag.__name__, name) |         self.assertEqual(tag.__name__, name) | ||||||
|         self.assertEqual(tag.__doc__, 'Expected %s __doc__' % name) |         self.assertEqual(tag.__doc__, 'Expected %s __doc__' % name) | ||||||
| @@ -62,11 +67,11 @@ class SimpleTagTests(TagTestCase): | |||||||
|         ] |         ] | ||||||
|  |  | ||||||
|         for entry in templates: |         for entry in templates: | ||||||
|             t = Template(entry[0]) |             t = self.engine.from_string(entry[0]) | ||||||
|             self.assertEqual(t.render(c), entry[1]) |             self.assertEqual(t.render(c), entry[1]) | ||||||
|  |  | ||||||
|         for entry in templates: |         for entry in templates: | ||||||
|             t = Template("%s as var %%}Result: {{ var }}" % entry[0][0:-2]) |             t = self.engine.from_string("%s as var %%}Result: {{ var }}" % entry[0][0:-2]) | ||||||
|             self.assertEqual(t.render(c), "Result: %s" % entry[1]) |             self.assertEqual(t.render(c), "Result: %s" % entry[1]) | ||||||
|  |  | ||||||
|     def test_simple_tag_errors(self): |     def test_simple_tag_errors(self): | ||||||
| @@ -85,11 +90,11 @@ class SimpleTagTests(TagTestCase): | |||||||
|  |  | ||||||
|         for entry in errors: |         for entry in errors: | ||||||
|             with self.assertRaisesMessage(TemplateSyntaxError, entry[0]): |             with self.assertRaisesMessage(TemplateSyntaxError, entry[0]): | ||||||
|                 Template(entry[1]) |                 self.engine.from_string(entry[1]) | ||||||
|  |  | ||||||
|         for entry in errors: |         for entry in errors: | ||||||
|             with self.assertRaisesMessage(TemplateSyntaxError, entry[0]): |             with self.assertRaisesMessage(TemplateSyntaxError, entry[0]): | ||||||
|                 Template("%s as var %%}" % entry[1][0:-2]) |                 self.engine.from_string("%s as var %%}" % entry[1][0:-2]) | ||||||
|  |  | ||||||
|     def test_simple_tag_registration(self): |     def test_simple_tag_registration(self): | ||||||
|         # Test that the decorators preserve the decorated function's docstring, name and attributes. |         # Test that the decorators preserve the decorated function's docstring, name and attributes. | ||||||
| @@ -108,7 +113,7 @@ class SimpleTagTests(TagTestCase): | |||||||
|             "takes_context=True so it must have a first argument of 'context'" |             "takes_context=True so it must have a first argument of 'context'" | ||||||
|         ) |         ) | ||||||
|         with self.assertRaisesMessage(TemplateSyntaxError, msg): |         with self.assertRaisesMessage(TemplateSyntaxError, msg): | ||||||
|             Template('{% load custom %}{% simple_tag_without_context_parameter 123 %}') |             self.engine.from_string('{% load custom %}{% simple_tag_without_context_parameter 123 %}') | ||||||
|  |  | ||||||
|  |  | ||||||
| class InclusionTagTests(TagTestCase): | class InclusionTagTests(TagTestCase): | ||||||
| @@ -147,7 +152,7 @@ class InclusionTagTests(TagTestCase): | |||||||
|         ] |         ] | ||||||
|  |  | ||||||
|         for entry in templates: |         for entry in templates: | ||||||
|             t = Template(entry[0]) |             t = self.engine.from_string(entry[0]) | ||||||
|             self.assertEqual(t.render(c), entry[1]) |             self.assertEqual(t.render(c), entry[1]) | ||||||
|  |  | ||||||
|     def test_inclusion_tag_errors(self): |     def test_inclusion_tag_errors(self): | ||||||
| @@ -173,7 +178,7 @@ class InclusionTagTests(TagTestCase): | |||||||
|  |  | ||||||
|         for entry in errors: |         for entry in errors: | ||||||
|             with self.assertRaisesMessage(TemplateSyntaxError, entry[0]): |             with self.assertRaisesMessage(TemplateSyntaxError, entry[0]): | ||||||
|                 Template(entry[1]) |                 self.engine.from_string(entry[1]) | ||||||
|  |  | ||||||
|     def test_include_tag_missing_context(self): |     def test_include_tag_missing_context(self): | ||||||
|         # The 'context' parameter must be present when takes_context is True |         # The 'context' parameter must be present when takes_context is True | ||||||
| @@ -182,7 +187,7 @@ class InclusionTagTests(TagTestCase): | |||||||
|             "takes_context=True so it must have a first argument of 'context'" |             "takes_context=True so it must have a first argument of 'context'" | ||||||
|         ) |         ) | ||||||
|         with self.assertRaisesMessage(TemplateSyntaxError, msg): |         with self.assertRaisesMessage(TemplateSyntaxError, msg): | ||||||
|             Template('{% load inclusion %}{% inclusion_tag_without_context_parameter 123 %}') |             self.engine.from_string('{% load inclusion %}{% inclusion_tag_without_context_parameter 123 %}') | ||||||
|  |  | ||||||
|     def test_inclusion_tags_from_template(self): |     def test_inclusion_tags_from_template(self): | ||||||
|         c = Context({'value': 42}) |         c = Context({'value': 42}) | ||||||
| @@ -215,7 +220,7 @@ class InclusionTagTests(TagTestCase): | |||||||
|         ] |         ] | ||||||
|  |  | ||||||
|         for entry in templates: |         for entry in templates: | ||||||
|             t = Template(entry[0]) |             t = self.engine.from_string(entry[0]) | ||||||
|             self.assertEqual(t.render(c), entry[1]) |             self.assertEqual(t.render(c), entry[1]) | ||||||
|  |  | ||||||
|     def test_inclusion_tag_registration(self): |     def test_inclusion_tag_registration(self): | ||||||
| @@ -241,7 +246,7 @@ class InclusionTagTests(TagTestCase): | |||||||
|         Context of the included/rendered template as well. |         Context of the included/rendered template as well. | ||||||
|         """ |         """ | ||||||
|         c = Context({}) |         c = Context({}) | ||||||
|         t = Template('{% load inclusion %}{% inclusion_tag_current_app %}') |         t = self.engine.from_string('{% load inclusion %}{% inclusion_tag_current_app %}') | ||||||
|         self.assertEqual(t.render(c).strip(), 'None') |         self.assertEqual(t.render(c).strip(), 'None') | ||||||
|  |  | ||||||
|         # That part produces the deprecation warning |         # That part produces the deprecation warning | ||||||
| @@ -254,7 +259,7 @@ class InclusionTagTests(TagTestCase): | |||||||
|         Context of the included/rendered template as well. |         Context of the included/rendered template as well. | ||||||
|         """ |         """ | ||||||
|         c = Context({}) |         c = Context({}) | ||||||
|         t = Template('{% load inclusion %}{% inclusion_tag_use_l10n %}') |         t = self.engine.from_string('{% load inclusion %}{% inclusion_tag_use_l10n %}') | ||||||
|         self.assertEqual(t.render(c).strip(), 'None') |         self.assertEqual(t.render(c).strip(), 'None') | ||||||
|  |  | ||||||
|         c.use_l10n = True |         c.use_l10n = True | ||||||
| @@ -286,7 +291,7 @@ class AssignmentTagTests(TagTestCase): | |||||||
|     def test_assignment_tags(self): |     def test_assignment_tags(self): | ||||||
|         c = Context({'value': 42}) |         c = Context({'value': 42}) | ||||||
|  |  | ||||||
|         t = Template('{% load custom %}{% assignment_no_params as var %}The result is: {{ var }}') |         t = self.engine.from_string('{% load custom %}{% assignment_no_params as var %}The result is: {{ var }}') | ||||||
|         self.assertEqual(t.render(c), 'The result is: assignment_no_params - Expected result') |         self.assertEqual(t.render(c), 'The result is: assignment_no_params - Expected result') | ||||||
|  |  | ||||||
|     def test_assignment_tag_registration(self): |     def test_assignment_tag_registration(self): | ||||||
| @@ -300,18 +305,21 @@ class AssignmentTagTests(TagTestCase): | |||||||
|             "takes_context=True so it must have a first argument of 'context'" |             "takes_context=True so it must have a first argument of 'context'" | ||||||
|         ) |         ) | ||||||
|         with self.assertRaisesMessage(TemplateSyntaxError, msg): |         with self.assertRaisesMessage(TemplateSyntaxError, msg): | ||||||
|             Template('{% load custom %}{% assignment_tag_without_context_parameter 123 as var %}') |             self.engine.from_string('{% load custom %}{% assignment_tag_without_context_parameter 123 as var %}') | ||||||
|  |  | ||||||
|  |  | ||||||
| class TemplateTagLoadingTests(SimpleTestCase): | class TemplateTagLoadingTests(SimpleTestCase): | ||||||
|  |  | ||||||
|     def setUp(self): |     @classmethod | ||||||
|         self.egg_dir = os.path.join(ROOT, 'eggs') |     def setUpClass(cls): | ||||||
|  |         cls.egg_dir = os.path.join(ROOT, 'eggs') | ||||||
|  |         cls.engine = Engine() | ||||||
|  |         super(TemplateTagLoadingTests, cls).setUpClass() | ||||||
|  |  | ||||||
|     def test_load_error(self): |     def test_load_error(self): | ||||||
|         ttext = "{% load broken_tag %}" |         ttext = "{% load broken_tag %}" | ||||||
|         with self.assertRaises(TemplateSyntaxError) as e: |         with self.assertRaises(TemplateSyntaxError) as e: | ||||||
|             Template(ttext) |             self.engine.from_string(ttext) | ||||||
|  |  | ||||||
|         self.assertIn('ImportError', e.exception.args[0]) |         self.assertIn('ImportError', e.exception.args[0]) | ||||||
|         self.assertIn('Xtemplate', e.exception.args[0]) |         self.assertIn('Xtemplate', e.exception.args[0]) | ||||||
| @@ -322,10 +330,10 @@ class TemplateTagLoadingTests(SimpleTestCase): | |||||||
|         with extend_sys_path(egg_name): |         with extend_sys_path(egg_name): | ||||||
|             with self.assertRaises(TemplateSyntaxError): |             with self.assertRaises(TemplateSyntaxError): | ||||||
|                 with self.settings(INSTALLED_APPS=['tagsegg']): |                 with self.settings(INSTALLED_APPS=['tagsegg']): | ||||||
|                     Template(ttext) |                     self.engine.from_string(ttext) | ||||||
|             try: |             try: | ||||||
|                 with self.settings(INSTALLED_APPS=['tagsegg']): |                 with self.settings(INSTALLED_APPS=['tagsegg']): | ||||||
|                     Template(ttext) |                     self.engine.from_string(ttext) | ||||||
|             except TemplateSyntaxError as e: |             except TemplateSyntaxError as e: | ||||||
|                 self.assertIn('ImportError', e.args[0]) |                 self.assertIn('ImportError', e.args[0]) | ||||||
|                 self.assertIn('Xtemplate', e.args[0]) |                 self.assertIn('Xtemplate', e.args[0]) | ||||||
| @@ -335,4 +343,4 @@ class TemplateTagLoadingTests(SimpleTestCase): | |||||||
|         egg_name = '%s/tagsegg.egg' % self.egg_dir |         egg_name = '%s/tagsegg.egg' % self.egg_dir | ||||||
|         with extend_sys_path(egg_name): |         with extend_sys_path(egg_name): | ||||||
|             with self.settings(INSTALLED_APPS=['tagsegg']): |             with self.settings(INSTALLED_APPS=['tagsegg']): | ||||||
|                 Template(ttext) |                 self.engine.from_string(ttext) | ||||||
|   | |||||||
| @@ -2,7 +2,7 @@ from __future__ import unicode_literals | |||||||
|  |  | ||||||
| import logging | import logging | ||||||
|  |  | ||||||
| from django.template import Template, Variable, VariableDoesNotExist | from django.template import Engine, Variable, VariableDoesNotExist | ||||||
| from django.test import SimpleTestCase | from django.test import SimpleTestCase | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -38,7 +38,7 @@ class VariableResolveLoggingTests(SimpleTestCase): | |||||||
|  |  | ||||||
|             @property |             @property | ||||||
|             def template(self): |             def template(self): | ||||||
|                 return Template('') |                 return Engine().from_string('') | ||||||
|  |  | ||||||
|             @property |             @property | ||||||
|             def article(self): |             def article(self): | ||||||
|   | |||||||
| @@ -1,29 +1,33 @@ | |||||||
| from unittest import TestCase | from unittest import TestCase | ||||||
|  |  | ||||||
| from django.template import Context, Template | from django.template import Context, Engine | ||||||
| from django.template.base import VariableNode | from django.template.base import VariableNode | ||||||
| from django.test import override_settings |  | ||||||
|  |  | ||||||
|  |  | ||||||
| class NodelistTest(TestCase): | class NodelistTest(TestCase): | ||||||
|  |  | ||||||
|  |     @classmethod | ||||||
|  |     def setUpClass(cls): | ||||||
|  |         cls.engine = Engine() | ||||||
|  |         super(NodelistTest, cls).setUpClass() | ||||||
|  |  | ||||||
|     def test_for(self): |     def test_for(self): | ||||||
|         template = Template('{% for i in 1 %}{{ a }}{% endfor %}') |         template = self.engine.from_string('{% for i in 1 %}{{ a }}{% endfor %}') | ||||||
|         vars = template.nodelist.get_nodes_by_type(VariableNode) |         vars = template.nodelist.get_nodes_by_type(VariableNode) | ||||||
|         self.assertEqual(len(vars), 1) |         self.assertEqual(len(vars), 1) | ||||||
|  |  | ||||||
|     def test_if(self): |     def test_if(self): | ||||||
|         template = Template('{% if x %}{{ a }}{% endif %}') |         template = self.engine.from_string('{% if x %}{{ a }}{% endif %}') | ||||||
|         vars = template.nodelist.get_nodes_by_type(VariableNode) |         vars = template.nodelist.get_nodes_by_type(VariableNode) | ||||||
|         self.assertEqual(len(vars), 1) |         self.assertEqual(len(vars), 1) | ||||||
|  |  | ||||||
|     def test_ifequal(self): |     def test_ifequal(self): | ||||||
|         template = Template('{% ifequal x y %}{{ a }}{% endifequal %}') |         template = self.engine.from_string('{% ifequal x y %}{{ a }}{% endifequal %}') | ||||||
|         vars = template.nodelist.get_nodes_by_type(VariableNode) |         vars = template.nodelist.get_nodes_by_type(VariableNode) | ||||||
|         self.assertEqual(len(vars), 1) |         self.assertEqual(len(vars), 1) | ||||||
|  |  | ||||||
|     def test_ifchanged(self): |     def test_ifchanged(self): | ||||||
|         template = Template('{% ifchanged x %}{{ a }}{% endifchanged %}') |         template = self.engine.from_string('{% ifchanged x %}{{ a }}{% endifchanged %}') | ||||||
|         vars = template.nodelist.get_nodes_by_type(VariableNode) |         vars = template.nodelist.get_nodes_by_type(VariableNode) | ||||||
|         self.assertEqual(len(vars), 1) |         self.assertEqual(len(vars), 1) | ||||||
|  |  | ||||||
| @@ -33,7 +37,6 @@ class ErrorIndexTest(TestCase): | |||||||
|     Checks whether index of error is calculated correctly in |     Checks whether index of error is calculated correctly in | ||||||
|     template debugger in for loops. Refs ticket #5831 |     template debugger in for loops. Refs ticket #5831 | ||||||
|     """ |     """ | ||||||
|     @override_settings(DEBUG=True) |  | ||||||
|     def test_correct_exception_index(self): |     def test_correct_exception_index(self): | ||||||
|         tests = [ |         tests = [ | ||||||
|             ('{% load bad_tag %}{% for i in range %}{% badsimpletag %}{% endfor %}', (38, 56)), |             ('{% load bad_tag %}{% for i in range %}{% badsimpletag %}{% endfor %}', (38, 56)), | ||||||
| @@ -46,8 +49,9 @@ class ErrorIndexTest(TestCase): | |||||||
|             'range': range(5), |             'range': range(5), | ||||||
|             'five': 5, |             'five': 5, | ||||||
|         }) |         }) | ||||||
|  |         engine = Engine(debug=True) | ||||||
|         for source, expected_error_source_index in tests: |         for source, expected_error_source_index in tests: | ||||||
|             template = Template(source) |             template = engine.from_string(source) | ||||||
|             try: |             try: | ||||||
|                 template.render(context) |                 template.render(context) | ||||||
|             except (RuntimeError, TypeError) as e: |             except (RuntimeError, TypeError) as e: | ||||||
|   | |||||||
| @@ -3,7 +3,7 @@ from __future__ import unicode_literals | |||||||
|  |  | ||||||
| from unittest import TestCase | from unittest import TestCase | ||||||
|  |  | ||||||
| from django.template import Context, Template | from django.template import Context, Engine | ||||||
| from django.template.base import TemplateEncodingError | from django.template.base import TemplateEncodingError | ||||||
| from django.utils import six | from django.utils import six | ||||||
| from django.utils.safestring import SafeData | from django.utils.safestring import SafeData | ||||||
| @@ -12,13 +12,14 @@ from django.utils.safestring import SafeData | |||||||
| class UnicodeTests(TestCase): | class UnicodeTests(TestCase): | ||||||
|     def test_template(self): |     def test_template(self): | ||||||
|         # Templates can be created from unicode strings. |         # Templates can be created from unicode strings. | ||||||
|         t1 = Template('ŠĐĆŽćžšđ {{ var }}') |         engine = Engine() | ||||||
|  |         t1 = engine.from_string('ŠĐĆŽćžšđ {{ var }}') | ||||||
|         # Templates can also be created from bytestrings. These are assumed to |         # Templates can also be created from bytestrings. These are assumed to | ||||||
|         # be encoded using UTF-8. |         # be encoded using UTF-8. | ||||||
|         s = b'\xc5\xa0\xc4\x90\xc4\x86\xc5\xbd\xc4\x87\xc5\xbe\xc5\xa1\xc4\x91 {{ var }}' |         s = b'\xc5\xa0\xc4\x90\xc4\x86\xc5\xbd\xc4\x87\xc5\xbe\xc5\xa1\xc4\x91 {{ var }}' | ||||||
|         t2 = Template(s) |         t2 = engine.from_string(s) | ||||||
|         s = b'\x80\xc5\xc0' |         with self.assertRaises(TemplateEncodingError): | ||||||
|         self.assertRaises(TemplateEncodingError, Template, s) |             engine.from_string(b'\x80\xc5\xc0') | ||||||
|  |  | ||||||
|         # Contexts can be constructed from unicode or UTF-8 bytestrings. |         # Contexts can be constructed from unicode or UTF-8 bytestrings. | ||||||
|         Context({b"var": b"foo"}) |         Context({b"var": b"foo"}) | ||||||
|   | |||||||
| @@ -5,37 +5,33 @@ import sys | |||||||
|  |  | ||||||
| from django.contrib.auth.models import Group | from django.contrib.auth.models import Group | ||||||
| from django.core import urlresolvers | from django.core import urlresolvers | ||||||
| from django.template import ( | from django.template import Context, Engine, TemplateSyntaxError | ||||||
|     Context, Engine, Template, TemplateSyntaxError, engines, loader, |  | ||||||
| ) |  | ||||||
| from django.test import SimpleTestCase, override_settings | from django.test import SimpleTestCase, override_settings | ||||||
|  |  | ||||||
|  |  | ||||||
| class TemplateTests(SimpleTestCase): | class TemplateTests(SimpleTestCase): | ||||||
|  |  | ||||||
|     @override_settings(DEBUG=True) |  | ||||||
|     def test_string_origin(self): |     def test_string_origin(self): | ||||||
|         template = Template('string template') |         template = Engine().from_string('string template') | ||||||
|         self.assertEqual(template.origin.source, 'string template') |         self.assertEqual(template.origin.source, 'string template') | ||||||
|  |  | ||||||
|     @override_settings(SETTINGS_MODULE=None, DEBUG=True) |     @override_settings(SETTINGS_MODULE=None) | ||||||
|     def test_url_reverse_no_settings_module(self): |     def test_url_reverse_no_settings_module(self): | ||||||
|         # Regression test for #9005 |         """ | ||||||
|         t = Template('{% url will_not_match %}') |         #9005 -- url tag shouldn't require settings.SETTINGS_MODULE to | ||||||
|  |         be set. | ||||||
|  |         """ | ||||||
|  |         t = Engine(debug=True).from_string('{% url will_not_match %}') | ||||||
|         c = Context() |         c = Context() | ||||||
|         with self.assertRaises(urlresolvers.NoReverseMatch): |         with self.assertRaises(urlresolvers.NoReverseMatch): | ||||||
|             t.render(c) |             t.render(c) | ||||||
|  |  | ||||||
|     @override_settings( |  | ||||||
|         TEMPLATES=[{ |  | ||||||
|             'BACKEND': 'django.template.backends.django.DjangoTemplates', |  | ||||||
|             'OPTIONS': {'string_if_invalid': '%s is invalid'}, |  | ||||||
|         }], |  | ||||||
|         SETTINGS_MODULE='also_something', |  | ||||||
|     ) |  | ||||||
|     def test_url_reverse_view_name(self): |     def test_url_reverse_view_name(self): | ||||||
|         # Regression test for #19827 |         """ | ||||||
|         t = Template('{% url will_not_match %}') |         #19827 -- url tag should keep original strack trace when reraising | ||||||
|  |         exception. | ||||||
|  |         """ | ||||||
|  |         t = Engine().from_string('{% url will_not_match %}') | ||||||
|         c = Context() |         c = Context() | ||||||
|         try: |         try: | ||||||
|             t.render(c) |             t.render(c) | ||||||
| @@ -107,9 +103,10 @@ class TemplateTests(SimpleTestCase): | |||||||
|         """ |         """ | ||||||
|         #18169 -- NoReverseMatch should not be silence in block.super. |         #18169 -- NoReverseMatch should not be silence in block.super. | ||||||
|         """ |         """ | ||||||
|         t = loader.get_template('included_content.html') |         engine = Engine(app_dirs=True) | ||||||
|  |         t = engine.get_template('included_content.html') | ||||||
|         with self.assertRaises(urlresolvers.NoReverseMatch): |         with self.assertRaises(urlresolvers.NoReverseMatch): | ||||||
|             t.render() |             t.render(Context()) | ||||||
|  |  | ||||||
|     def test_debug_tag_non_ascii(self): |     def test_debug_tag_non_ascii(self): | ||||||
|         """ |         """ | ||||||
| @@ -117,7 +114,7 @@ class TemplateTests(SimpleTestCase): | |||||||
|         """ |         """ | ||||||
|         Group.objects.create(name="清風") |         Group.objects.create(name="清風") | ||||||
|         c1 = Context({"objs": Group.objects.all()}) |         c1 = Context({"objs": Group.objects.all()}) | ||||||
|         t1 = Template('{% debug %}') |         t1 = Engine().from_string('{% debug %}') | ||||||
|         self.assertIn("清風", t1.render(c1)) |         self.assertIn("清風", t1.render(c1)) | ||||||
|  |  | ||||||
|     def test_extends_generic_template(self): |     def test_extends_generic_template(self): | ||||||
| @@ -125,8 +122,8 @@ class TemplateTests(SimpleTestCase): | |||||||
|         #24338 -- Allow extending django.template.backends.django.Template |         #24338 -- Allow extending django.template.backends.django.Template | ||||||
|         objects. |         objects. | ||||||
|         """ |         """ | ||||||
|         parent = engines['django'].from_string( |         engine = Engine() | ||||||
|             '{% block content %}parent{% endblock %}') |         parent = engine.from_string('{% block content %}parent{% endblock %}') | ||||||
|         child = engines['django'].from_string( |         child = engine.from_string( | ||||||
|             '{% extends parent %}{% block content %}child{% endblock %}') |             '{% extends parent %}{% block content %}child{% endblock %}') | ||||||
|         self.assertEqual(child.render({'parent': parent}), 'child') |         self.assertEqual(child.render(Context({'parent': parent})), 'child') | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user