2
0

test_basic.py 7.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179
  1. # -*- coding: utf-8 -*-
  2. from __future__ import unicode_literals
  3. import warnings
  4. from django.contrib.auth import get_user, get_user_model
  5. from django.contrib.auth.models import AnonymousUser, User
  6. from django.core.exceptions import ImproperlyConfigured
  7. from django.db import IntegrityError
  8. from django.http import HttpRequest
  9. from django.test import TestCase, override_settings
  10. from django.utils import translation
  11. from .models import CustomUser
  12. class BasicTestCase(TestCase):
  13. def test_user(self):
  14. "Check that users can be created and can set their password"
  15. u = User.objects.create_user('testuser', 'test@example.com', 'testpw')
  16. self.assertTrue(u.has_usable_password())
  17. self.assertFalse(u.check_password('bad'))
  18. self.assertTrue(u.check_password('testpw'))
  19. # Check we can manually set an unusable password
  20. u.set_unusable_password()
  21. u.save()
  22. self.assertFalse(u.check_password('testpw'))
  23. self.assertFalse(u.has_usable_password())
  24. u.set_password('testpw')
  25. self.assertTrue(u.check_password('testpw'))
  26. u.set_password(None)
  27. self.assertFalse(u.has_usable_password())
  28. # Check username getter
  29. self.assertEqual(u.get_username(), 'testuser')
  30. # Check authentication/permissions
  31. self.assertFalse(u.is_anonymous)
  32. self.assertTrue(u.is_authenticated)
  33. self.assertFalse(u.is_staff)
  34. self.assertTrue(u.is_active)
  35. self.assertFalse(u.is_superuser)
  36. # Check API-based user creation with no password
  37. u2 = User.objects.create_user('testuser2', 'test2@example.com')
  38. self.assertFalse(u2.has_usable_password())
  39. def test_unicode_username(self):
  40. User.objects.create_user('jörg')
  41. User.objects.create_user('Григорий')
  42. # Two equivalent unicode normalized usernames should be duplicates
  43. omega_username = 'iamtheΩ' # U+03A9 GREEK CAPITAL LETTER OMEGA
  44. ohm_username = 'iamtheΩ' # U+2126 OHM SIGN
  45. User.objects.create_user(ohm_username)
  46. with self.assertRaises(IntegrityError):
  47. User.objects.create_user(omega_username)
  48. def test_is_anonymous_authenticated_method_deprecation(self):
  49. deprecation_message = (
  50. 'Using user.is_authenticated() and user.is_anonymous() as a '
  51. 'method is deprecated. Remove the parentheses to use it as an '
  52. 'attribute.'
  53. )
  54. u = User.objects.create_user('testuser', 'test@example.com', 'testpw')
  55. # Backwards-compatibility callables
  56. with warnings.catch_warnings(record=True) as warns:
  57. warnings.simplefilter('always')
  58. self.assertFalse(u.is_anonymous())
  59. self.assertEqual(len(warns), 1)
  60. self.assertEqual(str(warns[0].message), deprecation_message)
  61. with warnings.catch_warnings(record=True) as warns:
  62. warnings.simplefilter('always')
  63. self.assertTrue(u.is_authenticated())
  64. self.assertEqual(len(warns), 1)
  65. self.assertEqual(str(warns[0].message), deprecation_message)
  66. def test_user_no_email(self):
  67. "Check that users can be created without an email"
  68. u = User.objects.create_user('testuser1')
  69. self.assertEqual(u.email, '')
  70. u2 = User.objects.create_user('testuser2', email='')
  71. self.assertEqual(u2.email, '')
  72. u3 = User.objects.create_user('testuser3', email=None)
  73. self.assertEqual(u3.email, '')
  74. def test_anonymous_user(self):
  75. "Check the properties of the anonymous user"
  76. a = AnonymousUser()
  77. self.assertIsNone(a.pk)
  78. self.assertEqual(a.username, '')
  79. self.assertEqual(a.get_username(), '')
  80. self.assertTrue(a.is_anonymous)
  81. self.assertFalse(a.is_authenticated)
  82. self.assertFalse(a.is_staff)
  83. self.assertFalse(a.is_active)
  84. self.assertFalse(a.is_superuser)
  85. self.assertEqual(a.groups.all().count(), 0)
  86. self.assertEqual(a.user_permissions.all().count(), 0)
  87. def test_anonymous_user_is_anonymous_authenticated_method_deprecation(self):
  88. a = AnonymousUser()
  89. deprecation_message = (
  90. 'Using user.is_authenticated() and user.is_anonymous() as a '
  91. 'method is deprecated. Remove the parentheses to use it as an '
  92. 'attribute.'
  93. )
  94. # Backwards-compatibility callables
  95. with warnings.catch_warnings(record=True) as warns:
  96. warnings.simplefilter('always') # prevent warnings from appearing as errors
  97. self.assertTrue(a.is_anonymous())
  98. self.assertEqual(len(warns), 1)
  99. self.assertEqual(str(warns[0].message), deprecation_message)
  100. with warnings.catch_warnings(record=True) as warns:
  101. warnings.simplefilter('always') # prevent warnings from appearing as errors
  102. self.assertFalse(a.is_authenticated())
  103. self.assertEqual(len(warns), 1)
  104. self.assertEqual(str(warns[0].message), deprecation_message)
  105. def test_superuser(self):
  106. "Check the creation and properties of a superuser"
  107. super = User.objects.create_superuser('super', 'super@example.com', 'super')
  108. self.assertTrue(super.is_superuser)
  109. self.assertTrue(super.is_active)
  110. self.assertTrue(super.is_staff)
  111. def test_get_user_model(self):
  112. "The current user model can be retrieved"
  113. self.assertEqual(get_user_model(), User)
  114. @override_settings(AUTH_USER_MODEL='auth_tests.CustomUser')
  115. def test_swappable_user(self):
  116. "The current user model can be swapped out for another"
  117. self.assertEqual(get_user_model(), CustomUser)
  118. with self.assertRaises(AttributeError):
  119. User.objects.all()
  120. @override_settings(AUTH_USER_MODEL='badsetting')
  121. def test_swappable_user_bad_setting(self):
  122. "The alternate user setting must point to something in the format app.model"
  123. with self.assertRaises(ImproperlyConfigured):
  124. get_user_model()
  125. @override_settings(AUTH_USER_MODEL='thismodel.doesntexist')
  126. def test_swappable_user_nonexistent_model(self):
  127. "The current user model must point to an installed model"
  128. with self.assertRaises(ImproperlyConfigured):
  129. get_user_model()
  130. def test_user_verbose_names_translatable(self):
  131. "Default User model verbose names are translatable (#19945)"
  132. with translation.override('en'):
  133. self.assertEqual(User._meta.verbose_name, 'user')
  134. self.assertEqual(User._meta.verbose_name_plural, 'users')
  135. with translation.override('es'):
  136. self.assertEqual(User._meta.verbose_name, 'usuario')
  137. self.assertEqual(User._meta.verbose_name_plural, 'usuarios')
  138. class TestGetUser(TestCase):
  139. def test_get_user_anonymous(self):
  140. request = HttpRequest()
  141. request.session = self.client.session
  142. user = get_user(request)
  143. self.assertIsInstance(user, AnonymousUser)
  144. def test_get_user(self):
  145. created_user = User.objects.create_user('testuser', 'test@example.com', 'testpw')
  146. self.client.login(username='testuser', password='testpw')
  147. request = HttpRequest()
  148. request.session = self.client.session
  149. user = get_user(request)
  150. self.assertIsInstance(user, User)
  151. self.assertEqual(user.username, created_user.username)