123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177 |
- from django.core import mail
- from django.urls import reverse
- from ...conf.test import override_dynamic_settings
- from ..test import AuthenticatedUserTestCase
- class UserChangePasswordTests(AuthenticatedUserTestCase):
- """tests for user change password RPC (/api/users/1/change-password/)"""
- def setUp(self):
- super().setUp()
- self.link = "/api/users/%s/change-password/" % self.user.pk
- def test_unsupported_methods(self):
- """api isn't supporting GET"""
- response = self.client.get(self.link)
- self.assertEqual(response.status_code, 405)
- def test_empty_input(self):
- """api errors correctly for empty input"""
- response = self.client.post(self.link, data={})
- self.assertEqual(response.status_code, 400)
- self.assertEqual(
- response.json(),
- {
- "new_password": ["This field is required."],
- "password": ["This field is required."],
- },
- )
- def test_invalid_password(self):
- """api errors correctly for invalid password"""
- response = self.client.post(
- self.link, data={"new_password": "N3wP@55w0rd", "password": "Lor3mIpsum"}
- )
- self.assertEqual(response.status_code, 400)
- self.assertEqual(
- response.json(), {"password": ["Entered password is invalid."]}
- )
- def test_blank_input(self):
- """api errors correctly for blank input"""
- response = self.client.post(
- self.link, data={"new_password": "", "password": self.USER_PASSWORD}
- )
- self.assertEqual(response.status_code, 400)
- self.assertEqual(
- response.json(), {"new_password": ["This field may not be blank."]}
- )
- def test_short_new_pasword(self):
- """api errors correctly for short new password"""
- response = self.client.post(
- self.link, data={"new_password": "n", "password": self.USER_PASSWORD}
- )
- self.assertEqual(response.status_code, 400)
- self.assertEqual(
- response.json(),
- {
- "new_password": [
- "This password is too short. It must contain at least 7 characters."
- ]
- },
- )
- @override_dynamic_settings(forum_address="http://test.com/")
- def test_change_password(self):
- """api allows users to change their passwords"""
- new_password = "N3wP@55w0rd"
- response = self.client.post(
- self.link,
- data={"new_password": new_password, "password": self.USER_PASSWORD},
- )
- self.assertEqual(response.status_code, 200)
- self.assertIn("Confirm password change", mail.outbox[0].subject)
- for line in [l.strip() for l in mail.outbox[0].body.splitlines()]:
- if line.startswith("http://"):
- token = line.rstrip("/").split("/")[-1]
- break
- else:
- self.fail("E-mail sent didn't contain confirmation url")
- response = self.client.get(
- reverse("misago:options-confirm-password-change", kwargs={"token": token})
- )
- self.assertEqual(response.status_code, 200)
- self.reload_user()
- self.assertTrue(self.user.check_password(new_password))
- @override_dynamic_settings(forum_address="http://test.com/")
- def test_change_password_with_whitespaces(self):
- """api handles users with whitespaces around their passwords"""
- old_password = " old password "
- new_password = " N3wP@55w0rd "
- self.user.set_password(old_password)
- self.user.save()
- self.login_user(self.user)
- response = self.client.post(
- self.link, data={"new_password": new_password, "password": old_password}
- )
- self.assertEqual(response.status_code, 200)
- self.assertIn("Confirm password change", mail.outbox[0].subject)
- for line in [l.strip() for l in mail.outbox[0].body.splitlines()]:
- if line.startswith("http://"):
- token = line.rstrip("/").split("/")[-1]
- break
- else:
- self.fail("E-mail sent didn't contain confirmation url")
- response = self.client.get(
- reverse("misago:options-confirm-password-change", kwargs={"token": token})
- )
- self.assertEqual(response.status_code, 200)
- self.reload_user()
- self.assertTrue(self.user.check_password(new_password))
- @override_dynamic_settings(
- enable_oauth2_client=True,
- oauth2_provider="Lorem",
- )
- def test_change_password_api_returns_403_if_oauth_is_enabled(self):
- new_password = " N3wP@55w0rd "
- self.login_user(self.user)
- response = self.client.post(
- self.link,
- data={"new_password": new_password, "password": self.USER_PASSWORD},
- )
- self.assertEqual(response.status_code, 403)
- self.assertEqual(len(mail.outbox), 0)
- @override_dynamic_settings(forum_address="http://test.com/")
- def test_confirm_change_password_view_returns_403_if_oauth_is_enabled(self):
- new_password = " N3wP@55w0rd "
- self.login_user(self.user)
- response = self.client.post(
- self.link,
- data={"new_password": new_password, "password": self.USER_PASSWORD},
- )
- self.assertEqual(response.status_code, 200)
- self.assertIn("Confirm password change", mail.outbox[0].subject)
- for line in [l.strip() for l in mail.outbox[0].body.splitlines()]:
- if line.startswith("http://"):
- token = line.rstrip("/").split("/")[-1]
- break
- else:
- self.fail("E-mail sent didn't contain confirmation url")
- with override_dynamic_settings(
- enable_oauth2_client=True, oauth2_provider="Lorem"
- ):
- response = self.client.get(
- reverse(
- "misago:options-confirm-password-change", kwargs={"token": token}
- )
- )
- self.assertEqual(response.status_code, 403)
|