|
@@ -1,5 +1,6 @@
|
|
|
from django.contrib.auth import get_user_model
|
|
|
from django.core import mail
|
|
|
+from django.urls import reverse
|
|
|
|
|
|
from misago.users.testutils import AuthenticatedUserTestCase
|
|
|
|
|
@@ -17,21 +18,19 @@ class UserChangePasswordTests(AuthenticatedUserTestCase):
|
|
|
response = self.client.get(self.link)
|
|
|
self.assertEqual(response.status_code, 405)
|
|
|
|
|
|
- def test_change_password(self):
|
|
|
- """api allows users to change their passwords"""
|
|
|
- response = self.client.post(self.link, data={
|
|
|
- 'new_password': 'N3wP@55w0rd',
|
|
|
- 'password': self.USER_PASSWORD
|
|
|
- })
|
|
|
- self.assertEqual(response.status_code, 200)
|
|
|
+ def test_empty_input(self):
|
|
|
+ """api errors correctly for empty input"""
|
|
|
+ response = self.client.post(self.link, data={})
|
|
|
|
|
|
- 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")
|
|
|
+ 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"""
|
|
@@ -39,18 +38,65 @@ class UserChangePasswordTests(AuthenticatedUserTestCase):
|
|
|
'new_password': 'N3wP@55w0rd',
|
|
|
'password': 'Lor3mIpsum'
|
|
|
})
|
|
|
- self.assertContains(response, 'password is invalid', status_code=400)
|
|
|
|
|
|
- def test_invalid_input(self):
|
|
|
- """api errors correctly for invalid input"""
|
|
|
+ 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.assertContains(response, 'new_password":["This field is required', status_code=400)
|
|
|
|
|
|
+ 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.assertContains(response, 'password is too short', status_code=400)
|
|
|
+
|
|
|
+ self.assertEqual(response.status_code, 400)
|
|
|
+ self.assertEqual(response.json(), {
|
|
|
+ 'new_password': [
|
|
|
+ "This password is too short. It must contain at least 7 characters."
|
|
|
+ ],
|
|
|
+ })
|
|
|
+
|
|
|
+ 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))
|