1
0
mirror of https://github.com/django/django.git synced 2025-10-25 06:36:07 +00:00

Fixed #26951 -- Allowed AuthenticationForm to work with a username of 0.

This commit is contained in:
Olexander Yermakov
2016-07-26 16:50:29 +03:00
committed by Tim Graham
parent 74bb013cc1
commit 975a76a964
4 changed files with 45 additions and 3 deletions

View File

@@ -15,7 +15,7 @@ from django.contrib.auth.models import User
from django.contrib.sites.models import Site
from django.core import mail
from django.core.mail import EmailMultiAlternatives
from django.forms.fields import CharField, Field
from django.forms.fields import CharField, Field, IntegerField
from django.test import SimpleTestCase, TestCase, mock, override_settings
from django.utils import six, translation
from django.utils.encoding import force_text
@@ -23,6 +23,7 @@ from django.utils.text import capfirst
from django.utils.translation import ugettext as _
from .models.custom_user import CustomUser, ExtensionUser
from .models.with_integer_username import IntegerUsernameUser
from .settings import AUTH_TEMPLATES
@@ -351,6 +352,23 @@ class AuthenticationFormTest(TestDataMixin, TestCase):
form.is_valid() # Not necessary to have valid credentails for the test.
self.assertEqual(form.cleaned_data['password'], data['password'])
@override_settings(AUTH_USER_MODEL='auth_tests.IntegerUsernameUser')
def test_integer_username(self):
class CustomAuthenticationForm(AuthenticationForm):
username = IntegerField()
user = IntegerUsernameUser.objects.create_user(username=0, password='pwd')
data = {
'username': 0,
'password': 'pwd',
}
form = CustomAuthenticationForm(None, data)
self.assertTrue(form.is_valid())
self.assertEqual(form.cleaned_data['username'], data['username'])
self.assertEqual(form.cleaned_data['password'], data['password'])
self.assertEqual(form.errors, {})
self.assertEqual(form.user_cache, user)
class SetPasswordFormTest(TestDataMixin, TestCase):