Début des tests

This commit is contained in:
Tom Hubrecht 2021-03-25 09:43:06 +01:00
parent 52839ff987
commit 80305ae249
5 changed files with 140 additions and 3 deletions

View file

@ -1,3 +0,0 @@
from django.test import TestCase
# Create your tests here.

View file

View file

@ -0,0 +1,57 @@
from django.conf import settings
from django.contrib.auth import get_user_model
from django.test import TestCase
from django.utils.translation import gettext_lazy as _
from .test_utils import create_election
User = get_user_model()
class UserTests(TestCase):
def setUp(self):
self.election_1 = create_election(1)
self.election_2 = create_election(2)
self.election_3 = create_election(3, False)
self.cas_user = User.objects.create(
username="cas__user", email="user@clipper.ens.fr", full_name="Ulric Ser"
)
self.user_1 = User.objects.create(
username="1__user",
email="user1@ens.fr",
full_name="Ulric Ser",
election=self.election_1,
)
self.pwd_user = User.objects.create(
username="pwd__user", email="user@ens.fr", full_name="Ulric Ser"
)
def test_special_user(self):
self.assertTrue(self.user_1.can_vote(self.client, self.election_1))
self.assertFalse(self.user_1.can_vote(self.client, self.election_2))
self.assertFalse(self.user_1.can_vote(self.client, self.election_3))
def test_cas_user(self):
# On simule la connection par CAS via authens
session = self.client.session
session["CASCONNECTED"] = True
session.save()
# On sauvegarde le cookie de session
session_cookie_name = settings.SESSION_COOKIE_NAME
self.client.cookies[session_cookie_name] = session.session_key
self.assertFalse(self.cas_user.can_vote(self.client, self.election_1))
self.assertTrue(self.cas_user.can_vote(self.client, self.election_3))
def test_pwd_user(self):
self.assertFalse(self.pwd_user.can_vote(self.client, self.election_1))
self.assertFalse(self.pwd_user.can_vote(self.client, self.election_2))
def test_connection_method(self):
self.assertEqual(self.cas_user.connection_method, _("CAS"))
self.assertEqual(self.pwd_user.connection_method, _("mot de passe"))
self.assertEqual(self.user_1.connection_method, _("identifiants spécifiques"))

View file

@ -0,0 +1,26 @@
from datetime import timedelta
from django.utils import timezone
from elections.models import Election
def create_election(i, restricted=True, creator=None, future=False):
now = timezone.now()
day = timedelta(days=1)
if future:
start_date = now + day
end_date = now + 2 * day
else:
start_date = now - day
end_date = now + day
return Election.objects.create(
name=f"Election {i}",
short_name=f"election_{i}",
start_date=start_date,
end_date=end_date,
restricted=restricted,
created_by=creator,
)

View file

@ -0,0 +1,57 @@
from django.contrib.auth import get_user_model
from django.contrib.auth.models import Permission
from django.test import TestCase
from django.urls import reverse
from .test_utils import create_election
User = get_user_model()
class AdminViewsTest(TestCase):
def setUp(self):
perm = Permission.objects.get(codename="is_admin")
self.admin_1 = User.objects.create(
username="pwd__admin1", email="admin1@ens.fr", full_name="Alfred Dmin"
)
self.admin_2 = User.objects.create(
username="pwd__admin2", email="admin2@ens.fr", full_name="Albert Dmin"
)
self.base_user = User.objects.create(
username="cas__user", email="user@clipper.ens.fr", full_name="Ulric Ser"
)
self.admin_1.user_permissions.add(perm)
self.admin_2.user_permissions.add(perm)
self.election_1 = create_election(1, creator=self.admin_1)
self.election_2 = create_election(2, creator=self.admin_1, future=True)
self.election_3 = create_election(3, creator=self.admin_2)
self.election_4 = create_election(4)
def test_create_view(self):
url = reverse("election.create")
# Création possible pour un admin
self.client.force_login(self.admin_1)
self.assertEqual(self.client.get(url).status_code, 200)
# Création impossible pour un user lambda
self.client.force_login(self.base_user)
self.assertEqual(self.client.get(url).status_code, 403)
def test_admin_view(self):
url_1 = reverse("election.admin", args=[self.election_1.pk])
url_3 = reverse("election.admin", args=[self.election_3.pk])
url_4 = reverse("election.admin", args=[self.election_4.pk])
# Accès uniquement à sa propre élection
self.client.force_login(self.admin_1)
self.assertEqual(self.client.get(url_1).status_code, 200)
self.assertEqual(self.client.get(url_3).status_code, 404)
self.assertEqual(self.client.get(url_4).status_code, 404)
# Accès refusé pour un user lambda
self.client.force_login(self.base_user)
self.assertEqual(self.client.get(url_1).status_code, 403)