test_user_changeemail_api.py 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115
  1. from django.contrib.auth import get_user_model
  2. from django.core import mail
  3. from misago.users.testutils import AuthenticatedUserTestCase
  4. class UserChangeEmailTests(AuthenticatedUserTestCase):
  5. """
  6. tests for user change email RPC (/api/users/1/change-email/)
  7. """
  8. def setUp(self):
  9. super(UserChangeEmailTests, self).setUp()
  10. self.link = '/api/users/%s/change-email/' % self.user.pk
  11. def test_unsupported_methods(self):
  12. """api isn't supporting GET"""
  13. response = self.client.get(self.link)
  14. self.assertEqual(response.status_code, 405)
  15. def test_change_email(self):
  16. """api allows users to change their e-mail addresses"""
  17. response = self.client.post(self.link, data={
  18. 'new_email': 'new@email.com',
  19. 'password': self.USER_PASSWORD
  20. })
  21. self.assertEqual(response.status_code, 200)
  22. self.assertIn('Confirm e-mail change', mail.outbox[0].subject)
  23. for line in [l.strip() for l in mail.outbox[0].body.splitlines()]:
  24. if line.startswith('http://'):
  25. token = line.rstrip('/').split('/')[-1]
  26. break
  27. else:
  28. self.fail("E-mail sent didn't contain confirmation url")
  29. response = self.client.post(self.link, data={'token': token})
  30. self.assertEqual(response.status_code, 200)
  31. self.reload_user()
  32. self.assertEqual(self.user.email, 'new@email.com')
  33. def test_invalid_password(self):
  34. """api errors correctly for invalid password"""
  35. response = self.client.post(self.link, data={
  36. 'new_email': 'new@email.com',
  37. 'password': 'Lor3mIpsum'
  38. })
  39. self.assertEqual(response.status_code, 400)
  40. self.assertIn('password is invalid', response.content)
  41. def test_invalid_input(self):
  42. """api errors correctly for invalid input"""
  43. response = self.client.post(self.link, data={
  44. 'new_email': '',
  45. 'password': self.USER_PASSWORD
  46. })
  47. self.assertEqual(response.status_code, 400)
  48. self.assertIn('enter new e-mail', response.content)
  49. response = self.client.post(self.link, data={
  50. 'new_email': 'newmail',
  51. 'password': self.USER_PASSWORD
  52. })
  53. self.assertEqual(response.status_code, 400)
  54. self.assertIn('valid email address', response.content)
  55. def test_email_taken(self):
  56. """api validates email usage"""
  57. User = get_user_model()
  58. User.objects.create_user('BobBoberson', 'new@email.com', 'Pass.123')
  59. response = self.client.post(self.link, data={
  60. 'new_email': 'new@email.com',
  61. 'password': self.USER_PASSWORD
  62. })
  63. self.assertEqual(response.status_code, 400)
  64. self.assertIn('not available', response.content)
  65. def test_invalid_token(self):
  66. """api handles invalid token"""
  67. response = self.client.post(self.link, data={
  68. 'new_email': 'new@email.com',
  69. 'password': self.USER_PASSWORD
  70. })
  71. self.assertEqual(response.status_code, 200)
  72. response = self.client.post(self.link, data={'token': 'invalid-token'})
  73. self.assertEqual(response.status_code, 400)
  74. self.reload_user()
  75. self.assertTrue(self.user.email != 'new@email.com')
  76. def test_expired_token(self):
  77. """api handles invalid token"""
  78. response = self.client.post(self.link, data={
  79. 'new_email': 'new@email.com',
  80. 'password': self.USER_PASSWORD
  81. })
  82. self.assertEqual(response.status_code, 200)
  83. for line in [l.strip() for l in mail.outbox[0].body.splitlines()]:
  84. if line.startswith('http://'):
  85. token = line.rstrip('/').split('/')[-1]
  86. break
  87. else:
  88. self.fail("E-mail sent didn't contain confirmation url")
  89. self.user.set_password('L0lN0p3!')
  90. self.user.save()
  91. self.login_user(self.user, 'L0lN0p3!')
  92. response = self.client.post(self.link, data={'token': 'invalid-token'})
  93. self.assertEqual(response.status_code, 400)
  94. self.reload_user()
  95. self.assertTrue(self.user.email != 'new@email.com')