mirror of
				https://github.com/django/django.git
				synced 2025-10-25 06:36:07 +00:00 
			
		
		
		
	Fixed #3465: template variable lookups like {{ foobar.13 }} now (correctly) fail silently on unsubscriptable objects. Thanks, Gary Wilson.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@4639 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
		| @@ -667,7 +667,11 @@ def resolve_variable(path, context): | |||||||
|                 except (TypeError, AttributeError): |                 except (TypeError, AttributeError): | ||||||
|                     try: # list-index lookup |                     try: # list-index lookup | ||||||
|                         current = current[int(bits[0])] |                         current = current[int(bits[0])] | ||||||
|                     except (IndexError, ValueError, KeyError): |                     except (IndexError, # list index out of range | ||||||
|  |                             ValueError, # invalid literal for int() | ||||||
|  |                             KeyError,   # current is a dict without `int(bits[0])` key | ||||||
|  |                             TypeError,  # unsubscriptable object | ||||||
|  |                             ): | ||||||
|                         raise VariableDoesNotExist("Failed lookup for key [%s] in %r", (bits[0], current)) # missing attribute |                         raise VariableDoesNotExist("Failed lookup for key [%s] in %r", (bits[0], current)) # missing attribute | ||||||
|                 except Exception, e: |                 except Exception, e: | ||||||
|                     if getattr(e, 'silent_variable_failure', False): |                     if getattr(e, 'silent_variable_failure', False): | ||||||
|   | |||||||
| @@ -127,6 +127,29 @@ class Templates(unittest.TestCase): | |||||||
|             # Fail silently when accessing a non-simple method |             # Fail silently when accessing a non-simple method | ||||||
|             'basic-syntax20': ("{{ var.method2 }}", {"var": SomeClass()}, ("","INVALID")), |             'basic-syntax20': ("{{ var.method2 }}", {"var": SomeClass()}, ("","INVALID")), | ||||||
|  |  | ||||||
|  |             # List-index syntax allows a template to access a certain item of a subscriptable object. | ||||||
|  |             'list-index01': ("{{ var.1 }}", {"var": ["first item", "second item"]}, "second item"), | ||||||
|  |  | ||||||
|  |             # Fail silently when the list index is out of range. | ||||||
|  |             'list-index02': ("{{ var.5 }}", {"var": ["first item", "second item"]}, ("", "INVALID")), | ||||||
|  |  | ||||||
|  |             # Fail silently when the variable is not a subscriptable object. | ||||||
|  |             'list-index03': ("{{ var.1 }}", {"var": None}, ("", "INVALID")), | ||||||
|  |  | ||||||
|  |             # Fail silently when variable is a dict without the specified key. | ||||||
|  |             'list-index04': ("{{ var.1 }}", {"var": {}}, ("", "INVALID")), | ||||||
|  |  | ||||||
|  |             # Dictionary lookup wins out when dict's key is a string. | ||||||
|  |             'list-index05': ("{{ var.1 }}", {"var": {'1': "hello"}}, "hello"), | ||||||
|  |  | ||||||
|  |             # But list-index lookup wins out when dict's key is an int, which | ||||||
|  |             # behind the scenes is really a dictionary lookup (for a dict) | ||||||
|  |             # after converting the key to an int. | ||||||
|  |             'list-index06': ("{{ var.1 }}", {"var": {1: "hello"}}, "hello"), | ||||||
|  |  | ||||||
|  |             # Dictionary lookup wins out when there is a string and int version of the key. | ||||||
|  |             'list-index07': ("{{ var.1 }}", {"var": {'1': "hello", 1: "world"}}, "hello"), | ||||||
|  |              | ||||||
|             # Basic filter usage |             # Basic filter usage | ||||||
|             'basic-syntax21': ("{{ var|upper }}", {"var": "Django is the greatest!"}, "DJANGO IS THE GREATEST!"), |             'basic-syntax21': ("{{ var|upper }}", {"var": "Django is the greatest!"}, "DJANGO IS THE GREATEST!"), | ||||||
|  |  | ||||||
| @@ -167,7 +190,7 @@ class Templates(unittest.TestCase): | |||||||
|             'basic-syntax33': (r'1{{ var.method3 }}2', {"var": SomeClass()}, ("12", "1INVALID2")), |             'basic-syntax33': (r'1{{ var.method3 }}2', {"var": SomeClass()}, ("12", "1INVALID2")), | ||||||
|  |  | ||||||
|             # In methods that raise an exception without a "silent_variable_attribute" set to True, |             # In methods that raise an exception without a "silent_variable_attribute" set to True, | ||||||
|             # the exception propogates |             # the exception propagates | ||||||
|             'basic-syntax34': (r'1{{ var.method4 }}2', {"var": SomeClass()}, SomeOtherException), |             'basic-syntax34': (r'1{{ var.method4 }}2', {"var": SomeClass()}, SomeOtherException), | ||||||
|  |  | ||||||
|             # Escaped backslash in argument |             # Escaped backslash in argument | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user