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:
		
				
					committed by
					
						 Tim Graham
						Tim Graham
					
				
			
			
				
	
			
			
			
						parent
						
							74bb013cc1
						
					
				
				
					commit
					975a76a964
				
			| @@ -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): | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user