test_user_changepassword_api.py 3.3 KB

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