test_forgottenpassword_views.py 3.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. from django.contrib.auth import get_user_model
  2. from django.urls import reverse
  3. from misago.core.utils import encode_json_html
  4. from misago.users.models import Ban
  5. from misago.users.testutils import UserTestCase
  6. from misago.users.tokens import make_password_change_token
  7. UserModel = get_user_model()
  8. class ForgottenPasswordViewsTests(UserTestCase):
  9. def test_guest_request_view_returns_200(self):
  10. """request new password view returns 200 for guests"""
  11. response = self.client.get(reverse('misago:forgotten-password'))
  12. self.assertEqual(response.status_code, 200)
  13. def test_authenticated_request_view_returns_200(self):
  14. """request new password view returns 200 for authenticated"""
  15. self.login_user(self.get_authenticated_user())
  16. response = self.client.get(reverse('misago:forgotten-password'))
  17. self.assertEqual(response.status_code, 200)
  18. def test_change_password_on_banned(self):
  19. """change banned user password errors"""
  20. test_user = UserModel.objects.create_user('Bob', 'bob@test.com', 'Pass.123')
  21. Ban.objects.create(
  22. check_type=Ban.USERNAME,
  23. banned_value='bob',
  24. user_message='Nope!',
  25. )
  26. password_token = make_password_change_token(test_user)
  27. response = self.client.get(
  28. reverse(
  29. 'misago:forgotten-password-change-form',
  30. kwargs={
  31. 'pk': test_user.pk,
  32. 'token': password_token,
  33. },
  34. )
  35. )
  36. self.assertContains(response, encode_json_html("<p>Nope!</p>"), status_code=403)
  37. def test_change_password_on_other_user(self):
  38. """change other user password errors"""
  39. test_user = UserModel.objects.create_user('Bob', 'bob@test.com', 'Pass.123')
  40. password_token = make_password_change_token(test_user)
  41. self.login_user(self.get_authenticated_user())
  42. response = self.client.get(
  43. reverse(
  44. 'misago:forgotten-password-change-form',
  45. kwargs={
  46. 'pk': test_user.pk,
  47. 'token': password_token,
  48. },
  49. )
  50. )
  51. self.assertContains(response, 'your link has expired', status_code=400)
  52. def test_change_password_invalid_token(self):
  53. """invalid form token errors"""
  54. test_user = UserModel.objects.create_user('Bob', 'bob@test.com', 'Pass.123')
  55. response = self.client.get(
  56. reverse(
  57. 'misago:forgotten-password-change-form',
  58. kwargs={
  59. 'pk': test_user.pk,
  60. 'token': 'abcdfghqsads',
  61. },
  62. )
  63. )
  64. self.assertContains(response, 'your link is invalid', status_code=400)
  65. def test_change_password_form(self):
  66. """change user password form displays for valid token"""
  67. test_user = UserModel.objects.create_user('Bob', 'bob@test.com', 'Pass.123')
  68. password_token = make_password_change_token(test_user)
  69. response = self.client.get(
  70. reverse(
  71. 'misago:forgotten-password-change-form',
  72. kwargs={
  73. 'pk': test_user.pk,
  74. 'token': password_token,
  75. },
  76. )
  77. )
  78. self.assertContains(response, password_token)