generated from ocadotechnology/codeforlife-template-backend
-
Notifications
You must be signed in to change notification settings - Fork 24
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
558feaf
commit 3e35be0
Showing
6 changed files
with
202 additions
and
16 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -5,12 +5,10 @@ | |
|
||
from codeforlife.tests import ModelViewSetTestCase | ||
from codeforlife.user.models import User | ||
from rest_framework import status | ||
|
||
from ...serializers import UserSerializer | ||
from ...views import UserViewSet | ||
|
||
|
||
class TestUserViewSet(ModelViewSetTestCase[UserViewSet, UserSerializer, User]): | ||
class TestUserViewSet(ModelViewSetTestCase[User]): | ||
""" | ||
Base naming convention: | ||
test_{action} | ||
|
@@ -41,3 +39,89 @@ def test_is_unique_email(self): | |
) | ||
|
||
self.assertTrue(response.json()) | ||
|
||
def test_request_password_reset(self): | ||
""" | ||
Check request password reset generates a reset password URL, if email exists. | ||
""" | ||
user = User.objects.first() | ||
assert user is not None | ||
|
||
viewname = self.client.reverse("request-password-reset") | ||
|
||
response = self.client.post( | ||
viewname, data={"email": "[email protected]"} | ||
) | ||
|
||
assert response.data is None | ||
|
||
response = self.client.post(viewname, data={"email": user.email}) | ||
|
||
assert response.data["reset_password_url"] is not None | ||
assert response.data["uidb64"] is not None | ||
assert response.data["token"] is not None | ||
|
||
def test_reset_password(self): | ||
""" | ||
Check reset password logic: requires valid encoded uid, user token and check password update. | ||
""" | ||
user = User.objects.first() | ||
assert user is not None | ||
|
||
# Generate a password reset URL | ||
viewname = self.client.reverse("request-password-reset") | ||
|
||
response = self.client.post(viewname, data={"email": user.email}) | ||
reset_password_url = response.data["reset_password_url"] | ||
|
||
# Test reset-password GET | ||
# Check invalid uid raises 400 | ||
viewname = self.client.reverse( | ||
"reset-password", | ||
kwargs={"uidb64": "whatever", "token": response.data["token"]}, | ||
) | ||
|
||
invalid_uid_response = self.client.get( | ||
viewname, status_code_assertion=status.HTTP_400_BAD_REQUEST | ||
) | ||
|
||
assert invalid_uid_response.data["non_field_errors"] == [ | ||
"no user found for given uid" | ||
] | ||
|
||
# Check invalid token raises 400 | ||
viewname = self.client.reverse( | ||
"reset-password", | ||
kwargs={"uidb64": response.data["uidb64"], "token": "whatever"}, | ||
) | ||
|
||
invalid_token_response = self.client.get( | ||
viewname, status_code_assertion=status.HTTP_400_BAD_REQUEST | ||
) | ||
|
||
assert invalid_token_response.data["non_field_errors"] == [ | ||
"token doesn't match given user" | ||
] | ||
|
||
# Check successful GET | ||
self.client.get(reset_password_url) | ||
|
||
# Test reset-password PATCH for teacher | ||
self.client.patch(reset_password_url, data={"password": "N3wPassword!"}) | ||
self.client.login(email=user.email, password="N3wPassword!") | ||
self.client.logout() | ||
|
||
user = User.objects.get(id=11) | ||
assert user is not None | ||
|
||
# Generate a password reset URL | ||
viewname = self.client.reverse("request-password-reset") | ||
|
||
response = self.client.post(viewname, data={"email": user.email}) | ||
reset_password_url = response.data["reset_password_url"] | ||
|
||
self.client.get(reset_password_url) | ||
|
||
# Test reset-password PATCH for indy | ||
self.client.patch(reset_password_url, data={"password": "N3wPassword"}) | ||
self.client.login(email=user.email, password="N3wPassword") |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -3,7 +3,7 @@ set -e | |
|
||
cd "${BASH_SOURCE%/*}" | ||
|
||
source ./setup.sh | ||
source ./setup | ||
|
||
cd frontend | ||
|
||
|