diff --git a/apps/account/tests/tests_common.py b/apps/account/tests/tests_common.py index 0992b930..05185952 100644 --- a/apps/account/tests/tests_common.py +++ b/apps/account/tests/tests_common.py @@ -7,21 +7,19 @@ from django.urls import reverse class AccountUserTests(APITestCase): - - url = reverse('web:account:user-retrieve-update') - def setUp(self): self.data = get_tokens_for_user() def test_user_url(self): - response = self.client.get(self.url) + url = reverse('web:account:user-retrieve-update') + response = self.client.get(url) self.assertEqual(response.status_code, status.HTTP_401_UNAUTHORIZED) self.client.cookies = SimpleCookie( {'access_token': self.data['tokens'].get('access_token'), 'refresh_token': self.data['tokens'].get('access_token')}) - response = self.client.get(self.url) + response = self.client.get(url) self.assertEqual(response.status_code, status.HTTP_200_OK) data = { @@ -33,19 +31,16 @@ class AccountUserTests(APITestCase): "email": "sedragurdatest@desoz.com", "newsletter": self.data["newsletter"] } - response = self.client.patch(self.url, data=data, format='json') + response = self.client.patch(url, data=data, format='json') self.assertEqual(response.status_code, status.HTTP_200_OK) data["email"] = "sedragurdatest2@desoz.com" - response = self.client.put(self.url, data=data, format='json') + response = self.client.put(url, data=data, format='json') self.assertEqual(response.status_code, status.HTTP_200_OK) class AccountChangePasswordTests(APITestCase): - - url = reverse('web:account:change-password') - def setUp(self): self.data = get_tokens_for_user() @@ -54,15 +49,16 @@ class AccountChangePasswordTests(APITestCase): "old_password": self.data["password"], "password": "new password" } + url = reverse('web:account:change-password') - response = self.client.patch(self.url, data=data, format='json') + response = self.client.patch(url, data=data, format='json') self.assertEqual(response.status_code, status.HTTP_401_UNAUTHORIZED) self.client.cookies = SimpleCookie( {'access_token': self.data['tokens'].get('access_token'), 'refresh_token': self.data['tokens'].get('access_token')}) - response = self.client.patch(self.url, data=data, format='json') + response = self.client.patch(url, data=data, format='json') self.assertEqual(response.status_code, status.HTTP_200_OK) diff --git a/apps/account/tests/tests_web.py b/apps/account/tests/tests_web.py new file mode 100644 index 00000000..e771b31a --- /dev/null +++ b/apps/account/tests/tests_web.py @@ -0,0 +1,49 @@ +from rest_framework.test import APITestCase +from rest_framework import status +from authorization.tests.tests import get_tokens_for_user +from django.urls import reverse +from account.models import User + + +class AccountResetPassWordTests(APITestCase): + + def setUp(self): + self.data = get_tokens_for_user() + + def test_reset_password(self): + url = reverse('web:account:password-reset') + data = { + "username_or_email": self.data["email"] + } + response = self.client.post(url, data=data) + self.assertEqual(response.status_code, status.HTTP_200_OK) + + data = { + "username_or_email": self.data["username"] + } + response = self.client.post(url, data=data) + self.assertEqual(response.status_code, status.HTTP_200_OK) + + +class AccountResetPassWordTests(APITestCase): + + def setUp(self): + self.data = get_tokens_for_user() + + def test_reset_password_confirm(self): + data ={ + "password": "newpasswordnewpassword" + } + user = User.objects.get(email=self.data["email"]) + token = user.reset_password_token + uidb64 = user.get_user_uidb64 + + url = reverse('web:account:password-reset-confirm', kwargs={ + 'uidb64': uidb64, + 'token': token + }) + response = self.client.patch(url, data=data) + self.assertEqual(response.status_code, status.HTTP_200_OK) + + +