mirror of
				https://github.com/django/django.git
				synced 2025-10-25 22:56:12 +00:00 
			
		
		
		
	Fixed #24765 -- Allowed template context updates to flatten a Context.
This commit is contained in:
		
				
					committed by
					
						 Tim Graham
						Tim Graham
					
				
			
			
				
	
			
			
			
						parent
						
							e7e8d30cae
						
					
				
				
					commit
					ec704371e3
				
			| @@ -52,7 +52,13 @@ class BaseContext(object): | ||||
|             yield d | ||||
|  | ||||
|     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): | ||||
|         if len(self.dicts) == 1: | ||||
| @@ -175,6 +181,8 @@ class Context(BaseContext): | ||||
|         "Pushes other_dict to the stack of dictionaries in the Context" | ||||
|         if not hasattr(other_dict, '__getitem__'): | ||||
|             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) | ||||
|  | ||||
|  | ||||
|   | ||||
| @@ -43,6 +43,46 @@ class ContextTests(SimpleTestCase): | ||||
|             self.assertEqual(c['a'], 3) | ||||
|         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): | ||||
|         c = Context() | ||||
|  | ||||
| @@ -96,6 +136,20 @@ class ContextTests(SimpleTestCase): | ||||
|             '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): | ||||
|         """ | ||||
|         #21765 -- equality comparison should work | ||||
|   | ||||
		Reference in New Issue
	
	Block a user