Fixed #7833: the user creation form now works when password1 isn't set.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@8542 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
parent
e3df35478d
commit
15ed0d65b0
|
@ -30,7 +30,7 @@ class UserCreationForm(forms.ModelForm):
|
||||||
raise forms.ValidationError(_("A user with that username already exists."))
|
raise forms.ValidationError(_("A user with that username already exists."))
|
||||||
|
|
||||||
def clean_password2(self):
|
def clean_password2(self):
|
||||||
password1 = self.cleaned_data["password1"]
|
password1 = self.cleaned_data.get("password1", "")
|
||||||
password2 = self.cleaned_data["password2"]
|
password2 = self.cleaned_data["password2"]
|
||||||
if password1 != password2:
|
if password1 != password2:
|
||||||
raise forms.ValidationError(_("The two password fields didn't match."))
|
raise forms.ValidationError(_("The two password fields didn't match."))
|
||||||
|
|
|
@ -4,7 +4,7 @@ FORM_TESTS = """
|
||||||
>>> from django.contrib.auth.forms import UserCreationForm, AuthenticationForm
|
>>> from django.contrib.auth.forms import UserCreationForm, AuthenticationForm
|
||||||
>>> from django.contrib.auth.forms import PasswordChangeForm, SetPasswordForm
|
>>> from django.contrib.auth.forms import PasswordChangeForm, SetPasswordForm
|
||||||
|
|
||||||
The user already exists.
|
# The user already exists.
|
||||||
|
|
||||||
>>> user = User.objects.create_user("jsmith", "jsmith@example.com", "test123")
|
>>> user = User.objects.create_user("jsmith", "jsmith@example.com", "test123")
|
||||||
>>> data = {
|
>>> data = {
|
||||||
|
@ -18,7 +18,7 @@ False
|
||||||
>>> form["username"].errors
|
>>> form["username"].errors
|
||||||
[u'A user with that username already exists.']
|
[u'A user with that username already exists.']
|
||||||
|
|
||||||
The username contains invalid data.
|
# The username contains invalid data.
|
||||||
|
|
||||||
>>> data = {
|
>>> data = {
|
||||||
... 'username': 'jsmith@example.com',
|
... 'username': 'jsmith@example.com',
|
||||||
|
@ -31,7 +31,7 @@ False
|
||||||
>>> form["username"].errors
|
>>> form["username"].errors
|
||||||
[u'This value must contain only letters, numbers and underscores.']
|
[u'This value must contain only letters, numbers and underscores.']
|
||||||
|
|
||||||
The verification password is incorrect.
|
# The verification password is incorrect.
|
||||||
|
|
||||||
>>> data = {
|
>>> data = {
|
||||||
... 'username': 'jsmith2',
|
... 'username': 'jsmith2',
|
||||||
|
@ -44,7 +44,25 @@ False
|
||||||
>>> form["password2"].errors
|
>>> form["password2"].errors
|
||||||
[u"The two password fields didn't match."]
|
[u"The two password fields didn't match."]
|
||||||
|
|
||||||
The success case.
|
# One (or both) passwords weren't given
|
||||||
|
|
||||||
|
>>> data = {'username': 'jsmith2'}
|
||||||
|
>>> form = UserCreationForm(data)
|
||||||
|
>>> form.is_valid()
|
||||||
|
False
|
||||||
|
>>> form['password1'].errors
|
||||||
|
[u'This field is required.']
|
||||||
|
>>> form['password2'].errors
|
||||||
|
[u'This field is required.']
|
||||||
|
|
||||||
|
>>> data['password2'] = 'test123'
|
||||||
|
>>> form = UserCreationForm(data)
|
||||||
|
>>> form.is_valid()
|
||||||
|
False
|
||||||
|
>>> form['password1'].errors
|
||||||
|
[u'This field is required.']
|
||||||
|
|
||||||
|
# The success case.
|
||||||
|
|
||||||
>>> data = {
|
>>> data = {
|
||||||
... 'username': 'jsmith2',
|
... 'username': 'jsmith2',
|
||||||
|
@ -57,7 +75,7 @@ True
|
||||||
>>> form.save()
|
>>> form.save()
|
||||||
<User: jsmith2>
|
<User: jsmith2>
|
||||||
|
|
||||||
The user submits an invalid username.
|
# The user submits an invalid username.
|
||||||
|
|
||||||
>>> data = {
|
>>> data = {
|
||||||
... 'username': 'jsmith_does_not_exist',
|
... 'username': 'jsmith_does_not_exist',
|
||||||
|
@ -70,7 +88,7 @@ False
|
||||||
>>> form.non_field_errors()
|
>>> form.non_field_errors()
|
||||||
[u'Please enter a correct username and password. Note that both fields are case-sensitive.']
|
[u'Please enter a correct username and password. Note that both fields are case-sensitive.']
|
||||||
|
|
||||||
The user is inactive.
|
# The user is inactive.
|
||||||
|
|
||||||
>>> data = {
|
>>> data = {
|
||||||
... 'username': 'jsmith',
|
... 'username': 'jsmith',
|
||||||
|
@ -87,7 +105,7 @@ False
|
||||||
>>> user.is_active = True
|
>>> user.is_active = True
|
||||||
>>> user.save()
|
>>> user.save()
|
||||||
|
|
||||||
The success case
|
# The success case
|
||||||
|
|
||||||
>>> form = AuthenticationForm(None, data)
|
>>> form = AuthenticationForm(None, data)
|
||||||
>>> form.is_valid()
|
>>> form.is_valid()
|
||||||
|
@ -95,9 +113,9 @@ True
|
||||||
>>> form.non_field_errors()
|
>>> form.non_field_errors()
|
||||||
[]
|
[]
|
||||||
|
|
||||||
SetPasswordForm:
|
### SetPasswordForm:
|
||||||
|
|
||||||
The two new passwords do not match.
|
# The two new passwords do not match.
|
||||||
|
|
||||||
>>> data = {
|
>>> data = {
|
||||||
... 'new_password1': 'abc123',
|
... 'new_password1': 'abc123',
|
||||||
|
@ -109,7 +127,7 @@ False
|
||||||
>>> form["new_password2"].errors
|
>>> form["new_password2"].errors
|
||||||
[u"The two password fields didn't match."]
|
[u"The two password fields didn't match."]
|
||||||
|
|
||||||
The success case.
|
# The success case.
|
||||||
|
|
||||||
>>> data = {
|
>>> data = {
|
||||||
... 'new_password1': 'abc123',
|
... 'new_password1': 'abc123',
|
||||||
|
@ -119,7 +137,7 @@ The success case.
|
||||||
>>> form.is_valid()
|
>>> form.is_valid()
|
||||||
True
|
True
|
||||||
|
|
||||||
PasswordChangeForm:
|
### PasswordChangeForm:
|
||||||
|
|
||||||
The old password is incorrect.
|
The old password is incorrect.
|
||||||
|
|
||||||
|
@ -134,7 +152,7 @@ False
|
||||||
>>> form["old_password"].errors
|
>>> form["old_password"].errors
|
||||||
[u'Your old password was entered incorrectly. Please enter it again.']
|
[u'Your old password was entered incorrectly. Please enter it again.']
|
||||||
|
|
||||||
The two new passwords do not match.
|
# The two new passwords do not match.
|
||||||
|
|
||||||
>>> data = {
|
>>> data = {
|
||||||
... 'old_password': 'test123',
|
... 'old_password': 'test123',
|
||||||
|
@ -147,7 +165,7 @@ False
|
||||||
>>> form["new_password2"].errors
|
>>> form["new_password2"].errors
|
||||||
[u"The two password fields didn't match."]
|
[u"The two password fields didn't match."]
|
||||||
|
|
||||||
The success case.
|
# The success case.
|
||||||
|
|
||||||
>>> data = {
|
>>> data = {
|
||||||
... 'old_password': 'test123',
|
... 'old_password': 'test123',
|
||||||
|
@ -158,7 +176,7 @@ The success case.
|
||||||
>>> form.is_valid()
|
>>> form.is_valid()
|
||||||
True
|
True
|
||||||
|
|
||||||
Regression test - check the order of fields:
|
# Regression test - check the order of fields:
|
||||||
|
|
||||||
>>> PasswordChangeForm(user, {}).fields.keys()
|
>>> PasswordChangeForm(user, {}).fields.keys()
|
||||||
['old_password', 'new_password1', 'new_password2']
|
['old_password', 'new_password1', 'new_password2']
|
||||||
|
|
Loading…
Reference in New Issue