test_forgottenpassword_views.py 3.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  1. from django.contrib.auth import get_user_model
  2. from django.core.urlresolvers import reverse
  3. from ..models import BAN_USERNAME, Ban
  4. from ..testutils import UserTestCase
  5. from ..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(
  21. check_type=BAN_USERNAME,
  22. banned_value='bob',
  23. user_message='Nope!',
  24. )
  25. password_token = make_password_change_token(test_user)
  26. response = self.client.get(
  27. reverse('misago:forgotten-password-change-form', kwargs={
  28. 'pk': test_user.pk,
  29. 'token': password_token,
  30. }))
  31. self.assertEqual(response.status_code, 403)
  32. self.assertIn('<p>Nope!</p>', response.content)
  33. def test_change_password_on_other_user(self):
  34. """change other user password errors"""
  35. User = get_user_model()
  36. test_user = User.objects.create_user('Bob', 'bob@test.com', 'Pass.123')
  37. password_token = make_password_change_token(test_user)
  38. self.login_user(self.get_authenticated_user())
  39. response = self.client.get(
  40. reverse('misago:forgotten-password-change-form', kwargs={
  41. 'pk': test_user.pk,
  42. 'token': password_token,
  43. }))
  44. self.assertEqual(response.status_code, 400)
  45. self.assertIn('your link has expired', response.content)
  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.assertEqual(response.status_code, 400)
  57. self.assertIn('your link is invalid', response.content)
  58. def test_change_password_form(self):
  59. """change user password form displays for valid token"""
  60. User = get_user_model()
  61. test_user = User.objects.create_user('Bob', 'bob@test.com', 'Pass.123')
  62. password_token = make_password_change_token(test_user)
  63. response = self.client.get(
  64. reverse('misago:forgotten-password-change-form', kwargs={
  65. 'pk': test_user.pk,
  66. 'token': password_token,
  67. }))
  68. self.assertEqual(response.status_code, 200)
  69. self.assertIn(password_token, response.content)