test_options_views.py 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  1. from django.core import mail
  2. from django.urls import reverse
  3. from misago.users.testutils import AuthenticatedUserTestCase
  4. class OptionsViewsTests(AuthenticatedUserTestCase):
  5. def test_lander_view_returns_200(self):
  6. """/options has no show stoppers"""
  7. response = self.client.get(reverse('misago:options'))
  8. self.assertEqual(response.status_code, 200)
  9. def test_form_view_returns_200(self):
  10. """/options/some-form has no show stoppers"""
  11. response = self.client.get(
  12. reverse('misago:options-form', kwargs={'form_name': 'some-fake-form'})
  13. )
  14. self.assertEqual(response.status_code, 200)
  15. class ConfirmChangeEmailTests(AuthenticatedUserTestCase):
  16. def setUp(self):
  17. super(ConfirmChangeEmailTests, self).setUp()
  18. link = '/api/users/%s/change-email/' % self.user.pk
  19. response = self.client.post(
  20. link, data={'new_email': 'n3w@email.com',
  21. 'password': self.USER_PASSWORD}
  22. )
  23. self.assertEqual(response.status_code, 200)
  24. for line in [l.strip() for l in mail.outbox[0].body.splitlines()]:
  25. if line.startswith('http://'):
  26. self.link = line.strip()
  27. break
  28. def test_invalid_token(self):
  29. """invalid token is rejected"""
  30. response = self.client.get(
  31. reverse('misago:options-confirm-email-change', kwargs={'token': 'invalid'})
  32. )
  33. self.assertContains(response, "Change confirmation link is invalid.", status_code=400)
  34. def test_change_email(self):
  35. """valid token changes email"""
  36. response = self.client.get(self.link)
  37. self.assertContains(response, "your e-mail has been changed")
  38. self.reload_user()
  39. self.assertEqual(self.user.email, 'n3w@email.com')
  40. class ConfirmChangePasswordTests(AuthenticatedUserTestCase):
  41. def setUp(self):
  42. super(ConfirmChangePasswordTests, self).setUp()
  43. link = '/api/users/%s/change-password/' % self.user.pk
  44. response = self.client.post(
  45. link, data={'new_password': 'n3wp4ssword',
  46. 'password': self.USER_PASSWORD}
  47. )
  48. self.assertEqual(response.status_code, 200)
  49. for line in [l.strip() for l in mail.outbox[0].body.splitlines()]:
  50. if line.startswith('http://'):
  51. self.link = line.strip()
  52. break
  53. def test_invalid_token(self):
  54. """invalid token is rejected"""
  55. response = self.client.get(
  56. reverse('misago:options-confirm-password-change', kwargs={'token': 'invalid'})
  57. )
  58. self.assertContains(response, "Change confirmation link is invalid.", status_code=400)
  59. def test_change_password(self):
  60. """valid token changes password"""
  61. response = self.client.get(self.link)
  62. self.assertContains(response, "your password has been changed")
  63. self.reload_user()
  64. self.assertFalse(self.user.check_password(self.USER_PASSWORD))
  65. self.assertTrue(self.user.check_password('n3wp4ssword'))