test_user_create_api.py 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132
  1. from django.contrib.auth import get_user_model
  2. from django.core import mail
  3. from django.urls import reverse
  4. from misago.conf import settings
  5. from ..models import Online
  6. from ..testutils import UserTestCase
  7. class UserCreateTests(UserTestCase):
  8. """
  9. tests for new user registration (POST to /api/users/)
  10. """
  11. def setUp(self):
  12. super(UserCreateTests, self).setUp()
  13. self.api_link = '/api/users/'
  14. def test_empty_request(self):
  15. """empty request errors with code 400"""
  16. response = self.client.post(self.api_link)
  17. self.assertEqual(response.status_code, 400)
  18. def test_authenticated_request(self):
  19. """authentiated user request errors with code 403"""
  20. self.login_user(self.get_authenticated_user())
  21. response = self.client.post(self.api_link)
  22. self.assertEqual(response.status_code, 403)
  23. def test_registration_off_request(self):
  24. """registrations off request errors with code 403"""
  25. settings.override_setting('account_activation', 'closed')
  26. response = self.client.post(self.api_link)
  27. self.assertContains(response, 'closed', status_code=403)
  28. def test_registration_validates_password(self):
  29. """api uses django's validate_password to validate registrations"""
  30. response = self.client.post(self.api_link, data={
  31. 'username': 'Bob',
  32. 'email': 'l.o.r.e.m.i.p.s.u.m@gmail.com',
  33. 'password': '123'
  34. })
  35. self.assertContains(response, "password is too short", status_code=400)
  36. self.assertContains(response, "password is entirely numeric", status_code=400)
  37. self.assertContains(response, "email is not allowed", status_code=400)
  38. def test_registration_validates_password_similiarity(self):
  39. """api uses validate_password to validate registrations"""
  40. response = self.client.post(self.api_link, data={
  41. 'username': 'BobBoberson',
  42. 'email': 'l.o.r.e.m.i.p.s.u.m@gmail.com',
  43. 'password': 'BobBoberson'
  44. })
  45. self.assertContains(response, "password is too similar to the username", status_code=400)
  46. def test_registration_calls_validate_new_registration(self):
  47. """api uses validate_new_registration to validate registrations"""
  48. response = self.client.post(self.api_link, data={
  49. 'username': 'Bob',
  50. 'email': 'l.o.r.e.m.i.p.s.u.m@gmail.com',
  51. 'password': 'pas123'
  52. })
  53. self.assertContains(response, "email is not allowed", status_code=400)
  54. def test_registration_creates_active_user(self):
  55. """api creates active and signed in user on POST"""
  56. settings.override_setting('account_activation', 'none')
  57. response = self.client.post(self.api_link, data={
  58. 'username': 'Bob',
  59. 'email': 'bob@bob.com',
  60. 'password': 'pass123'
  61. })
  62. self.assertContains(response, 'active')
  63. self.assertContains(response, 'Bob')
  64. self.assertContains(response, 'bob@bob.com')
  65. User = get_user_model()
  66. User.objects.get_by_username('Bob')
  67. test_user = User.objects.get_by_email('bob@bob.com')
  68. self.assertEqual(Online.objects.filter(user=test_user).count(), 1)
  69. response = self.client.get(reverse('misago:index'))
  70. self.assertContains(response, 'Bob')
  71. self.assertIn('Welcome', mail.outbox[0].subject)
  72. def test_registration_creates_inactive_user(self):
  73. """api creates inactive user on POST"""
  74. settings.override_setting('account_activation', 'user')
  75. response = self.client.post(self.api_link, data={
  76. 'username': 'Bob',
  77. 'email': 'bob@bob.com',
  78. 'password': 'pass123'
  79. })
  80. self.assertContains(response, 'user')
  81. self.assertContains(response, 'Bob')
  82. self.assertContains(response, 'bob@bob.com')
  83. User = get_user_model()
  84. User.objects.get_by_username('Bob')
  85. User.objects.get_by_email('bob@bob.com')
  86. self.assertIn('Welcome', mail.outbox[0].subject)
  87. def test_registration_creates_admin_activated_user(self):
  88. """api creates admin activated user on POST"""
  89. settings.override_setting('account_activation', 'admin')
  90. response = self.client.post(self.api_link, data={
  91. 'username': 'Bob',
  92. 'email': 'bob@bob.com',
  93. 'password': 'pass123'
  94. })
  95. self.assertContains(response, 'admin')
  96. self.assertContains(response, 'Bob')
  97. self.assertContains(response, 'bob@bob.com')
  98. User = get_user_model()
  99. User.objects.get_by_username('Bob')
  100. User.objects.get_by_email('bob@bob.com')
  101. self.assertIn('Welcome', mail.outbox[0].subject)