mirror of
				https://github.com/django/django.git
				synced 2025-10-30 00:56:09 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			166 lines
		
	
	
		
			6.0 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			166 lines
		
	
	
		
			6.0 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| from template_tests.test_response import test_processor_name
 | |
| 
 | |
| from django.template import Context, EngineHandler, RequestContext
 | |
| from django.template.backends.django import DjangoTemplates
 | |
| from django.template.library import InvalidTemplateLibrary
 | |
| from django.test import RequestFactory, override_settings
 | |
| 
 | |
| from .test_dummy import TemplateStringsTests
 | |
| 
 | |
| 
 | |
| class DjangoTemplatesTests(TemplateStringsTests):
 | |
| 
 | |
|     engine_class = DjangoTemplates
 | |
|     backend_name = 'django'
 | |
| 
 | |
|     def test_context_has_priority_over_template_context_processors(self):
 | |
|         # See ticket #23789.
 | |
|         engine = DjangoTemplates({
 | |
|             'DIRS': [],
 | |
|             'APP_DIRS': False,
 | |
|             'NAME': 'django',
 | |
|             'OPTIONS': {
 | |
|                 'context_processors': [test_processor_name],
 | |
|             },
 | |
|         })
 | |
| 
 | |
|         template = engine.from_string('{{ processors }}')
 | |
|         request = RequestFactory().get('/')
 | |
| 
 | |
|         # Context processors run
 | |
|         content = template.render({}, request)
 | |
|         self.assertEqual(content, 'yes')
 | |
| 
 | |
|         # Context overrides context processors
 | |
|         content = template.render({'processors': 'no'}, request)
 | |
|         self.assertEqual(content, 'no')
 | |
| 
 | |
|     def test_render_requires_dict(self):
 | |
|         """django.Template.render() requires a dict."""
 | |
|         engine = DjangoTemplates({
 | |
|             'DIRS': [],
 | |
|             'APP_DIRS': False,
 | |
|             'NAME': 'django',
 | |
|             'OPTIONS': {},
 | |
|         })
 | |
|         template = engine.from_string('')
 | |
|         context = Context()
 | |
|         request_context = RequestContext(RequestFactory().get('/'), {})
 | |
|         msg = 'context must be a dict rather than Context.'
 | |
|         with self.assertRaisesMessage(TypeError, msg):
 | |
|             template.render(context)
 | |
|         msg = 'context must be a dict rather than RequestContext.'
 | |
|         with self.assertRaisesMessage(TypeError, msg):
 | |
|             template.render(request_context)
 | |
| 
 | |
|     @override_settings(INSTALLED_APPS=['template_backends.apps.good'])
 | |
|     def test_templatetag_discovery(self):
 | |
|         engine = DjangoTemplates({
 | |
|             'DIRS': [],
 | |
|             'APP_DIRS': False,
 | |
|             'NAME': 'django',
 | |
|             'OPTIONS': {
 | |
|                 'libraries': {
 | |
|                     'alternate': 'template_backends.apps.good.templatetags.good_tags',
 | |
|                     'override': 'template_backends.apps.good.templatetags.good_tags',
 | |
|                 },
 | |
|             },
 | |
|         })
 | |
| 
 | |
|         # libraries are discovered from installed applications
 | |
|         self.assertEqual(
 | |
|             engine.engine.libraries['good_tags'],
 | |
|             'template_backends.apps.good.templatetags.good_tags',
 | |
|         )
 | |
|         self.assertEqual(
 | |
|             engine.engine.libraries['subpackage.tags'],
 | |
|             'template_backends.apps.good.templatetags.subpackage.tags',
 | |
|         )
 | |
|         # libraries are discovered from django.templatetags
 | |
|         self.assertEqual(
 | |
|             engine.engine.libraries['static'],
 | |
|             'django.templatetags.static',
 | |
|         )
 | |
|         # libraries passed in OPTIONS are registered
 | |
