test_user_changepassword_api.py 3.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. from django.core import mail
  2. from django.urls import reverse
  3. from misago.users.testutils import AuthenticatedUserTestCase
  4. class UserChangePasswordTests(AuthenticatedUserTestCase):
  5. """
  6. tests for user change password RPC (/api/users/1/change-password/)
  7. """
  8. def setUp(self):
  9. super(UserChangePasswordTests, self).setUp()
  10. self.link = '/api/users/%s/change-password/' % 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_empty_input(self):
  16. """api errors correctly for empty input"""
  17. response = self.client.post(self.link, data={})
  18. self.assertEqual(response.status_code, 400)
  19. self.assertEqual(
  20. response.json(), {
  21. 'new_password': ["This field is required."],
  22. 'password': ["This field is required."],
  23. }
  24. )
  25. def test_invalid_password(self):
  26. """api errors correctly for invalid password"""
  27. response = self.client.post(
  28. self.link, data={'new_password': 'N3wP@55w0rd',
  29. 'password': 'Lor3mIpsum'}
  30. )
  31. self.assertEqual(response.status_code, 400)
  32. self.assertEqual(response.json(), {
  33. 'password': ["Entered password is invalid."],
  34. })
  35. def test_blank_input(self):
  36. """api errors correctly for blank input"""
  37. response = self.client.post(
  38. self.link, data={'new_password': '',
  39. 'password': self.USER_PASSWORD}
  40. )
  41. self.assertEqual(response.status_code, 400)
  42. self.assertEqual(response.json(), {
  43. 'new_password': ["This field may not be blank."],
  44. })
  45. def test_short_new_pasword(self):
  46. """api errors correctly for short new password"""
  47. response = self.client.post(
  48. self.link, data={'new_password': 'n',
  49. 'password': self.USER_PASSWORD}
  50. )
  51. self.assertEqual(response.status_code, 400)
  52. self.assertEqual(
  53. response.json(), {
  54. 'new_password':
  55. ["This password is too short. It must contain at least 7 characters."],
  56. }
  57. )
  58. def test_change_password(self):
  59. """api allows users to change their passwords"""
  60. new_password = 'N3wP@55w0rd'
  61. response = self.client.post(
  62. self.link, data={'new_password': new_password,
  63. 'password': self.USER_PASSWORD}
  64. )
  65. self.assertEqual(response.status_code, 200)
  66. self.assertIn('Confirm password change', mail.outbox[0].subject)
  67. for line in [l.strip() for l in mail.outbox[0].body.splitlines()]:
  68. if line.startswith('http://'):
  69. token = line.rstrip('/').split('/')[-1]
  70. break
  71. else:
  72. self.fail("E-mail sent didn't contain confirmation url")
  73. response = self.client.get(
  74. reverse('misago:options-confirm-password-change', kwargs={'token': token})
  75. )
  76. self.assertEqual(response.status_code, 200)
  77. self.reload_user()
  78. self.assertTrue(self.user.check_password(new_password))