mirror of
				https://github.com/django/django.git
				synced 2025-10-26 15:16:09 +00:00 
			
		
		
		
	Fixed #32765 -- Removed "for" HTML attribute from ReadOnlyPasswordHashWidget.
ReadOnlyPasswordHashWidget doesn't have any labelable elements.
This commit is contained in:
		
				
					committed by
					
						 Mariusz Felisiak
						Mariusz Felisiak
					
				
			
			
				
	
			
			
			
						parent
						
							fa4e963ee7
						
					
				
				
					commit
					536c155e67
				
			| @@ -50,6 +50,9 @@ class ReadOnlyPasswordHashWidget(forms.Widget): | |||||||
|         context['summary'] = summary |         context['summary'] = summary | ||||||
|         return context |         return context | ||||||
|  |  | ||||||
|  |     def id_for_label(self, id_): | ||||||
|  |         return None | ||||||
|  |  | ||||||
|  |  | ||||||
| class ReadOnlyPasswordHashField(forms.Field): | class ReadOnlyPasswordHashField(forms.Field): | ||||||
|     widget = ReadOnlyPasswordHashWidget |     widget = ReadOnlyPasswordHashWidget | ||||||
|   | |||||||
| @@ -13,6 +13,7 @@ from django.contrib.sites.models import Site | |||||||
| from django.core import mail | from django.core import mail | ||||||
| from django.core.exceptions import ValidationError | from django.core.exceptions import ValidationError | ||||||
| from django.core.mail import EmailMultiAlternatives | from django.core.mail import EmailMultiAlternatives | ||||||
|  | from django.forms import forms | ||||||
| from django.forms.fields import CharField, Field, IntegerField | from django.forms.fields import CharField, Field, IntegerField | ||||||
| from django.test import SimpleTestCase, TestCase, override_settings | from django.test import SimpleTestCase, TestCase, override_settings | ||||||
| from django.utils import translation | from django.utils import translation | ||||||
| @@ -1025,6 +1026,18 @@ class ReadOnlyPasswordHashTest(SimpleTestCase): | |||||||
|         self.assertIs(field.disabled, True) |         self.assertIs(field.disabled, True) | ||||||
|         self.assertFalse(field.has_changed('aaa', 'bbb')) |         self.assertFalse(field.has_changed('aaa', 'bbb')) | ||||||
|  |  | ||||||
|  |     def test_label(self): | ||||||
|  |         """ | ||||||
|  |         ReadOnlyPasswordHashWidget doesn't contain a for attribute in the | ||||||
|  |         <label> because it doesn't have any labelable elements. | ||||||
|  |         """ | ||||||
|  |         class TestForm(forms.Form): | ||||||
|  |             hash_field = ReadOnlyPasswordHashField() | ||||||
|  |  | ||||||
|  |         bound_field = TestForm()['hash_field'] | ||||||
|  |         self.assertEqual(bound_field.field.widget.id_for_label('id'), None) | ||||||
|  |         self.assertEqual(bound_field.label_tag(), '<label>Hash field:</label>') | ||||||
|  |  | ||||||
|  |  | ||||||
| class AdminPasswordChangeFormTest(TestDataMixin, TestCase): | class AdminPasswordChangeFormTest(TestDataMixin, TestCase): | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user