test_forgottenpassword_views.py 3.2 KB

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