test_user_changepassword_api.py 3.2 KB

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