test_forgottenpassword_views.py 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  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 ..models import BAN_USERNAME, Ban
  5. from ..testutils import UserTestCase
  6. from ..tokens import make_password_change_token
  7. class ForgottenPasswordViewsTests(UserTestCase):
  8. def test_guest_request_view_returns_200(self):
  9. """request new password view returns 200 for guests"""
  10. response = self.client.get(reverse('misago:forgotten-password'))
  11. self.assertEqual(response.status_code, 200)
  12. def test_authenticated_request_view_returns_200(self):
  13. """request new password view returns 200 for authenticated"""
  14. self.login_user(self.get_authenticated_user())
  15. response = self.client.get(reverse('misago:forgotten-password'))
  16. self.assertEqual(response.status_code, 200)
  17. def test_change_password_on_banned(self):
  18. """change banned user password errors"""
  19. User = get_user_model()
  20. test_user = User.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('misago:forgotten-password-change-form', kwargs={
  29. 'pk': test_user.pk,
  30. 'token': password_token,
  31. }))
  32. self.assertContains(
  33. response, encode_json_html("<p>Nope!</p>"), status_code=403)
  34. def test_change_password_on_other_user(self):
  35. """change other user password errors"""
  36. User = get_user_model()
  37. test_user = User.objects.create_user('Bob', 'bob@test.com', 'Pass.123')
  38. password_token = make_password_change_token(test_user)
  39. self.login_user(self.get_authenticated_user())
  40. response = self.client.get(
  41. reverse('misago:forgotten-password-change-form', kwargs={
  42. 'pk': test_user.pk,
  43. 'token': password_token,
  44. }))
  45. self.assertContains(response, 'your link has expired', status_code=400)
  46. def test_change_password_invalid_token(self):
  47. """invalid form token errors"""
  48. User = get_user_model()
  49. test_user = User.objects.create_user('Bob', 'bob@test.com', 'Pass.123')
  50. password_token = make_password_change_token(test_user)
  51. response = self.client.get(
  52. reverse('misago:forgotten-password-change-form', kwargs={
  53. 'pk': test_user.pk,
  54. 'token': 'abcdfghqsads',
  55. }))
  56. self.assertContains(response, 'your link is invalid', status_code=400)
  57. def test_change_password_form(self):
  58. """change user password form displays for valid token"""
  59. User = get_user_model()
  60. test_user = User.objects.create_user('Bob', 'bob@test.com', 'Pass.123')
  61. password_token = make_password_change_token(test_user)
  62. response = self.client.get(
  63. reverse('misago:forgotten-password-change-form', kwargs={
  64. 'pk': test_user.pk,
  65. 'token': password_token,
  66. }))
  67. self.assertContains(response, password_token)