test_basic.py 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  1. from django.contrib.auth import get_user, get_user_model
  2. from django.contrib.auth.models import AnonymousUser, User
  3. from django.core.exceptions import ImproperlyConfigured
  4. from django.db import IntegrityError
  5. from django.http import HttpRequest
  6. from django.test import TestCase, override_settings
  7. from django.utils import translation
  8. from .models import CustomUser
  9. class BasicTestCase(TestCase):
  10. def test_user(self):
  11. "Users can be created and can set their password"
  12. u = User.objects.create_user('testuser', 'test@example.com', 'testpw')
  13. self.assertTrue(u.has_usable_password())
  14. self.assertFalse(u.check_password('bad'))
  15. self.assertTrue(u.check_password('testpw'))
  16. # Check we can manually set an unusable password
  17. u.set_unusable_password()
  18. u.save()
  19. self.assertFalse(u.check_password('testpw'))
  20. self.assertFalse(u.has_usable_password())
  21. u.set_password('testpw')
  22. self.assertTrue(u.check_password('testpw'))
  23. u.set_password(None)
  24. self.assertFalse(u.has_usable_password())
  25. # Check username getter
  26. self.assertEqual(u.get_username(), 'testuser')
  27. # Check authentication/permissions
  28. self.assertFalse(u.is_anonymous)
  29. self.assertTrue(u.is_authenticated)
  30. self.assertFalse(u.is_staff)
  31. self.assertTrue(u.is_active)
  32. self.assertFalse(u.is_superuser)
  33. # Check API-based user creation with no password
  34. u2 = User.objects.create_user('testuser2', 'test2@example.com')
  35. self.assertFalse(u2.has_usable_password())
  36. def test_unicode_username(self):
  37. User.objects.create_user('jörg')
  38. User.objects.create_user('Григорий')
  39. # Two equivalent unicode normalized usernames should be duplicates
  40. omega_username = 'iamtheΩ' # U+03A9 GREEK CAPITAL LETTER OMEGA
  41. ohm_username = 'iamtheΩ' # U+2126 OHM SIGN
  42. User.objects.create_user(ohm_username)
  43. with self.assertRaises(IntegrityError):
  44. User.objects.create_user(omega_username)
  45. def test_user_no_email(self):
  46. "Users can be created without an email"
  47. u = User.objects.create_user('testuser1')
  48. self.assertEqual(u.email, '')
  49. u2 = User.objects.create_user('testuser2', email='')
  50. self.assertEqual(u2.email, '')
  51. u3 = User.objects.create_user('testuser3', email=None)
  52. self.assertEqual(u3.email, '')
  53. def test_anonymous_user(self):
  54. "Check the properties of the anonymous user"
  55. a = AnonymousUser()
  56. self.assertIsNone(a.pk)
  57. self.assertEqual(a.username, '')
  58. self.assertEqual(a.get_username(), '')
  59. self.assertTrue(a.is_anonymous)
  60. self.assertFalse(a.is_authenticated)
  61. self.assertFalse(a.is_staff)
  62. self.assertFalse(a.is_active)
  63. self.assertFalse(a.is_superuser)
  64. self.assertEqual(a.groups.all().count(), 0)
  65. self.assertEqual(a.user_permissions.all().count(), 0)
  66. def test_superuser(self):
  67. "Check the creation and properties of a superuser"
  68. super = User.objects.create_superuser('super', 'super@example.com', 'super')
  69. self.assertTrue(super.is_superuser)
  70. self.assertTrue(super.is_active)
  71. self.assertTrue(super.is_staff)
  72. def test_get_user_model(self):
  73. "The current user model can be retrieved"
  74. self.assertEqual(get_user_model(), User)
  75. @override_settings(AUTH_USER_MODEL='auth_tests.CustomUser')
  76. def test_swappable_user(self):
  77. "The current user model can be swapped out for another"
  78. self.assertEqual(get_user_model(), CustomUser)
  79. with self.assertRaises(AttributeError):
  80. User.objects.all()
  81. @override_settings(AUTH_USER_MODEL='badsetting')
  82. def test_swappable_user_bad_setting(self):
  83. "The alternate user setting must point to something in the format app.model"
  84. with self.assertRaises(ImproperlyConfigured):
  85. get_user_model()
  86. @override_settings(AUTH_USER_MODEL='thismodel.doesntexist')
  87. def test_swappable_user_nonexistent_model(self):
  88. "The current user model must point to an installed model"
  89. with self.assertRaises(ImproperlyConfigured):
  90. get_user_model()
  91. def test_user_verbose_names_translatable(self):
  92. "Default User model verbose names are translatable (#19945)"
  93. with translation.override('en'):
  94. self.assertEqual(User._meta.verbose_name, 'user')
  95. self.assertEqual(User._meta.verbose_name_plural, 'users')
  96. with translation.override('es'):
  97. self.assertEqual(User._meta.verbose_name, 'usuario')
  98. self.assertEqual(User._meta.verbose_name_plural, 'usuarios')
  99. class TestGetUser(TestCase):
  100. def test_get_user_anonymous(self):
  101. request = HttpRequest()
  102. request.session = self.client.session
  103. user = get_user(request)
  104. self.assertIsInstance(user, AnonymousUser)
  105. def test_get_user(self):
  106. created_user = User.objects.create_user('testuser', 'test@example.com', 'testpw')
  107. self.client.login(username='testuser', password='testpw')
  108. request = HttpRequest()
  109. request.session = self.client.session
  110. user = get_user(request)
  111. self.assertIsInstance(user, User)
  112. self.assertEqual(user.username, created_user.username)