mirror of
				https://github.com/django/django.git
				synced 2025-10-25 22:56:12 +00:00 
			
		
		
		
	Fixed #27111 -- Fixed KeyError if USERNAME_FIELD isn't in UserCreationForm.fields.
This commit is contained in:
		
				
					committed by
					
						 Tim Graham
						Tim Graham
					
				
			
			
				
	
			
			
			
						parent
						
							9aaeec337e
						
					
				
				
					commit
					3c18f8a3d2
				
			| @@ -94,7 +94,8 @@ class UserCreationForm(forms.ModelForm): | |||||||
|  |  | ||||||
|     def __init__(self, *args, **kwargs): |     def __init__(self, *args, **kwargs): | ||||||
|         super(UserCreationForm, self).__init__(*args, **kwargs) |         super(UserCreationForm, self).__init__(*args, **kwargs) | ||||||
|         self.fields[self._meta.model.USERNAME_FIELD].widget.attrs.update({'autofocus': ''}) |         if self._meta.model.USERNAME_FIELD in self.fields: | ||||||
|  |             self.fields[self._meta.model.USERNAME_FIELD].widget.attrs.update({'autofocus': ''}) | ||||||
|  |  | ||||||
|     def clean_password2(self): |     def clean_password2(self): | ||||||
|         password1 = self.cleaned_data.get("password1") |         password1 = self.cleaned_data.get("password1") | ||||||
|   | |||||||
| @@ -76,3 +76,6 @@ Bugfixes | |||||||
| * Included the already applied migration state changes in the ``Apps`` instance | * Included the already applied migration state changes in the ``Apps`` instance | ||||||
|   provided to the ``pre_migrate`` signal receivers to allow ``ContentType`` |   provided to the ``pre_migrate`` signal receivers to allow ``ContentType`` | ||||||
|   renaming to be performed on model rename (:ticket:`27100`). |   renaming to be performed on model rename (:ticket:`27100`). | ||||||
|  |  | ||||||
|  | * Reallowed subclassing ``UserCreationForm`` without ``USERNAME_FIELD`` in | ||||||
|  |   ``Meta.fields`` (:ticket:`27111`). | ||||||
|   | |||||||
| @@ -22,7 +22,9 @@ from django.utils.encoding import force_text | |||||||
| from django.utils.text import capfirst | from django.utils.text import capfirst | ||||||
| from django.utils.translation import ugettext as _ | from django.utils.translation import ugettext as _ | ||||||
|  |  | ||||||
| from .models.custom_user import CustomUser, ExtensionUser | from .models.custom_user import ( | ||||||
|  |     CustomUser, CustomUserWithoutIsActiveField, ExtensionUser, | ||||||
|  | ) | ||||||
| from .models.with_integer_username import IntegerUsernameUser | from .models.with_integer_username import IntegerUsernameUser | ||||||
| from .settings import AUTH_TEMPLATES | from .settings import AUTH_TEMPLATES | ||||||
|  |  | ||||||
| @@ -209,6 +211,20 @@ class UserCreationFormTest(TestDataMixin, TestCase): | |||||||
|         form = CustomUserCreationForm(data) |         form = CustomUserCreationForm(data) | ||||||
|         self.assertTrue(form.is_valid()) |         self.assertTrue(form.is_valid()) | ||||||
|  |  | ||||||
|  |     def test_custom_form_hidden_username_field(self): | ||||||
|  |         class CustomUserCreationForm(UserCreationForm): | ||||||
|  |             class Meta(UserCreationForm.Meta): | ||||||
|  |                 model = CustomUserWithoutIsActiveField | ||||||
|  |                 fields = ('email',)  # without USERNAME_FIELD | ||||||
|  |  | ||||||
|  |         data = { | ||||||
|  |             'email': 'testclient@example.com', | ||||||
|  |             'password1': 'testclient', | ||||||
|  |             'password2': 'testclient', | ||||||
|  |         } | ||||||
|  |         form = CustomUserCreationForm(data) | ||||||
|  |         self.assertTrue(form.is_valid()) | ||||||
|  |  | ||||||
|     def test_password_whitespace_not_stripped(self): |     def test_password_whitespace_not_stripped(self): | ||||||
|         data = { |         data = { | ||||||
|             'username': 'testuser', |             'username': 'testuser', | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user