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

[1.8.x] Moved contrib.auth tests out of contrib.

Backport of 2d7aca3da0 from master
This commit is contained in:
Tim Graham
2015-02-10 09:17:08 -05:00
parent 44df17d53c
commit e55d888b66
44 changed files with 54 additions and 126 deletions

View File

@@ -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 *

View File

@@ -1 +0,0 @@
# The password for the fixture data users is 'password'

View File

@@ -0,0 +1 @@
# The password for the fixture data users is 'password'

View File

@@ -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):

View File

@@ -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'):

View File

@@ -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
) )

View File

@@ -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

View File

@@ -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,

View File

@@ -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

View File

@@ -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'])

View File

@@ -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(

View File

@@ -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

View File

@@ -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'

View File

@@ -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']

View File

@@ -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):

View File

@@ -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):

View File

@@ -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):