Kaydet (Commit) ec704371 authored tarafından Buddy Lindsey, Jr's avatar Buddy Lindsey, Jr Kaydeden (comit) Tim Graham

Fixed #24765 -- Allowed template context updates to flatten a Context.

üst e7e8d30c
...@@ -52,7 +52,13 @@ class BaseContext(object): ...@@ -52,7 +52,13 @@ class BaseContext(object):
yield d yield d
def push(self, *args, **kwargs): def push(self, *args, **kwargs):
return ContextDict(self, *args, **kwargs) dicts = []
for d in args:
if isinstance(d, BaseContext):
dicts += d.dicts[1:]
else:
dicts.append(d)
return ContextDict(self, *dicts, **kwargs)
def pop(self): def pop(self):
if len(self.dicts) == 1: if len(self.dicts) == 1:
...@@ -175,6 +181,8 @@ class Context(BaseContext): ...@@ -175,6 +181,8 @@ class Context(BaseContext):
"Pushes other_dict to the stack of dictionaries in the Context" "Pushes other_dict to the stack of dictionaries in the Context"
if not hasattr(other_dict, '__getitem__'): if not hasattr(other_dict, '__getitem__'):
raise TypeError('other_dict must be a mapping (dictionary-like) object.') raise TypeError('other_dict must be a mapping (dictionary-like) object.')
if isinstance(other_dict, BaseContext):
other_dict = other_dict.dicts[1:].pop()
return ContextDict(self, other_dict) return ContextDict(self, other_dict)
......
...@@ -43,6 +43,46 @@ class ContextTests(SimpleTestCase): ...@@ -43,6 +43,46 @@ class ContextTests(SimpleTestCase):
self.assertEqual(c['a'], 3) self.assertEqual(c['a'], 3)
self.assertEqual(c['a'], 1) self.assertEqual(c['a'], 1)
def test_push_context_manager_with_context_object(self):
c = Context({'a': 1})
with c.push(Context({'a': 3})):
self.assertEqual(c['a'], 3)
self.assertEqual(c['a'], 1)
def test_update_context_manager_with_context_object(self):
c = Context({'a': 1})
with c.update(Context({'a': 3})):
self.assertEqual(c['a'], 3)
self.assertEqual(c['a'], 1)
def test_push_proper_layering(self):
c = Context({'a': 1})
c.push(Context({'b': 2}))
c.push(Context({'c': 3, 'd': {'z': '26'}}))
self.assertEqual(
c.dicts,
[
{'False': False, 'None': None, 'True': True},
{'a': 1},
{'b': 2},
{'c': 3, 'd': {'z': '26'}},
]
)
def test_update_proper_layering(self):
c = Context({'a': 1})
c.update(Context({'b': 2}))
c.update(Context({'c': 3, 'd': {'z': '26'}}))
self.assertEqual(
c.dicts,
[
{'False': False, 'None': None, 'True': True},
{'a': 1},
{'b': 2},
{'c': 3, 'd': {'z': '26'}},
]
)
def test_setdefault(self): def test_setdefault(self):
c = Context() c = Context()
...@@ -96,6 +136,20 @@ class ContextTests(SimpleTestCase): ...@@ -96,6 +136,20 @@ class ContextTests(SimpleTestCase):
'a': 2, 'b': 4, 'c': 8 'a': 2, 'b': 4, 'c': 8
}) })
def test_flatten_context_with_context(self):
"""
Context.push() with a Context argument should work.
"""
a = Context({'a': 2})
a.push(Context({'z': '8'}))
self.assertEqual(a.flatten(), {
'False': False,
'None': None,
'True': True,
'a': 2,
'z': '8',
})
def test_context_comparable(self): def test_context_comparable(self):
""" """
#21765 -- equality comparison should work #21765 -- equality comparison should work
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment