Here is a test case:
{{{
diff --git a/tests/auth_tests/test_forms.py
b/tests/auth_tests/test_forms.py
index 6172c44..1d4cd48 100644
--- a/tests/auth_tests/test_forms.py
+++ b/tests/auth_tests/test_forms.py
@@ -20,7 +20,7 @@ from django.utils.encoding import force_text
from django.utils.text import capfirst
from django.utils.translation import ugettext as _
-from .models.custom_user import ExtensionUser
+from .models.custom_user import CustomUser, ExtensionUser
from .settings import AUTH_TEMPLATES
@@ -139,6 +139,22 @@ class UserCreationFormTest(TestDataMixin, TestCase):
form = CustomUserCreationForm(data)
self.assertTrue(form.is_valid())
+
@override_settings(AUTH_MODEL='auth_tests.models.custom_user.CustomUser')
+ def test_custom_form_with_different_username_field(self):
+ class CustomUserCreationForm(UserCreationForm):
+ class Meta(UserCreationForm.Meta):
+ model = CustomUser
+ fields = ('email', 'date_of_birth')
+
+ data = {
+ 'email': 'te...@client222.com',
+ 'password1': 'testclient',
+ 'password2': 'testclient',
+ 'date_of_birth': '1988-02-24',
+ }
+ form = CustomUserCreationForm(data)
+ self.assertTrue(form.is_valid())
+
def test_password_whitespace_not_stripped(self):
data = {
'username': 'testuser',
}}}
And here is the traceback:
{{{
Traceback (most recent call last):
File "/home/berker/projects/django/django/test/utils.py", line 208, in
inner
return func(*args, **kwargs)
File "/home/berker/projects/django/tests/auth_tests/test_forms.py", line
155, in test_custom_form_with_different_username_field
form = CustomUserCreationForm(data)
File "/home/berker/projects/django/django/contrib/auth/forms.py", line
85, in __init__
self.fields['username'].widget.attrs.update({'autofocus': ''})
KeyError: u'username'
}}}
I will open a oull request to fix this shortly.
--
Ticket URL: <https://code.djangoproject.com/ticket/26381>
Django <https://code.djangoproject.com/>
The Web framework for perfectionists with deadlines.
* cc: berker.peksag@… (added)
* needs_docs: => 0
* needs_tests: => 0
* needs_better_patch: => 0
--
Ticket URL: <https://code.djangoproject.com/ticket/26381#comment:1>
* has_patch: 0 => 1
Comment:
Pull request: https://github.com/django/django/pull/6315
--
Ticket URL: <https://code.djangoproject.com/ticket/26381#comment:2>
* owner: nobody => berkerpeksag
* status: new => assigned
Old description:
New description:
I will open a pull request to fix this shortly.
--
--
Ticket URL: <https://code.djangoproject.com/ticket/26381#comment:3>
* version: 1.9 => master
* stage: Unreviewed => Accepted
Comment:
The line that needs to be fixed is new in Django 1.10, so this doesn't
affect 1.9.
--
Ticket URL: <https://code.djangoproject.com/ticket/26381#comment:4>
* status: assigned => closed
* resolution: => fixed
Comment:
In [changeset:"efa9539787dbdd06cd2169023edcf7db3e2ff0c4" efa9539]:
{{{
#!CommitTicketReference repository=""
revision="efa9539787dbdd06cd2169023edcf7db3e2ff0c4"
Fixed #26381 -- Made UserCreationForm reusable with custom user models
that define USERNAME_FIELD.
}}}
--
Ticket URL: <https://code.djangoproject.com/ticket/26381#comment:5>