[1.8.x] Moved contrib.auth tests out of contrib.
Backport of 2d7aca3da0
from master
This commit is contained in:
parent
44df17d53c
commit
e55d888b66
|
@ -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'
|
|
|
@ -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
|
# Redirect in test_user_change_password will fail if session auth hash
|
||||||
|
# isn't updated after password change (#21649)
|
||||||
|
@modify_settings(MIDDLEWARE_CLASSES={
|
||||||
|
'append': 'django.contrib.auth.middleware.SessionAuthenticationMiddleware',
|
||||||
|
})
|
||||||
@override_settings(
|
@override_settings(
|
||||||
# Redirect in test_user_change_password will fail if session auth hash
|
PASSWORD_HASHERS=['django.contrib.auth.hashers.SHA1PasswordHasher'],
|
||||||
# isn't updated after password change (#21649)
|
ROOT_URLCONF='auth_tests.urls_admin',
|
||||||
MIDDLEWARE_CLASSES=list(settings.MIDDLEWARE_CLASSES) + [
|
|
||||||
'django.contrib.auth.middleware.SessionAuthenticationMiddleware'
|
|
||||||
],
|
|
||||||
PASSWORD_HASHERS=('django.contrib.auth.hashers.SHA1PasswordHasher',),
|
|
||||||
ROOT_URLCONF='django.contrib.auth.tests.urls_admin',
|
|
||||||
)
|
)
|
||||||
class ChangelistTests(AuthViewsTestCase):
|
class ChangelistTests(AuthViewsTestCase):
|
||||||
|
|
Loading…
Reference in New Issue