2020-11-02 10:44:53 +00:00
|
|
|
import os
|
|
|
|
|
2020-09-24 12:15:42 +00:00
|
|
|
from corres2math.tokens import email_validation_token
|
|
|
|
from django.contrib.auth.models import User
|
|
|
|
from django.test import TestCase
|
|
|
|
from django.urls import reverse
|
|
|
|
from django.utils.encoding import force_bytes
|
|
|
|
from django.utils.http import urlsafe_base64_encode
|
|
|
|
|
|
|
|
from .models import CoachRegistration, Registration, StudentRegistration
|
|
|
|
|
|
|
|
|
|
|
|
class TestIndexPage(TestCase):
|
|
|
|
def test_index(self) -> None:
|
2020-10-30 18:46:46 +00:00
|
|
|
"""
|
|
|
|
Display the index page, without any right.
|
|
|
|
"""
|
2020-09-24 12:15:42 +00:00
|
|
|
response = self.client.get(reverse("index"))
|
|
|
|
self.assertEqual(response.status_code, 200)
|
|
|
|
|
|
|
|
|
|
|
|
class TestRegistration(TestCase):
|
|
|
|
def setUp(self) -> None:
|
|
|
|
self.user = User.objects.create_superuser(
|
|
|
|
username="admin",
|
|
|
|
password="admin",
|
|
|
|
email="admin@example.com",
|
|
|
|
)
|
|
|
|
self.client.force_login(self.user)
|
|
|
|
|
2020-09-24 16:39:55 +00:00
|
|
|
self.student = User.objects.create(email="student@example.com")
|
|
|
|
StudentRegistration.objects.create(user=self.student, student_class=11, school="Earth")
|
|
|
|
self.coach = User.objects.create(email="coach@example.com")
|
|
|
|
CoachRegistration.objects.create(user=self.coach, professional_activity="Teacher")
|
|
|
|
|
2020-10-06 11:35:05 +00:00
|
|
|
def test_admin_pages(self):
|
2020-10-30 18:46:46 +00:00
|
|
|
"""
|
|
|
|
Check that admin pages are rendering successfully.
|
|
|
|
"""
|
2020-10-06 11:35:05 +00:00
|
|
|
response = self.client.get(reverse("admin:index") + "registration/registration/")
|
|
|
|
self.assertEqual(response.status_code, 200)
|
|
|
|
|
|
|
|
response = self.client.get(reverse("admin:index")
|
|
|
|
+ f"registration/registration/{self.user.registration.pk}/change/")
|
|
|
|
self.assertEqual(response.status_code, 200)
|
|
|
|
|
|
|
|
response = self.client.get(reverse("admin:index")
|
|
|
|
+ f"registration/registration/{self.student.registration.pk}/change/")
|
|
|
|
self.assertEqual(response.status_code, 200)
|
|
|
|
|
|
|
|
response = self.client.get(reverse("admin:index")
|
|
|
|
+ f"registration/registration/{self.coach.registration.pk}/change/")
|
|
|
|
self.assertEqual(response.status_code, 200)
|
|
|
|
|
2020-09-24 12:15:42 +00:00
|
|
|
def test_registration(self):
|
2020-10-30 18:46:46 +00:00
|
|
|
"""
|
|
|
|
Ensure that the signup form is working successfully.
|
|
|
|
"""
|
2020-09-24 12:15:42 +00:00
|
|
|
response = self.client.get(reverse("registration:signup"))
|
|
|
|
self.assertEqual(response.status_code, 200)
|
|
|
|
|
|
|
|
# Incomplete form
|
|
|
|
response = self.client.post(reverse("registration:signup"), data=dict(
|
|
|
|
last_name="Toto",
|
|
|
|
first_name="Toto",
|
|
|
|
email="toto@example.com",
|
|
|
|
password1="azertyuiopazertyuiop",
|
|
|
|
password2="azertyuiopazertyuiop",
|
|
|
|
role="participant",
|
|
|
|
))
|
|
|
|
self.assertEqual(response.status_code, 200)
|
|
|
|
|
|
|
|
response = self.client.post(reverse("registration:signup"), data=dict(
|
|
|
|
last_name="Toto",
|
|
|
|
first_name="Toto",
|
|
|
|
email="toto@example.com",
|
|
|
|
password1="azertyuiopazertyuiop",
|
|
|
|
password2="azertyuiopazertyuiop",
|
|
|
|
role="participant",
|
|
|
|
student_class=12,
|
|
|
|
school="God",
|
|
|
|
give_contact_to_animath=False,
|
|
|
|
))
|
|
|
|
self.assertRedirects(response, reverse("registration:email_validation_sent"), 302, 200)
|
|
|
|
self.assertTrue(User.objects.filter(email="toto@example.com").exists())
|
|
|
|
|
|
|
|
response = self.client.get(reverse("registration:email_validation_sent"))
|
|
|
|
self.assertEqual(response.status_code, 200)
|
|
|
|
|
|
|
|
response = self.client.post(reverse("registration:signup"), data=dict(
|
|
|
|
last_name="Toto",
|
|
|
|
first_name="Coach",
|
|
|
|
email="coachtoto@example.com",
|
|
|
|
password1="azertyuiopazertyuiop",
|
|
|
|
password2="azertyuiopazertyuiop",
|
|
|
|
role="coach",
|
|
|
|
professional_activity="God",
|
|
|
|
give_contact_to_animath=True,
|
|
|
|
))
|
|
|
|
self.assertRedirects(response, reverse("registration:email_validation_sent"), 302, 200)
|
|
|
|
self.assertTrue(User.objects.filter(email="coachtoto@example.com").exists())
|
|
|
|
|
|
|
|
user = User.objects.get(email="coachtoto@example.com")
|
|
|
|
token = email_validation_token.make_token(user)
|
|
|
|
uid = urlsafe_base64_encode(force_bytes(user.pk))
|
|
|
|
response = self.client.get(reverse("registration:email_validation", kwargs=dict(uidb64=uid, token=token)))
|
|
|
|
self.assertEqual(response.status_code, 200)
|
|
|
|
user.registration.refresh_from_db()
|
|
|
|
self.assertTrue(user.registration.email_confirmed)
|
|
|
|
|
|
|
|
# Token has expired
|
|
|
|
response = self.client.get(reverse("registration:email_validation", kwargs=dict(uidb64=uid, token=token)))
|
|
|
|
self.assertEqual(response.status_code, 400)
|
|
|
|
|
|
|
|
# Uid does not exist
|
|
|
|
response = self.client.get(reverse("registration:email_validation", kwargs=dict(uidb64=0, token="toto")))
|
|
|
|
self.assertEqual(response.status_code, 400)
|
|
|
|
|
|
|
|
response = self.client.get(reverse("registration:email_validation_resend", args=(user.pk,)))
|
|
|
|
self.assertRedirects(response, reverse("registration:email_validation_sent"), 302, 200)
|
|
|
|
|
|
|
|
def test_login(self):
|
2020-10-30 18:46:46 +00:00
|
|
|
"""
|
|
|
|
With a registered user, try to log in
|
|
|
|
"""
|
2020-09-24 12:15:42 +00:00
|
|
|
response = self.client.get(reverse("login"))
|
|
|
|
self.assertEqual(response.status_code, 200)
|
|
|
|
|
|
|
|
self.client.logout()
|
|
|
|
|
|
|
|
response = self.client.post(reverse("login"), data=dict(
|
|
|
|
username="admin",
|
|
|
|
password="toto",
|
|
|
|
))
|
|
|
|
self.assertEqual(response.status_code, 200)
|
|
|
|
|
|
|
|
response = self.client.post(reverse("login"), data=dict(
|
|
|
|
username="admin@example.com",
|
|
|
|
password="admin",
|
|
|
|
))
|
|
|
|
self.assertRedirects(response, reverse("index"), 302, 200)
|
|
|
|
|
2020-09-24 16:39:55 +00:00
|
|
|
def test_user_detail(self):
|
2020-10-30 18:46:46 +00:00
|
|
|
"""
|
|
|
|
Load a user detail page.
|
|
|
|
"""
|
2020-09-24 16:39:55 +00:00
|
|
|
response = self.client.get(reverse("registration:my_account_detail"))
|
|
|
|
self.assertRedirects(response, reverse("registration:user_detail", args=(self.user.pk,)))
|
|
|
|
|
|
|
|
response = self.client.get(reverse("registration:user_detail", args=(self.user.pk,)))
|
|
|
|
self.assertEqual(response.status_code, 200)
|
|
|
|
|
|
|
|
def test_update_user(self):
|
2020-10-30 18:46:46 +00:00
|
|
|
"""
|
|
|
|
Update the user information, for each type of user.
|
|
|
|
"""
|
2020-09-24 16:39:55 +00:00
|
|
|
for user, data in [(self.user, dict(role="Bot")),
|
|
|
|
(self.student, dict(student_class=11, school="Sky")),
|
|
|
|
(self.coach, dict(professional_activity="God"))]:
|
|
|
|
response = self.client.get(reverse("registration:update_user", args=(user.pk,)))
|
|
|
|
self.assertEqual(response.status_code, 200)
|
|
|
|
|
|
|
|
response = self.client.post(reverse("registration:update_user", args=(user.pk,)), data=dict(
|
|
|
|
first_name="Changed",
|
|
|
|
last_name="Name",
|
|
|
|
email="new_" + user.email,
|
|
|
|
give_contact_to_animath=True,
|
|
|
|
))
|
|
|
|
self.assertEqual(response.status_code, 200)
|
|
|
|
|
|
|
|
data.update(
|
|
|
|
first_name="Changed",
|
|
|
|
last_name="Name",
|
|
|
|
email="new_" + user.email,
|
|
|
|
give_contact_to_animath=True,
|
|
|
|
)
|
|
|
|
response = self.client.post(reverse("registration:update_user", args=(user.pk,)), data=data)
|
|
|
|
self.assertRedirects(response, reverse("registration:user_detail", args=(user.pk,)), 302, 200)
|
|
|
|
user.refresh_from_db()
|
|
|
|
self.assertEqual(user.email, user.username)
|
|
|
|
self.assertFalse(user.registration.email_confirmed)
|
|
|
|
self.assertEqual(user.first_name, "Changed")
|
2020-09-24 12:15:42 +00:00
|
|
|
|
2020-09-27 15:06:05 +00:00
|
|
|
def test_upload_photo_authorization(self):
|
2020-10-30 18:46:46 +00:00
|
|
|
"""
|
|
|
|
Try to upload a photo authorization.
|
|
|
|
"""
|
2020-09-27 15:06:05 +00:00
|
|
|
response = self.client.get(reverse("registration:upload_user_photo_authorization",
|
|
|
|
args=(self.student.registration.pk,)))
|
|
|
|
self.assertEqual(response.status_code, 200)
|
|
|
|
|
|
|
|
# README is not a valid PDF file
|
|
|
|
response = self.client.post(reverse("registration:upload_user_photo_authorization",
|
|
|
|
args=(self.student.registration.pk,)), data=dict(
|
|
|
|
photo_authorization=open("README.md", "rb"),
|
|
|
|
))
|
|
|
|
self.assertEqual(response.status_code, 200)
|
|
|
|
|
|
|
|
response = self.client.post(reverse("registration:upload_user_photo_authorization",
|
|
|
|
args=(self.student.registration.pk,)), data=dict(
|
|
|
|
photo_authorization=open("corres2math/static/Autorisation de droit à l'image - majeur.pdf", "rb"),
|
|
|
|
))
|
|
|
|
self.assertRedirects(response, reverse("registration:user_detail", args=(self.student.pk,)), 302, 200)
|
|
|
|
|
|
|
|
self.student.registration.refresh_from_db()
|
|
|
|
self.assertTrue(self.student.registration.photo_authorization)
|
|
|
|
|
|
|
|
response = self.client.get(reverse("photo_authorization",
|
|
|
|
args=(self.student.registration.photo_authorization.name.split('/')[-1],)))
|
|
|
|
self.assertEqual(response.status_code, 200)
|
|
|
|
|
2020-09-27 16:40:45 +00:00
|
|
|
from participation.models import Team
|
|
|
|
team = Team.objects.create(name="Test", trigram="TES")
|
|
|
|
self.student.registration.team = team
|
|
|
|
self.student.registration.save()
|
|
|
|
response = self.client.get(reverse("participation:team_authorizations", args=(team.pk,)))
|
|
|
|
self.assertEqual(response.status_code, 200)
|
|
|
|
self.assertEqual(response["content-type"], "application/zip")
|
|
|
|
|
2020-11-02 10:44:53 +00:00
|
|
|
# Do it twice, ensure that the previous authorization got deleted
|
|
|
|
old_authoratization = self.student.registration.photo_authorization.path
|
|
|
|
response = self.client.post(reverse("registration:upload_user_photo_authorization",
|
|
|
|
args=(self.student.registration.pk,)), data=dict(
|
|
|
|
photo_authorization=open("corres2math/static/Autorisation de droit à l'image - majeur.pdf", "rb"),
|
|
|
|
))
|
|
|
|
self.assertRedirects(response, reverse("registration:user_detail", args=(self.student.pk,)), 302, 200)
|
|
|
|
self.assertFalse(os.path.isfile(old_authoratization))
|
|
|
|
|
|
|
|
self.student.registration.refresh_from_db()
|
2020-09-27 16:09:39 +00:00
|
|
|
self.student.registration.photo_authorization.delete()
|
|
|
|
|
2020-11-02 10:44:53 +00:00
|
|
|
def test_user_detail_forbidden(self):
|
|
|
|
"""
|
|
|
|
Create a new user and ensure that it can't see the detail of another user.
|
|
|
|
"""
|
|
|
|
self.client.force_login(self.coach)
|
|
|
|
|
|
|
|
response = self.client.get(reverse("registration:user_detail", args=(self.user.pk,)))
|
|
|
|
self.assertEqual(response.status_code, 403)
|
|
|
|
|
|
|
|
response = self.client.get(reverse("registration:update_user", args=(self.user.pk,)))
|
|
|
|
self.assertEqual(response.status_code, 403)
|
|
|
|
|
|
|
|
response = self.client.get(reverse("registration:upload_user_photo_authorization", args=(self.user.pk,)))
|
|
|
|
self.assertEqual(response.status_code, 403)
|
|
|
|
|
|
|
|
response = self.client.get(reverse("photo_authorization", args=("inexisting-authorization",)))
|
|
|
|
self.assertEqual(response.status_code, 404)
|
|
|
|
|
|
|
|
with open("media/authorization/photo/example", "w") as f:
|
|
|
|
f.write("I lost the game.")
|
|
|
|
self.student.registration.photo_authorization = "authorization/photo/example"
|
|
|
|
self.student.registration.save()
|
|
|
|
response = self.client.get(reverse("photo_authorization", args=("example",)))
|
|
|
|
self.assertEqual(response.status_code, 403)
|
|
|
|
os.remove("media/authorization/photo/example")
|
|
|
|
|
2020-09-24 12:15:42 +00:00
|
|
|
def test_string_render(self):
|
|
|
|
# TODO These string field tests will be removed when used in a template
|
|
|
|
self.assertRaises(NotImplementedError, lambda: Registration().type)
|
2020-09-24 16:39:55 +00:00
|
|
|
self.assertRaises(NotImplementedError, lambda: Registration().form_class)
|