mirror of
				https://github.com/django/django.git
				synced 2025-10-25 06:36:07 +00:00 
			
		
		
		
	Fixed #17888 -- no longer silence exceptions inside of check_test. Thanks to brutasse for the patch.
This commit is contained in:
		| @@ -507,11 +507,7 @@ class CheckboxInput(Widget): | |||||||
|  |  | ||||||
|     def render(self, name, value, attrs=None): |     def render(self, name, value, attrs=None): | ||||||
|         final_attrs = self.build_attrs(attrs, type='checkbox', name=name) |         final_attrs = self.build_attrs(attrs, type='checkbox', name=name) | ||||||
|         try: |         if self.check_test(value): | ||||||
|             result = self.check_test(value) |  | ||||||
|         except: # Silently catch exceptions |  | ||||||
|             result = False |  | ||||||
|         if result: |  | ||||||
|             final_attrs['checked'] = 'checked' |             final_attrs['checked'] = 'checked' | ||||||
|         if not (value is True or value is False or value is None or value == ''): |         if not (value is True or value is False or value is None or value == ''): | ||||||
|             # Only add the 'value' attribute if a value is non-empty. |             # Only add the 'value' attribute if a value is non-empty. | ||||||
| @@ -525,7 +521,7 @@ class CheckboxInput(Widget): | |||||||
|             return False |             return False | ||||||
|         value = data.get(name) |         value = data.get(name) | ||||||
|         # Translate true and false strings to boolean values. |         # Translate true and false strings to boolean values. | ||||||
|         values =  {'true': True, 'false': False} |         values = {'true': True, 'false': False} | ||||||
|         if isinstance(value, six.string_types): |         if isinstance(value, six.string_types): | ||||||
|             value = values.get(value.lower(), value) |             value = values.get(value.lower(), value) | ||||||
|         return value |         return value | ||||||
|   | |||||||
| @@ -310,6 +310,10 @@ commonly used groups of widgets: | |||||||
|         A callable that takes the value of the CheckBoxInput and returns |         A callable that takes the value of the CheckBoxInput and returns | ||||||
|         ``True`` if the checkbox should be checked for that value. |         ``True`` if the checkbox should be checked for that value. | ||||||
|  |  | ||||||
|  |         .. versionchanged:: 1.5 | ||||||
|  |             Exceptions from ``check_test`` used to be silenced by its caller, | ||||||
|  |             this is no longer the case, they will propagate upwards. | ||||||
|  |  | ||||||
| ``Select`` | ``Select`` | ||||||
| ~~~~~~~~~~ | ~~~~~~~~~~ | ||||||
|  |  | ||||||
|   | |||||||
| @@ -216,13 +216,9 @@ class FormsWidgetTestCase(TestCase): | |||||||
|         self.assertHTMLEqual(w.render('greeting', 'hello there'), '<input checked="checked" type="checkbox" name="greeting" value="hello there" />') |         self.assertHTMLEqual(w.render('greeting', 'hello there'), '<input checked="checked" type="checkbox" name="greeting" value="hello there" />') | ||||||
|         self.assertHTMLEqual(w.render('greeting', 'hello & goodbye'), '<input checked="checked" type="checkbox" name="greeting" value="hello & goodbye" />') |         self.assertHTMLEqual(w.render('greeting', 'hello & goodbye'), '<input checked="checked" type="checkbox" name="greeting" value="hello & goodbye" />') | ||||||
|  |  | ||||||
|         # A subtlety: If the 'check_test' argument cannot handle a value and raises any |         # Ticket #17888: calling check_test shouldn't swallow exceptions | ||||||
|         # exception during its __call__, then the exception will be swallowed and the box |         with self.assertRaises(AttributeError): | ||||||
|         # will not be checked. In this example, the 'check_test' assumes the value has a |             w.render('greeting', True) | ||||||
|         # startswith() method, which fails for the values True, False and None. |  | ||||||
|         self.assertHTMLEqual(w.render('greeting', True), '<input type="checkbox" name="greeting" />') |  | ||||||
|         self.assertHTMLEqual(w.render('greeting', False), '<input type="checkbox" name="greeting" />') |  | ||||||
|         self.assertHTMLEqual(w.render('greeting', None), '<input type="checkbox" name="greeting" />') |  | ||||||
|  |  | ||||||
|         # The CheckboxInput widget will return False if the key is not found in the data |         # The CheckboxInput widget will return False if the key is not found in the data | ||||||
|         # dictionary (because HTML form submission doesn't send any result for unchecked |         # dictionary (because HTML form submission doesn't send any result for unchecked | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user