Fixed #24538 -- Allowed self in Jinja context

Rendering a Jinja template with self in the context threw an error.
While self is a reserved variable in Jinja, including self in the
context is not an error, so Django should respect that.
This commit is contained in:
Tim Heap 2015-03-31 15:37:17 +11:00 committed by Tim Graham
parent 48ddc66219
commit 4ea1909d3c
2 changed files with 19 additions and 1 deletions

View File

@ -60,4 +60,4 @@ class Template(object):
context['request'] = request context['request'] = request
context['csrf_input'] = csrf_input_lazy(request) context['csrf_input'] = csrf_input_lazy(request)
context['csrf_token'] = csrf_token_lazy(request) context['csrf_token'] = csrf_token_lazy(request)
return self.template.render(**context) return self.template.render(context)

View File

@ -21,3 +21,21 @@ class Jinja2Tests(TemplateStringsTests):
engine_class = Jinja2 engine_class = Jinja2
backend_name = 'jinja2' backend_name = 'jinja2'
options = {'keep_trailing_newline': True} options = {'keep_trailing_newline': True}
def test_self_context(self):
"""
#24538 -- Using 'self' in the context should not throw errors
"""
engine = Jinja2({
'DIRS': [],
'APP_DIRS': False,
'NAME': 'django',
'OPTIONS': {},
})
# self will be overridden to be a TemplateReference, so the self
# variable will not come through. Attempting to use one though should
# not throw an error.
template = engine.from_string('hello {{ foo }}!')
content = template.render(context={'self': 'self', 'foo': 'world'})
self.assertEqual(content, 'hello world!')