mirror of
				https://github.com/django/django.git
				synced 2025-10-26 15:16:09 +00:00 
			
		
		
		
	[1.8.x] Moved contrib.auth tests out of contrib.
Backport of 2d7aca3da0 from master
			
			
This commit is contained in:
		| @@ -18,9 +18,7 @@ recursive-include django/contrib/*/locale * | |||||||
| recursive-include django/contrib/admin/templates * | recursive-include django/contrib/admin/templates * | ||||||
| recursive-include django/contrib/admin/static * | recursive-include django/contrib/admin/static * | ||||||
| recursive-include django/contrib/admindocs/templates * | recursive-include django/contrib/admindocs/templates * | ||||||
| recursive-include django/contrib/auth/fixtures * |  | ||||||
| recursive-include django/contrib/auth/templates * | recursive-include django/contrib/auth/templates * | ||||||
| recursive-include django/contrib/auth/tests/templates * |  | ||||||
| recursive-include django/contrib/gis/gdal/tests/data * | recursive-include django/contrib/gis/gdal/tests/data * | ||||||
| recursive-include django/contrib/gis/static * | recursive-include django/contrib/gis/static * | ||||||
| recursive-include django/contrib/gis/templates * | recursive-include django/contrib/gis/templates * | ||||||
|   | |||||||
| @@ -1 +0,0 @@ | |||||||
| # The password for the fixture data users is 'password' |  | ||||||
|   | |||||||
							
								
								
									
										1
									
								
								tests/auth_tests/__init__.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								tests/auth_tests/__init__.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | # The password for the fixture data users is 'password' | ||||||
| @@ -10,11 +10,10 @@ from django.contrib.auth.models import AnonymousUser, Group, Permission, User | |||||||
| from django.contrib.auth.tests.custom_user import ( | from django.contrib.auth.tests.custom_user import ( | ||||||
|     CustomPermissionsUser, CustomUser, ExtensionUser, |     CustomPermissionsUser, CustomUser, ExtensionUser, | ||||||
| ) | ) | ||||||
| from django.contrib.auth.tests.utils import skipIfCustomUser |  | ||||||
| from django.contrib.contenttypes.models import ContentType | from django.contrib.contenttypes.models import ContentType | ||||||
| from django.core.exceptions import ImproperlyConfigured, PermissionDenied | from django.core.exceptions import ImproperlyConfigured, PermissionDenied | ||||||
| from django.http import HttpRequest | from django.http import HttpRequest | ||||||
| from django.test import TestCase, override_settings | from django.test import TestCase, modify_settings, override_settings | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| class CountingMD5PasswordHasher(MD5PasswordHasher): | class CountingMD5PasswordHasher(MD5PasswordHasher): | ||||||
| @@ -175,7 +174,7 @@ class BaseModelBackendTest(object): | |||||||
|         user = self.UserModel._default_manager.get(pk=self.superuser.pk) |         user = self.UserModel._default_manager.get(pk=self.superuser.pk) | ||||||
|         self.assertEqual(len(user.get_all_permissions()), len(Permission.objects.all())) |         self.assertEqual(len(user.get_all_permissions()), len(Permission.objects.all())) | ||||||
| 
 | 
 | ||||||
|     @override_settings(PASSWORD_HASHERS=('django.contrib.auth.tests.test_auth_backends.CountingMD5PasswordHasher',)) |     @override_settings(PASSWORD_HASHERS=['auth_tests.test_auth_backends.CountingMD5PasswordHasher']) | ||||||
|     def test_authentication_timing(self): |     def test_authentication_timing(self): | ||||||
|         """Hasher is run once regardless of whether the user exists. Refs #20760.""" |         """Hasher is run once regardless of whether the user exists. Refs #20760.""" | ||||||
|         # Re-set the password, because this tests overrides PASSWORD_HASHERS |         # Re-set the password, because this tests overrides PASSWORD_HASHERS | ||||||
| @@ -192,7 +191,6 @@ class BaseModelBackendTest(object): | |||||||
|         self.assertEqual(CountingMD5PasswordHasher.calls, 1) |         self.assertEqual(CountingMD5PasswordHasher.calls, 1) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @skipIfCustomUser |  | ||||||
| class ModelBackendTest(BaseModelBackendTest, TestCase): | class ModelBackendTest(BaseModelBackendTest, TestCase): | ||||||
|     """ |     """ | ||||||
|     Tests for the ModelBackend using the default User model. |     Tests for the ModelBackend using the default User model. | ||||||
| @@ -339,22 +337,20 @@ class SimpleRowlevelBackend(object): | |||||||
|             return ['none'] |             return ['none'] | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @skipIfCustomUser | @modify_settings(AUTHENTICATION_BACKENDS={ | ||||||
|  |     'append': 'auth_tests.test_auth_backends.SimpleRowlevelBackend', | ||||||
|  | }) | ||||||
| class RowlevelBackendTest(TestCase): | class RowlevelBackendTest(TestCase): | ||||||
|     """ |     """ | ||||||
|     Tests for auth backend that supports object level permissions |     Tests for auth backend that supports object level permissions | ||||||
|     """ |     """ | ||||||
|     backend = 'django.contrib.auth.tests.test_auth_backends.SimpleRowlevelBackend' |  | ||||||
| 
 | 
 | ||||||
|     def setUp(self): |     def setUp(self): | ||||||
|         self.curr_auth = settings.AUTHENTICATION_BACKENDS |  | ||||||
|         settings.AUTHENTICATION_BACKENDS = tuple(self.curr_auth) + (self.backend,) |  | ||||||
|         self.user1 = User.objects.create_user('test', 'test@example.com', 'test') |         self.user1 = User.objects.create_user('test', 'test@example.com', 'test') | ||||||
|         self.user2 = User.objects.create_user('test2', 'test2@example.com', 'test') |         self.user2 = User.objects.create_user('test2', 'test2@example.com', 'test') | ||||||
|         self.user3 = User.objects.create_user('test3', 'test3@example.com', 'test') |         self.user3 = User.objects.create_user('test3', 'test3@example.com', 'test') | ||||||
| 
 | 
 | ||||||
|     def tearDown(self): |     def tearDown(self): | ||||||
|         settings.AUTHENTICATION_BACKENDS = self.curr_auth |  | ||||||
|         # The get_group_permissions test messes with ContentTypes, which will |         # The get_group_permissions test messes with ContentTypes, which will | ||||||
|         # be cached; flush the cache to ensure there are no side effects |         # be cached; flush the cache to ensure there are no side effects | ||||||
|         # Refs #14975, #14925 |         # Refs #14975, #14925 | ||||||
| @@ -380,21 +376,17 @@ class RowlevelBackendTest(TestCase): | |||||||
|         self.assertEqual(self.user3.get_group_permissions(TestObj()), {'group_perm'}) |         self.assertEqual(self.user3.get_group_permissions(TestObj()), {'group_perm'}) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  | @override_settings( | ||||||
|  |     AUTHENTICATION_BACKENDS=['auth_tests.test_auth_backends.SimpleRowlevelBackend'], | ||||||
|  | ) | ||||||
| class AnonymousUserBackendTest(TestCase): | class AnonymousUserBackendTest(TestCase): | ||||||
|     """ |     """ | ||||||
|     Tests for AnonymousUser delegating to backend. |     Tests for AnonymousUser delegating to backend. | ||||||
|     """ |     """ | ||||||
| 
 | 
 | ||||||
|     backend = 'django.contrib.auth.tests.test_auth_backends.SimpleRowlevelBackend' |  | ||||||
| 
 |  | ||||||
|     def setUp(self): |     def setUp(self): | ||||||
|         self.curr_auth = settings.AUTHENTICATION_BACKENDS |  | ||||||
|         settings.AUTHENTICATION_BACKENDS = (self.backend,) |  | ||||||
|         self.user1 = AnonymousUser() |         self.user1 = AnonymousUser() | ||||||
| 
 | 
 | ||||||
|     def tearDown(self): |  | ||||||
|         settings.AUTHENTICATION_BACKENDS = self.curr_auth |  | ||||||
| 
 |  | ||||||
|     def test_has_perm(self): |     def test_has_perm(self): | ||||||
|         self.assertEqual(self.user1.has_perm('perm', TestObj()), False) |         self.assertEqual(self.user1.has_perm('perm', TestObj()), False) | ||||||
|         self.assertEqual(self.user1.has_perm('anon', TestObj()), True) |         self.assertEqual(self.user1.has_perm('anon', TestObj()), True) | ||||||
| @@ -411,7 +403,6 @@ class AnonymousUserBackendTest(TestCase): | |||||||
|         self.assertEqual(self.user1.get_all_permissions(TestObj()), {'anon'}) |         self.assertEqual(self.user1.get_all_permissions(TestObj()), {'anon'}) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @skipIfCustomUser |  | ||||||
| @override_settings(AUTHENTICATION_BACKENDS=[]) | @override_settings(AUTHENTICATION_BACKENDS=[]) | ||||||
| class NoBackendsTest(TestCase): | class NoBackendsTest(TestCase): | ||||||
|     """ |     """ | ||||||
| @@ -424,23 +415,17 @@ class NoBackendsTest(TestCase): | |||||||
|         self.assertRaises(ImproperlyConfigured, self.user.has_perm, ('perm', TestObj(),)) |         self.assertRaises(ImproperlyConfigured, self.user.has_perm, ('perm', TestObj(),)) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @skipIfCustomUser | @override_settings(AUTHENTICATION_BACKENDS=['auth_tests.test_auth_backends.SimpleRowlevelBackend']) | ||||||
| class InActiveUserBackendTest(TestCase): | class InActiveUserBackendTest(TestCase): | ||||||
|     """ |     """ | ||||||
|     Tests for an inactive user |     Tests for an inactive user | ||||||
|     """ |     """ | ||||||
|     backend = 'django.contrib.auth.tests.test_auth_backends.SimpleRowlevelBackend' |  | ||||||
| 
 | 
 | ||||||
|     def setUp(self): |     def setUp(self): | ||||||
|         self.curr_auth = settings.AUTHENTICATION_BACKENDS |  | ||||||
|         settings.AUTHENTICATION_BACKENDS = (self.backend,) |  | ||||||
|         self.user1 = User.objects.create_user('test', 'test@example.com', 'test') |         self.user1 = User.objects.create_user('test', 'test@example.com', 'test') | ||||||
|         self.user1.is_active = False |         self.user1.is_active = False | ||||||
|         self.user1.save() |         self.user1.save() | ||||||
| 
 | 
 | ||||||
|     def tearDown(self): |  | ||||||
|         settings.AUTHENTICATION_BACKENDS = self.curr_auth |  | ||||||
| 
 |  | ||||||
|     def test_has_perm(self): |     def test_has_perm(self): | ||||||
|         self.assertEqual(self.user1.has_perm('perm', TestObj()), False) |         self.assertEqual(self.user1.has_perm('perm', TestObj()), False) | ||||||
|         self.assertEqual(self.user1.has_perm('inactive', TestObj()), True) |         self.assertEqual(self.user1.has_perm('inactive', TestObj()), True) | ||||||
| @@ -468,12 +453,11 @@ class PermissionDeniedBackend(object): | |||||||
|         raise PermissionDenied |         raise PermissionDenied | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @skipIfCustomUser |  | ||||||
| class PermissionDeniedBackendTest(TestCase): | class PermissionDeniedBackendTest(TestCase): | ||||||
|     """ |     """ | ||||||
|     Tests that other backends are not checked once a backend raises PermissionDenied |     Tests that other backends are not checked once a backend raises PermissionDenied | ||||||
|     """ |     """ | ||||||
|     backend = 'django.contrib.auth.tests.test_auth_backends.PermissionDeniedBackend' |     backend = 'auth_tests.test_auth_backends.PermissionDeniedBackend' | ||||||
| 
 | 
 | ||||||
|     def setUp(self): |     def setUp(self): | ||||||
|         self.user1 = User.objects.create_user('test', 'test@example.com', 'test') |         self.user1 = User.objects.create_user('test', 'test@example.com', 'test') | ||||||
| @@ -515,12 +499,11 @@ class NewModelBackend(ModelBackend): | |||||||
|     pass |     pass | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @skipIfCustomUser |  | ||||||
| class ChangedBackendSettingsTest(TestCase): | class ChangedBackendSettingsTest(TestCase): | ||||||
|     """ |     """ | ||||||
|     Tests for changes in the settings.AUTHENTICATION_BACKENDS |     Tests for changes in the settings.AUTHENTICATION_BACKENDS | ||||||
|     """ |     """ | ||||||
|     backend = 'django.contrib.auth.tests.test_auth_backends.NewModelBackend' |     backend = 'auth_tests.test_auth_backends.NewModelBackend' | ||||||
| 
 | 
 | ||||||
|     TEST_USERNAME = 'test_user' |     TEST_USERNAME = 'test_user' | ||||||
|     TEST_PASSWORD = 'test_password' |     TEST_PASSWORD = 'test_password' | ||||||
| @@ -572,14 +555,13 @@ class TypeErrorBackend(object): | |||||||
|         raise TypeError |         raise TypeError | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @skipIfCustomUser |  | ||||||
| class TypeErrorBackendTest(TestCase): | class TypeErrorBackendTest(TestCase): | ||||||
|     """ |     """ | ||||||
|     Tests that a TypeError within a backend is propagated properly. |     Tests that a TypeError within a backend is propagated properly. | ||||||
| 
 | 
 | ||||||
|     Regression test for ticket #18171 |     Regression test for ticket #18171 | ||||||
|     """ |     """ | ||||||
|     backend = 'django.contrib.auth.tests.test_auth_backends.TypeErrorBackend' |     backend = 'auth_tests.test_auth_backends.TypeErrorBackend' | ||||||
| 
 | 
 | ||||||
|     def setUp(self): |     def setUp(self): | ||||||
|         self.user1 = User.objects.create_user('test', 'test@example.com', 'test') |         self.user1 = User.objects.create_user('test', 'test@example.com', 'test') | ||||||
| @@ -589,7 +571,6 @@ class TypeErrorBackendTest(TestCase): | |||||||
|         self.assertRaises(TypeError, authenticate, username='test', password='test') |         self.assertRaises(TypeError, authenticate, username='test', password='test') | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @skipIfCustomUser |  | ||||||
| class ImproperlyConfiguredUserModelTest(TestCase): | class ImproperlyConfiguredUserModelTest(TestCase): | ||||||
|     """ |     """ | ||||||
|     Tests that an exception from within get_user_model is propagated and doesn't |     Tests that an exception from within get_user_model is propagated and doesn't | ||||||
| @@ -623,7 +604,7 @@ class ImportedBackendTests(TestCase): | |||||||
|     as the one defined in AUTHENTICATION_BACKENDS setting. |     as the one defined in AUTHENTICATION_BACKENDS setting. | ||||||
|     """ |     """ | ||||||
| 
 | 
 | ||||||
|     backend = 'django.contrib.auth.tests.backend_alias.ImportedModelBackend' |     backend = 'auth_tests.backend_alias.ImportedModelBackend' | ||||||
| 
 | 
 | ||||||
|     @override_settings(AUTHENTICATION_BACKENDS=(backend, )) |     @override_settings(AUTHENTICATION_BACKENDS=(backend, )) | ||||||
|     def test_backend_path(self): |     def test_backend_path(self): | ||||||
| @@ -4,7 +4,6 @@ from django.apps import apps | |||||||
| from django.contrib.auth import get_user_model | from django.contrib.auth import get_user_model | ||||||
| from django.contrib.auth.models import AnonymousUser, User | from django.contrib.auth.models import AnonymousUser, User | ||||||
| from django.contrib.auth.tests.custom_user import CustomUser | from django.contrib.auth.tests.custom_user import CustomUser | ||||||
| from django.contrib.auth.tests.utils import skipIfCustomUser |  | ||||||
| from django.core.exceptions import ImproperlyConfigured | from django.core.exceptions import ImproperlyConfigured | ||||||
| from django.dispatch import receiver | from django.dispatch import receiver | ||||||
| from django.test import TestCase, override_settings | from django.test import TestCase, override_settings | ||||||
| @@ -22,7 +21,6 @@ def user_model_swapped(**kwargs): | |||||||
|         apps.clear_cache() |         apps.clear_cache() | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @skipIfCustomUser |  | ||||||
| class BasicTestCase(TestCase): | class BasicTestCase(TestCase): | ||||||
|     def test_user(self): |     def test_user(self): | ||||||
|         "Check that users can be created and can set their password" |         "Check that users can be created and can set their password" | ||||||
| @@ -108,7 +106,6 @@ class BasicTestCase(TestCase): | |||||||
|         with self.assertRaises(ImproperlyConfigured): |         with self.assertRaises(ImproperlyConfigured): | ||||||
|             get_user_model() |             get_user_model() | ||||||
| 
 | 
 | ||||||
|     @skipIfCustomUser |  | ||||||
|     def test_user_verbose_names_translatable(self): |     def test_user_verbose_names_translatable(self): | ||||||
|         "Default User model verbose names are translatable (#19945)" |         "Default User model verbose names are translatable (#19945)" | ||||||
|         with translation.override('en'): |         with translation.override('en'): | ||||||
| @@ -6,7 +6,6 @@ from django.db.models import Q | |||||||
| from django.test import TestCase, override_settings | from django.test import TestCase, override_settings | ||||||
| 
 | 
 | ||||||
| from .settings import AUTH_MIDDLEWARE_CLASSES, AUTH_TEMPLATES | from .settings import AUTH_MIDDLEWARE_CLASSES, AUTH_TEMPLATES | ||||||
| from .utils import skipIfCustomUser |  | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| class MockUser(object): | class MockUser(object): | ||||||
| @@ -58,10 +57,9 @@ class PermWrapperTests(TestCase): | |||||||
|             self.EQLimiterObject() in pldict |             self.EQLimiterObject() in pldict | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @skipIfCustomUser |  | ||||||
| @override_settings( | @override_settings( | ||||||
|     PASSWORD_HASHERS=('django.contrib.auth.hashers.SHA1PasswordHasher',), |     PASSWORD_HASHERS=['django.contrib.auth.hashers.SHA1PasswordHasher'], | ||||||
|     ROOT_URLCONF='django.contrib.auth.tests.urls', |     ROOT_URLCONF='auth_tests.urls', | ||||||
|     TEMPLATES=AUTH_TEMPLATES, |     TEMPLATES=AUTH_TEMPLATES, | ||||||
|     USE_TZ=False,                           # required for loading the fixture |     USE_TZ=False,                           # required for loading the fixture | ||||||
| ) | ) | ||||||
| @@ -1,16 +1,15 @@ | |||||||
| from django.conf import settings | from django.conf import settings | ||||||
| from django.contrib.auth import models | from django.contrib.auth import models | ||||||
| from django.contrib.auth.decorators import login_required, permission_required | from django.contrib.auth.decorators import login_required, permission_required | ||||||
| from django.contrib.auth.tests.test_views import AuthViewsTestCase |  | ||||||
| from django.contrib.auth.tests.utils import skipIfCustomUser |  | ||||||
| from django.core.exceptions import PermissionDenied | from django.core.exceptions import PermissionDenied | ||||||
| from django.http import HttpResponse | from django.http import HttpResponse | ||||||
| from django.test import TestCase, override_settings | from django.test import TestCase, override_settings | ||||||
| from django.test.client import RequestFactory | from django.test.client import RequestFactory | ||||||
| 
 | 
 | ||||||
|  | from .test_views import AuthViewsTestCase | ||||||
| 
 | 
 | ||||||
| @skipIfCustomUser | 
 | ||||||
| @override_settings(ROOT_URLCONF='django.contrib.auth.tests.urls') | @override_settings(ROOT_URLCONF='auth_tests.urls') | ||||||
| class LoginRequiredTestCase(AuthViewsTestCase): | class LoginRequiredTestCase(AuthViewsTestCase): | ||||||
|     """ |     """ | ||||||
|     Tests the login_required decorators |     Tests the login_required decorators | ||||||
| @@ -19,11 +19,9 @@ from django.utils.text import capfirst | |||||||
| from django.utils.translation import ugettext as _ | from django.utils.translation import ugettext as _ | ||||||
| 
 | 
 | ||||||
| from .settings import AUTH_TEMPLATES | from .settings import AUTH_TEMPLATES | ||||||
| from .utils import skipIfCustomUser |  | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @skipIfCustomUser | @override_settings(USE_TZ=False, PASSWORD_HASHERS=['django.contrib.auth.hashers.SHA1PasswordHasher']) | ||||||
| @override_settings(USE_TZ=False, PASSWORD_HASHERS=('django.contrib.auth.hashers.SHA1PasswordHasher',)) |  | ||||||
| class UserCreationFormTest(TestCase): | class UserCreationFormTest(TestCase): | ||||||
| 
 | 
 | ||||||
|     fixtures = ['authtestdata.json'] |     fixtures = ['authtestdata.json'] | ||||||
| @@ -90,8 +88,7 @@ class UserCreationFormTest(TestCase): | |||||||
|         self.assertEqual(repr(u), '<User: jsmith@example.com>') |         self.assertEqual(repr(u), '<User: jsmith@example.com>') | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @skipIfCustomUser | @override_settings(USE_TZ=False, PASSWORD_HASHERS=['django.contrib.auth.hashers.SHA1PasswordHasher']) | ||||||
| @override_settings(USE_TZ=False, PASSWORD_HASHERS=('django.contrib.auth.hashers.SHA1PasswordHasher',)) |  | ||||||
| class AuthenticationFormTest(TestCase): | class AuthenticationFormTest(TestCase): | ||||||
| 
 | 
 | ||||||
|     fixtures = ['authtestdata.json'] |     fixtures = ['authtestdata.json'] | ||||||
| @@ -203,8 +200,7 @@ class AuthenticationFormTest(TestCase): | |||||||
|         self.assertEqual(form.fields['username'].label, "") |         self.assertEqual(form.fields['username'].label, "") | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @skipIfCustomUser | @override_settings(USE_TZ=False, PASSWORD_HASHERS=['django.contrib.auth.hashers.SHA1PasswordHasher']) | ||||||
| @override_settings(USE_TZ=False, PASSWORD_HASHERS=('django.contrib.auth.hashers.SHA1PasswordHasher',)) |  | ||||||
| class SetPasswordFormTest(TestCase): | class SetPasswordFormTest(TestCase): | ||||||
| 
 | 
 | ||||||
|     fixtures = ['authtestdata.json'] |     fixtures = ['authtestdata.json'] | ||||||
| @@ -231,8 +227,7 @@ class SetPasswordFormTest(TestCase): | |||||||
|         self.assertTrue(form.is_valid()) |         self.assertTrue(form.is_valid()) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @skipIfCustomUser | @override_settings(USE_TZ=False, PASSWORD_HASHERS=['django.contrib.auth.hashers.SHA1PasswordHasher']) | ||||||
| @override_settings(USE_TZ=False, PASSWORD_HASHERS=('django.contrib.auth.hashers.SHA1PasswordHasher',)) |  | ||||||
| class PasswordChangeFormTest(TestCase): | class PasswordChangeFormTest(TestCase): | ||||||
| 
 | 
 | ||||||
|     fixtures = ['authtestdata.json'] |     fixtures = ['authtestdata.json'] | ||||||
| @@ -280,8 +275,7 @@ class PasswordChangeFormTest(TestCase): | |||||||
|                          ['old_password', 'new_password1', 'new_password2']) |                          ['old_password', 'new_password1', 'new_password2']) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @skipIfCustomUser | @override_settings(USE_TZ=False, PASSWORD_HASHERS=['django.contrib.auth.hashers.SHA1PasswordHasher']) | ||||||
| @override_settings(USE_TZ=False, PASSWORD_HASHERS=('django.contrib.auth.hashers.SHA1PasswordHasher',)) |  | ||||||
| class UserChangeFormTest(TestCase): | class UserChangeFormTest(TestCase): | ||||||
| 
 | 
 | ||||||
|     fixtures = ['authtestdata.json'] |     fixtures = ['authtestdata.json'] | ||||||
| @@ -359,7 +353,6 @@ class UserChangeFormTest(TestCase): | |||||||
|         self.assertEqual(form.initial['password'], form['password'].value()) |         self.assertEqual(form.initial['password'], form['password'].value()) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @skipIfCustomUser |  | ||||||
| @override_settings( | @override_settings( | ||||||
|     PASSWORD_HASHERS=('django.contrib.auth.hashers.SHA1PasswordHasher',), |     PASSWORD_HASHERS=('django.contrib.auth.hashers.SHA1PasswordHasher',), | ||||||
|     TEMPLATES=AUTH_TEMPLATES, |     TEMPLATES=AUTH_TEMPLATES, | ||||||
| @@ -5,7 +5,6 @@ from django.contrib.auth.handlers.modwsgi import ( | |||||||
| ) | ) | ||||||
| from django.contrib.auth.models import Group, User | from django.contrib.auth.models import Group, User | ||||||
| from django.contrib.auth.tests.custom_user import CustomUser | from django.contrib.auth.tests.custom_user import CustomUser | ||||||
| from django.contrib.auth.tests.utils import skipIfCustomUser |  | ||||||
| from django.test import TransactionTestCase, override_settings | from django.test import TransactionTestCase, override_settings | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @@ -21,7 +20,6 @@ class ModWsgiHandlerTestCase(TransactionTestCase): | |||||||
|         'django.contrib.contenttypes', |         'django.contrib.contenttypes', | ||||||
|     ] |     ] | ||||||
| 
 | 
 | ||||||
|     @skipIfCustomUser |  | ||||||
|     def test_check_password(self): |     def test_check_password(self): | ||||||
|         """ |         """ | ||||||
|         Verify that check_password returns the correct values as per |         Verify that check_password returns the correct values as per | ||||||
| @@ -62,7 +60,6 @@ class ModWsgiHandlerTestCase(TransactionTestCase): | |||||||
|         # Valid user with incorrect password |         # Valid user with incorrect password | ||||||
|         self.assertFalse(check_password({}, 'test@example.com', 'incorrect')) |         self.assertFalse(check_password({}, 'test@example.com', 'incorrect')) | ||||||
| 
 | 
 | ||||||
|     @skipIfCustomUser |  | ||||||
|     def test_groups_for_user(self): |     def test_groups_for_user(self): | ||||||
|         """ |         """ | ||||||
|         Check that groups_for_user returns correct values as per |         Check that groups_for_user returns correct values as per | ||||||
| @@ -295,7 +295,7 @@ class TestUtilsHashPass(SimpleTestCase): | |||||||
|             state['upgraded'] = True |             state['upgraded'] = True | ||||||
| 
 | 
 | ||||||
|         with self.settings(PASSWORD_HASHERS=[ |         with self.settings(PASSWORD_HASHERS=[ | ||||||
|                 'django.contrib.auth.tests.test_hashers.PBKDF2SingleIterationHasher']): |                 'auth_tests.test_hashers.PBKDF2SingleIterationHasher']): | ||||||
|             encoded = make_password('letmein') |             encoded = make_password('letmein') | ||||||
|             algo, iterations, salt, hash = encoded.split('$', 3) |             algo, iterations, salt, hash = encoded.split('$', 3) | ||||||
|             self.assertEqual(iterations, '1') |             self.assertEqual(iterations, '1') | ||||||
| @@ -308,7 +308,7 @@ class TestUtilsHashPass(SimpleTestCase): | |||||||
|         # updated to the new iteration count. |         # updated to the new iteration count. | ||||||
|         with self.settings(PASSWORD_HASHERS=[ |         with self.settings(PASSWORD_HASHERS=[ | ||||||
|                 'django.contrib.auth.hashers.PBKDF2PasswordHasher', |                 'django.contrib.auth.hashers.PBKDF2PasswordHasher', | ||||||
|                 'django.contrib.auth.tests.test_hashers.PBKDF2SingleIterationHasher']): |                 'auth_tests.test_hashers.PBKDF2SingleIterationHasher']): | ||||||
|             self.assertTrue(check_password('letmein', encoded, setter)) |             self.assertTrue(check_password('letmein', encoded, setter)) | ||||||
|             self.assertTrue(state['upgraded']) |             self.assertTrue(state['upgraded']) | ||||||
| 
 | 
 | ||||||
| @@ -13,9 +13,9 @@ from django.contrib.auth.management.commands import ( | |||||||
| ) | ) | ||||||
| from django.contrib.auth.models import Group, User | from django.contrib.auth.models import Group, User | ||||||
| from django.contrib.auth.tests.custom_user import ( | from django.contrib.auth.tests.custom_user import ( | ||||||
|     CustomUser, CustomUserWithFK, Email, |     CustomUser, CustomUserBadRequiredFields, CustomUserNonListRequiredFields, | ||||||
|  |     CustomUserNonUniqueUsername, CustomUserWithFK, Email, | ||||||
| ) | ) | ||||||
| from django.contrib.auth.tests.utils import skipIfCustomUser |  | ||||||
| from django.contrib.contenttypes.models import ContentType | from django.contrib.contenttypes.models import ContentType | ||||||
| from django.core import checks, exceptions | from django.core import checks, exceptions | ||||||
| from django.core.management import call_command | from django.core.management import call_command | ||||||
| @@ -23,6 +23,7 @@ from django.core.management.base import CommandError | |||||||
| from django.test import TestCase, override_settings, override_system_checks | from django.test import TestCase, override_settings, override_system_checks | ||||||
| from django.utils import six | from django.utils import six | ||||||
| from django.utils.encoding import force_str | from django.utils.encoding import force_str | ||||||
|  | from django.utils.translation import ugettext_lazy as _ | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| def mock_inputs(inputs): | def mock_inputs(inputs): | ||||||
| @@ -74,7 +75,6 @@ class MockTTY(object): | |||||||
|         return True |         return True | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @skipIfCustomUser |  | ||||||
| class GetDefaultUsernameTestCase(TestCase): | class GetDefaultUsernameTestCase(TestCase): | ||||||
| 
 | 
 | ||||||
|     def setUp(self): |     def setUp(self): | ||||||
| @@ -103,7 +103,6 @@ class GetDefaultUsernameTestCase(TestCase): | |||||||
|         self.assertEqual(management.get_default_username(), 'julia') |         self.assertEqual(management.get_default_username(), 'julia') | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @skipIfCustomUser |  | ||||||
| class ChangepasswordManagementCommandTestCase(TestCase): | class ChangepasswordManagementCommandTestCase(TestCase): | ||||||
| 
 | 
 | ||||||
|     def setUp(self): |     def setUp(self): | ||||||
| @@ -155,7 +154,6 @@ class ChangepasswordManagementCommandTestCase(TestCase): | |||||||
|         command.execute(username="J\xfalia", stdout=self.stdout) |         command.execute(username="J\xfalia", stdout=self.stdout) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @skipIfCustomUser |  | ||||||
| @override_settings(SILENCED_SYSTEM_CHECKS=['fields.W342'])  # ForeignKey(unique=True) | @override_settings(SILENCED_SYSTEM_CHECKS=['fields.W342'])  # ForeignKey(unique=True) | ||||||
| class CreatesuperuserManagementCommandTestCase(TestCase): | class CreatesuperuserManagementCommandTestCase(TestCase): | ||||||
| 
 | 
 | ||||||
| @@ -216,11 +214,9 @@ class CreatesuperuserManagementCommandTestCase(TestCase): | |||||||
|         'u\u017eivatel': 'foo',  # username (cz) |         'u\u017eivatel': 'foo',  # username (cz) | ||||||
|         'email': 'nolocale@somewhere.org'}) |         'email': 'nolocale@somewhere.org'}) | ||||||
|     def test_non_ascii_verbose_name(self): |     def test_non_ascii_verbose_name(self): | ||||||
|         # Aliased so the string doesn't get extracted |  | ||||||
|         from django.utils.translation import ugettext_lazy as ulazy |  | ||||||
|         username_field = User._meta.get_field('username') |         username_field = User._meta.get_field('username') | ||||||
|         old_verbose_name = username_field.verbose_name |         old_verbose_name = username_field.verbose_name | ||||||
|         username_field.verbose_name = ulazy('u\u017eivatel') |         username_field.verbose_name = _('u\u017eivatel') | ||||||
|         new_io = six.StringIO() |         new_io = six.StringIO() | ||||||
|         try: |         try: | ||||||
|             call_command( |             call_command( | ||||||
| @@ -422,8 +418,6 @@ class CustomUserModelValidationTestCase(TestCase): | |||||||
|     @override_system_checks([check_user_model]) |     @override_system_checks([check_user_model]) | ||||||
|     def test_required_fields_is_list(self): |     def test_required_fields_is_list(self): | ||||||
|         "REQUIRED_FIELDS should be a list." |         "REQUIRED_FIELDS should be a list." | ||||||
| 
 |  | ||||||
|         from .custom_user import CustomUserNonListRequiredFields |  | ||||||
|         errors = checks.run_checks() |         errors = checks.run_checks() | ||||||
|         expected = [ |         expected = [ | ||||||
|             checks.Error( |             checks.Error( | ||||||
| @@ -439,8 +433,6 @@ class CustomUserModelValidationTestCase(TestCase): | |||||||
|     @override_system_checks([check_user_model]) |     @override_system_checks([check_user_model]) | ||||||
|     def test_username_not_in_required_fields(self): |     def test_username_not_in_required_fields(self): | ||||||
|         "USERNAME_FIELD should not appear in REQUIRED_FIELDS." |         "USERNAME_FIELD should not appear in REQUIRED_FIELDS." | ||||||
| 
 |  | ||||||
|         from .custom_user import CustomUserBadRequiredFields |  | ||||||
|         errors = checks.run_checks() |         errors = checks.run_checks() | ||||||
|         expected = [ |         expected = [ | ||||||
|             checks.Error( |             checks.Error( | ||||||
| @@ -457,8 +449,6 @@ class CustomUserModelValidationTestCase(TestCase): | |||||||
|     @override_system_checks([check_user_model]) |     @override_system_checks([check_user_model]) | ||||||
|     def test_username_non_unique(self): |     def test_username_non_unique(self): | ||||||
|         "A non-unique USERNAME_FIELD should raise a model validation error." |         "A non-unique USERNAME_FIELD should raise a model validation error." | ||||||
| 
 |  | ||||||
|         from .custom_user import CustomUserNonUniqueUsername |  | ||||||
|         errors = checks.run_checks() |         errors = checks.run_checks() | ||||||
|         expected = [ |         expected = [ | ||||||
|             checks.Error( |             checks.Error( | ||||||
| @@ -480,8 +470,6 @@ class CustomUserModelValidationTestCase(TestCase): | |||||||
|         """ A non-unique USERNAME_FIELD should raise an error only if we use the |         """ A non-unique USERNAME_FIELD should raise an error only if we use the | ||||||
|         default authentication backend. Otherwise, an warning should be raised. |         default authentication backend. Otherwise, an warning should be raised. | ||||||
|         """ |         """ | ||||||
| 
 |  | ||||||
|         from .custom_user import CustomUserNonUniqueUsername |  | ||||||
|         errors = checks.run_checks() |         errors = checks.run_checks() | ||||||
|         expected = [ |         expected = [ | ||||||
|             checks.Warning( |             checks.Warning( | ||||||
| @@ -2,14 +2,14 @@ from django.contrib.auth import get_user_model | |||||||
| from django.contrib.auth.models import ( | from django.contrib.auth.models import ( | ||||||
|     AbstractUser, Group, Permission, User, UserManager, |     AbstractUser, Group, Permission, User, UserManager, | ||||||
| ) | ) | ||||||
| from django.contrib.auth.tests.utils import skipIfCustomUser | # Needed so model is installed when tests are run independently: | ||||||
|  | from django.contrib.auth.tests.custom_user import IsActiveTestUser1  # NOQA | ||||||
| from django.contrib.contenttypes.models import ContentType | from django.contrib.contenttypes.models import ContentType | ||||||
| from django.core import mail | from django.core import mail | ||||||
| from django.db.models.signals import post_save | from django.db.models.signals import post_save | ||||||
| from django.test import TestCase, override_settings | from django.test import TestCase, override_settings | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @skipIfCustomUser |  | ||||||
| @override_settings(USE_TZ=False) | @override_settings(USE_TZ=False) | ||||||
| class NaturalKeysTestCase(TestCase): | class NaturalKeysTestCase(TestCase): | ||||||
|     fixtures = ['authtestdata.json'] |     fixtures = ['authtestdata.json'] | ||||||
| @@ -24,7 +24,6 @@ class NaturalKeysTestCase(TestCase): | |||||||
|         self.assertEqual(Group.objects.get_by_natural_key('users'), users_group) |         self.assertEqual(Group.objects.get_by_natural_key('users'), users_group) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @skipIfCustomUser |  | ||||||
| @override_settings(USE_TZ=False) | @override_settings(USE_TZ=False) | ||||||
| class LoadDataWithoutNaturalKeysTestCase(TestCase): | class LoadDataWithoutNaturalKeysTestCase(TestCase): | ||||||
|     fixtures = ['regular.json'] |     fixtures = ['regular.json'] | ||||||
| @@ -35,7 +34,6 @@ class LoadDataWithoutNaturalKeysTestCase(TestCase): | |||||||
|         self.assertEqual(group, user.groups.get()) |         self.assertEqual(group, user.groups.get()) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @skipIfCustomUser |  | ||||||
| @override_settings(USE_TZ=False) | @override_settings(USE_TZ=False) | ||||||
| class LoadDataWithNaturalKeysTestCase(TestCase): | class LoadDataWithNaturalKeysTestCase(TestCase): | ||||||
|     fixtures = ['natural.json'] |     fixtures = ['natural.json'] | ||||||
| @@ -100,7 +98,6 @@ class LoadDataWithNaturalKeysAndMultipleDatabasesTestCase(TestCase): | |||||||
|         self.assertEqual(perm_other.content_type_id, other_objects[0].id) |         self.assertEqual(perm_other.content_type_id, other_objects[0].id) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @skipIfCustomUser |  | ||||||
| class UserManagerTestCase(TestCase): | class UserManagerTestCase(TestCase): | ||||||
| 
 | 
 | ||||||
|     def test_create_user(self): |     def test_create_user(self): | ||||||
| @@ -167,7 +164,6 @@ class IsActiveTestCase(TestCase): | |||||||
|     Tests the behavior of the guaranteed is_active attribute |     Tests the behavior of the guaranteed is_active attribute | ||||||
|     """ |     """ | ||||||
| 
 | 
 | ||||||
|     @skipIfCustomUser |  | ||||||
|     def test_builtin_user_isactive(self): |     def test_builtin_user_isactive(self): | ||||||
|         user = User.objects.create(username='foo', email='foo@bar.com') |         user = User.objects.create(username='foo', email='foo@bar.com') | ||||||
|         # is_active is true by default |         # is_active is true by default | ||||||
| @@ -195,7 +191,6 @@ class IsActiveTestCase(TestCase): | |||||||
|         self.assertEqual(user_fetched.is_active, True) |         self.assertEqual(user_fetched.is_active, True) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @skipIfCustomUser |  | ||||||
| class TestCreateSuperUserSignals(TestCase): | class TestCreateSuperUserSignals(TestCase): | ||||||
|     """ |     """ | ||||||
|     Simple test case for ticket #20541 |     Simple test case for ticket #20541 | ||||||
| @@ -5,13 +5,11 @@ from django.contrib.auth import authenticate | |||||||
| from django.contrib.auth.backends import RemoteUserBackend | from django.contrib.auth.backends import RemoteUserBackend | ||||||
| from django.contrib.auth.middleware import RemoteUserMiddleware | from django.contrib.auth.middleware import RemoteUserMiddleware | ||||||
| from django.contrib.auth.models import User | from django.contrib.auth.models import User | ||||||
| from django.contrib.auth.tests.utils import skipIfCustomUser |  | ||||||
| from django.test import TestCase, override_settings | from django.test import TestCase, override_settings | ||||||
| from django.utils import timezone | from django.utils import timezone | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @skipIfCustomUser | @override_settings(ROOT_URLCONF='auth_tests.urls') | ||||||
| @override_settings(ROOT_URLCONF='django.contrib.auth.tests.urls') |  | ||||||
| class RemoteUserTest(TestCase): | class RemoteUserTest(TestCase): | ||||||
| 
 | 
 | ||||||
|     middleware = 'django.contrib.auth.middleware.RemoteUserMiddleware' |     middleware = 'django.contrib.auth.middleware.RemoteUserMiddleware' | ||||||
| @@ -154,14 +152,13 @@ class RemoteUserNoCreateBackend(RemoteUserBackend): | |||||||
|     create_unknown_user = False |     create_unknown_user = False | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @skipIfCustomUser |  | ||||||
| class RemoteUserNoCreateTest(RemoteUserTest): | class RemoteUserNoCreateTest(RemoteUserTest): | ||||||
|     """ |     """ | ||||||
|     Contains the same tests as RemoteUserTest, but using a custom auth backend |     Contains the same tests as RemoteUserTest, but using a custom auth backend | ||||||
|     class that doesn't create unknown users. |     class that doesn't create unknown users. | ||||||
|     """ |     """ | ||||||
| 
 | 
 | ||||||
|     backend = 'django.contrib.auth.tests.test_remote_user.RemoteUserNoCreateBackend' |     backend = 'auth_tests.test_remote_user.RemoteUserNoCreateBackend' | ||||||
| 
 | 
 | ||||||
|     def test_unknown_user(self): |     def test_unknown_user(self): | ||||||
|         num_users = User.objects.count() |         num_users = User.objects.count() | ||||||
| @@ -190,14 +187,13 @@ class CustomRemoteUserBackend(RemoteUserBackend): | |||||||
|         return user |         return user | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @skipIfCustomUser |  | ||||||
| class RemoteUserCustomTest(RemoteUserTest): | class RemoteUserCustomTest(RemoteUserTest): | ||||||
|     """ |     """ | ||||||
|     Tests a custom RemoteUserBackend subclass that overrides the clean_username |     Tests a custom RemoteUserBackend subclass that overrides the clean_username | ||||||
|     and configure_user methods. |     and configure_user methods. | ||||||
|     """ |     """ | ||||||
| 
 | 
 | ||||||
|     backend = 'django.contrib.auth.tests.test_remote_user.CustomRemoteUserBackend' |     backend = 'auth_tests.test_remote_user.CustomRemoteUserBackend' | ||||||
|     # REMOTE_USER strings with email addresses for the custom backend to |     # REMOTE_USER strings with email addresses for the custom backend to | ||||||
|     # clean. |     # clean. | ||||||
|     known_user = 'knownuser@example.com' |     known_user = 'knownuser@example.com' | ||||||
| @@ -228,13 +224,12 @@ class CustomHeaderMiddleware(RemoteUserMiddleware): | |||||||
|     header = 'HTTP_AUTHUSER' |     header = 'HTTP_AUTHUSER' | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @skipIfCustomUser |  | ||||||
| class CustomHeaderRemoteUserTest(RemoteUserTest): | class CustomHeaderRemoteUserTest(RemoteUserTest): | ||||||
|     """ |     """ | ||||||
|     Tests a custom RemoteUserMiddleware subclass with custom HTTP auth user |     Tests a custom RemoteUserMiddleware subclass with custom HTTP auth user | ||||||
|     header. |     header. | ||||||
|     """ |     """ | ||||||
|     middleware = ( |     middleware = ( | ||||||
|         'django.contrib.auth.tests.test_remote_user.CustomHeaderMiddleware' |         'auth_tests.test_remote_user.CustomHeaderMiddleware' | ||||||
|     ) |     ) | ||||||
|     header = 'HTTP_AUTHUSER' |     header = 'HTTP_AUTHUSER' | ||||||
| @@ -1,14 +1,12 @@ | |||||||
| from django.contrib.auth import signals | from django.contrib.auth import signals | ||||||
| from django.contrib.auth.models import User | from django.contrib.auth.models import User | ||||||
| from django.contrib.auth.tests.utils import skipIfCustomUser |  | ||||||
| from django.test import TestCase, override_settings | from django.test import TestCase, override_settings | ||||||
| from django.test.client import RequestFactory | from django.test.client import RequestFactory | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @skipIfCustomUser |  | ||||||
| @override_settings(USE_TZ=False, | @override_settings(USE_TZ=False, | ||||||
|     PASSWORD_HASHERS=('django.contrib.auth.hashers.SHA1PasswordHasher',), |     PASSWORD_HASHERS=['django.contrib.auth.hashers.SHA1PasswordHasher'], | ||||||
|     ROOT_URLCONF='django.contrib.auth.tests.urls') |     ROOT_URLCONF='auth_tests.urls') | ||||||
| class SignalTestCase(TestCase): | class SignalTestCase(TestCase): | ||||||
|     fixtures = ['authtestdata.json'] |     fixtures = ['authtestdata.json'] | ||||||
| 
 | 
 | ||||||
| @@ -1,6 +1,5 @@ | |||||||
| from django.contrib.auth import authenticate | from django.contrib.auth import authenticate | ||||||
| from django.contrib.auth.models import User | from django.contrib.auth.models import User | ||||||
| from django.contrib.auth.tests.utils import skipIfCustomUser |  | ||||||
| from django.contrib.auth.tokens import PasswordResetTokenGenerator | from django.contrib.auth.tokens import PasswordResetTokenGenerator | ||||||
| from django.contrib.auth.views import ( | from django.contrib.auth.views import ( | ||||||
|     password_change, password_change_done, password_reset, |     password_change, password_change_done, password_reset, | ||||||
| @@ -11,10 +10,9 @@ from django.utils.encoding import force_bytes, force_text | |||||||
| from django.utils.http import urlsafe_base64_encode | from django.utils.http import urlsafe_base64_encode | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @skipIfCustomUser |  | ||||||
| @override_settings( | @override_settings( | ||||||
|     PASSWORD_HASHERS=('django.contrib.auth.hashers.SHA1PasswordHasher',), |     PASSWORD_HASHERS=['django.contrib.auth.hashers.SHA1PasswordHasher'], | ||||||
|     ROOT_URLCONF='django.contrib.auth.tests.urls', |     ROOT_URLCONF='auth_tests.urls', | ||||||
| ) | ) | ||||||
| class AuthTemplateTests(TestCase): | class AuthTemplateTests(TestCase): | ||||||
| 
 | 
 | ||||||
| @@ -4,12 +4,10 @@ from datetime import date, timedelta | |||||||
| 
 | 
 | ||||||
| from django.conf import settings | from django.conf import settings | ||||||
| from django.contrib.auth.models import User | from django.contrib.auth.models import User | ||||||
| from django.contrib.auth.tests.utils import skipIfCustomUser |  | ||||||
| from django.contrib.auth.tokens import PasswordResetTokenGenerator | from django.contrib.auth.tokens import PasswordResetTokenGenerator | ||||||
| from django.test import TestCase | from django.test import TestCase | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @skipIfCustomUser |  | ||||||
| class TokenGeneratorTest(TestCase): | class TokenGeneratorTest(TestCase): | ||||||
| 
 | 
 | ||||||
|     def test_make_token(self): |     def test_make_token(self): | ||||||
| @@ -13,6 +13,8 @@ from django.contrib.auth.forms import ( | |||||||
|     AuthenticationForm, PasswordChangeForm, SetPasswordForm, |     AuthenticationForm, PasswordChangeForm, SetPasswordForm, | ||||||
| ) | ) | ||||||
| from django.contrib.auth.models import User | from django.contrib.auth.models import User | ||||||
|  | # Needed so model is installed when tests are run independently: | ||||||
|  | from django.contrib.auth.tests.custom_user import CustomUser  # NOQA | ||||||
| from django.contrib.auth.views import login as login_view, redirect_to_login | from django.contrib.auth.views import login as login_view, redirect_to_login | ||||||
| from django.contrib.sessions.middleware import SessionMiddleware | from django.contrib.sessions.middleware import SessionMiddleware | ||||||
| from django.contrib.sites.requests import RequestSite | from django.contrib.sites.requests import RequestSite | ||||||
| @@ -20,7 +22,9 @@ from django.core import mail | |||||||
| from django.core.urlresolvers import NoReverseMatch, reverse, reverse_lazy | from django.core.urlresolvers import NoReverseMatch, reverse, reverse_lazy | ||||||
| from django.http import HttpRequest, QueryDict | from django.http import HttpRequest, QueryDict | ||||||
| from django.middleware.csrf import CsrfViewMiddleware | from django.middleware.csrf import CsrfViewMiddleware | ||||||
| from django.test import TestCase, ignore_warnings, override_settings | from django.test import ( | ||||||
|  |     TestCase, ignore_warnings, modify_settings, override_settings, | ||||||
|  | ) | ||||||
| from django.test.utils import patch_logger | from django.test.utils import patch_logger | ||||||
| from django.utils.deprecation import RemovedInDjango20Warning | from django.utils.deprecation import RemovedInDjango20Warning | ||||||
| from django.utils.encoding import force_text | from django.utils.encoding import force_text | ||||||
| @@ -28,10 +32,7 @@ from django.utils.http import urlquote | |||||||
| from django.utils.six.moves.urllib.parse import ParseResult, urlparse | from django.utils.six.moves.urllib.parse import ParseResult, urlparse | ||||||
| from django.utils.translation import LANGUAGE_SESSION_KEY | from django.utils.translation import LANGUAGE_SESSION_KEY | ||||||
| 
 | 
 | ||||||
| # Needed so model is installed when tests are run independently: |  | ||||||
| from .custom_user import CustomUser  # NOQA |  | ||||||
| from .settings import AUTH_TEMPLATES | from .settings import AUTH_TEMPLATES | ||||||
| from .utils import skipIfCustomUser |  | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @override_settings( | @override_settings( | ||||||
| @@ -41,8 +42,8 @@ from .utils import skipIfCustomUser | |||||||
|     LANGUAGE_CODE='en', |     LANGUAGE_CODE='en', | ||||||
|     TEMPLATES=AUTH_TEMPLATES, |     TEMPLATES=AUTH_TEMPLATES, | ||||||
|     USE_TZ=False, |     USE_TZ=False, | ||||||
|     PASSWORD_HASHERS=('django.contrib.auth.hashers.SHA1PasswordHasher',), |     PASSWORD_HASHERS=['django.contrib.auth.hashers.SHA1PasswordHasher'], | ||||||
|     ROOT_URLCONF='django.contrib.auth.tests.urls', |     ROOT_URLCONF='auth_tests.urls', | ||||||
| ) | ) | ||||||
| class AuthViewsTestCase(TestCase): | class AuthViewsTestCase(TestCase): | ||||||
|     """ |     """ | ||||||
| @@ -86,7 +87,6 @@ class AuthViewsTestCase(TestCase): | |||||||
|                 self.fail("%r != %r (%s doesn't match)" % (url, expected, attr)) |                 self.fail("%r != %r (%s doesn't match)" % (url, expected, attr)) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @skipIfCustomUser |  | ||||||
| @override_settings(ROOT_URLCONF='django.contrib.auth.urls') | @override_settings(ROOT_URLCONF='django.contrib.auth.urls') | ||||||
| class AuthViewNamedURLTests(AuthViewsTestCase): | class AuthViewNamedURLTests(AuthViewsTestCase): | ||||||
| 
 | 
 | ||||||
| @@ -112,7 +112,6 @@ class AuthViewNamedURLTests(AuthViewsTestCase): | |||||||
|                 self.fail("Reversal of url named '%s' failed with NoReverseMatch" % name) |                 self.fail("Reversal of url named '%s' failed with NoReverseMatch" % name) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @skipIfCustomUser |  | ||||||
| class PasswordResetTest(AuthViewsTestCase): | class PasswordResetTest(AuthViewsTestCase): | ||||||
| 
 | 
 | ||||||
|     def test_email_not_found(self): |     def test_email_not_found(self): | ||||||
| @@ -355,7 +354,6 @@ class CustomUserPasswordResetTest(AuthViewsTestCase): | |||||||
|         self.assertContains(response, "Please enter your new password") |         self.assertContains(response, "Please enter your new password") | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @skipIfCustomUser |  | ||||||
| class ChangePasswordTest(AuthViewsTestCase): | class ChangePasswordTest(AuthViewsTestCase): | ||||||
| 
 | 
 | ||||||
|     def fail_login(self, password='password'): |     def fail_login(self, password='password'): | ||||||
| @@ -464,7 +462,6 @@ class SessionAuthenticationTests(AuthViewsTestCase): | |||||||
|         self.assertRedirects(response, '/password_change/done/') |         self.assertRedirects(response, '/password_change/done/') | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @skipIfCustomUser |  | ||||||
| class LoginTest(AuthViewsTestCase): | class LoginTest(AuthViewsTestCase): | ||||||
| 
 | 
 | ||||||
|     def test_current_site_in_context_after_login(self): |     def test_current_site_in_context_after_login(self): | ||||||
| @@ -614,7 +611,6 @@ class LoginTest(AuthViewsTestCase): | |||||||
|         self.assertNotEqual(original_session_key, self.client.session.session_key) |         self.assertNotEqual(original_session_key, self.client.session.session_key) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @skipIfCustomUser |  | ||||||
| class LoginURLSettings(AuthViewsTestCase): | class LoginURLSettings(AuthViewsTestCase): | ||||||
|     """Tests for settings.LOGIN_URL.""" |     """Tests for settings.LOGIN_URL.""" | ||||||
|     def assertLoginURLEquals(self, url, parse_qs=False): |     def assertLoginURLEquals(self, url, parse_qs=False): | ||||||
| @@ -657,7 +653,6 @@ class LoginURLSettings(AuthViewsTestCase): | |||||||
|         self.assertLoginURLEquals('/login/?next=/login_required/') |         self.assertLoginURLEquals('/login/?next=/login_required/') | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @skipIfCustomUser |  | ||||||
| class LoginRedirectUrlTest(AuthViewsTestCase): | class LoginRedirectUrlTest(AuthViewsTestCase): | ||||||
|     """Tests for settings.LOGIN_REDIRECT_URL.""" |     """Tests for settings.LOGIN_REDIRECT_URL.""" | ||||||
|     def assertLoginRedirectURLEqual(self, url): |     def assertLoginRedirectURLEqual(self, url): | ||||||
| @@ -696,7 +691,6 @@ class RedirectToLoginTests(AuthViewsTestCase): | |||||||
|         self.assertEqual(expected, login_redirect_response.url) |         self.assertEqual(expected, login_redirect_response.url) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @skipIfCustomUser |  | ||||||
| class LogoutTest(AuthViewsTestCase): | class LogoutTest(AuthViewsTestCase): | ||||||
| 
 | 
 | ||||||
|     def confirm_logged_out(self): |     def confirm_logged_out(self): | ||||||
| @@ -816,15 +810,14 @@ class LogoutTest(AuthViewsTestCase): | |||||||
|         self.assertEqual(self.client.session[LANGUAGE_SESSION_KEY], 'pl') |         self.assertEqual(self.client.session[LANGUAGE_SESSION_KEY], 'pl') | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @skipIfCustomUser |  | ||||||
| @override_settings( |  | ||||||
| # Redirect in test_user_change_password will fail if session auth hash | # Redirect in test_user_change_password will fail if session auth hash | ||||||
| # isn't updated after password change (#21649) | # isn't updated after password change (#21649) | ||||||
|     MIDDLEWARE_CLASSES=list(settings.MIDDLEWARE_CLASSES) + [ | @modify_settings(MIDDLEWARE_CLASSES={ | ||||||
|         'django.contrib.auth.middleware.SessionAuthenticationMiddleware' |     'append': 'django.contrib.auth.middleware.SessionAuthenticationMiddleware', | ||||||
|     ], | }) | ||||||
|     PASSWORD_HASHERS=('django.contrib.auth.hashers.SHA1PasswordHasher',), | @override_settings( | ||||||
|     ROOT_URLCONF='django.contrib.auth.tests.urls_admin', |     PASSWORD_HASHERS=['django.contrib.auth.hashers.SHA1PasswordHasher'], | ||||||
|  |     ROOT_URLCONF='auth_tests.urls_admin', | ||||||
| ) | ) | ||||||
| class ChangelistTests(AuthViewsTestCase): | class ChangelistTests(AuthViewsTestCase): | ||||||
| 
 | 
 | ||||||
		Reference in New Issue
	
	Block a user