|         self.assertEqual(
 | |
|             engine.engine.libraries['alternate'],
 | |
|             'template_backends.apps.good.templatetags.good_tags',
 | |
|         )
 | |
|         # libraries passed in OPTIONS take precedence over discovered ones
 | |
|         self.assertEqual(
 | |
|             engine.engine.libraries['override'],
 | |
|             'template_backends.apps.good.templatetags.good_tags',
 | |
|         )
 | |
| 
 | |
|     @override_settings(INSTALLED_APPS=['template_backends.apps.importerror'])
 | |
|     def test_templatetag_discovery_import_error(self):
 | |
|         """
 | |
|         Import errors in tag modules should be reraised with a helpful message.
 | |
|         """
 | |
|         with self.assertRaisesMessage(
 | |
|             InvalidTemplateLibrary,
 | |
|             "ImportError raised when trying to load "
 | |
|             "'template_backends.apps.importerror.templatetags.broken_tags'"
 | |
|         ):
 | |
|             DjangoTemplates({
 | |
|                 'DIRS': [],
 | |
|                 'APP_DIRS': False,
 | |
|                 'NAME': 'django',
 | |
|                 'OPTIONS': {},
 | |
|             })
 | |
| 
 | |
|     def test_builtins_discovery(self):
 | |
|         engine = DjangoTemplates({
 | |
|             'DIRS': [],
 | |
|             'APP_DIRS': False,
 | |
|             'NAME': 'django',
 | |
|             'OPTIONS': {
 | |
|                 'builtins': ['template_backends.apps.good.templatetags.good_tags'],
 | |
|             },
 | |
|         })
 | |
| 
 | |
|         self.assertEqual(
 | |
|             engine.engine.builtins, [
 | |
|                 'django.template.defaulttags',
 | |
|                 'django.template.defaultfilters',
 | |
|                 'django.template.loader_tags',
 | |
|                 'template_backends.apps.good.templatetags.good_tags',
 | |
|             ]
 | |
|         )
 | |
| 
 | |
|     def test_autoescape_off(self):
 | |
|         templates = [{
 | |
|             'BACKEND': 'django.template.backends.django.DjangoTemplates',
 | |
|             'OPTIONS': {'autoescape': False},
 | |
|         }]
 | |
|         engines = EngineHandler(templates=templates)
 | |
|         self.assertEqual(
 | |
|             engines['django'].from_string('Hello, {{ name }}').render({'name': 'Bob & Jim'}),
 | |
|             'Hello, Bob & Jim'
 | |
|         )
 | |
| 
 | |
|     def test_autoescape_default(self):
 | |
|         templates = [{
 | |
|             'BACKEND': 'django.template.backends.django.DjangoTemplates',
 | |
|         }]
 | |
|         engines = EngineHandler(templates=templates)
 | |
|         self.assertEqual(
 | |
|             engines['django'].from_string('Hello, {{ name }}').render({'name': 'Bob & Jim'}),
 | |
|             'Hello, Bob & Jim'
 | |
|         )
 | |
| 
 | |
|     default_loaders = [
 | |
|         'django.template.loaders.filesystem.Loader',
 | |
|         'django.template.loaders.app_directories.Loader',
 | |
|     ]
 | |
| 
 | |
|     @override_settings(DEBUG=False)
 | |
|     def test_non_debug_default_template_loaders(self):
 | |
|         engine = DjangoTemplates({'DIRS': [], 'APP_DIRS': True, 'NAME': 'django', 'OPTIONS': {}})
 | |
|         self.assertEqual(engine.engine.loaders, [('django.template.loaders.cached.Loader', self.default_loaders)])
 | |
| 
 | |
|     @override_settings(DEBUG=True)
 | |
|     def test_debug_default_template_loaders(self):
 | |
|         engine = DjangoTemplates({'DIRS': [], 'APP_DIRS': True, 'NAME': 'django', 'OPTIONS': {}})
 | |
|         self.assertEqual(engine.engine.loaders, self.default_loaders)
 |