mirror of
https://gitlab.crans.org/bde/nk20
synced 2024-12-18 13:32:28 +00:00
a6b479db19
- /apps/activity/api/serializers.py - /apps/activity/api/urls.py - /apps/activity/api/views.py - /apps/activity/tests/test_activities.py - /apps/activity/__init__.py - /apps/activity/admin.py - /apps/activity/apps.py - /apps/activity/forms.py - /apps/activity/tables.py - /apps/activity/urls.py - /apps/activity/views.py - /apps/api/__init__.py - /apps/api/apps.py - /apps/api/serializers.py - /apps/api/tests.py - /apps/api/urls.py - /apps/api/views.py - /apps/api/viewsets.py - /apps/logs/signals.py - /apps/logs/apps.py - /apps/logs/__init__.py - /apps/logs/api/serializers.py - /apps/logs/api/urls.py - /apps/logs/api/views.py - /apps/member/api/serializers.py - /apps/member/api/urls.py - /apps/member/api/views.py - /apps/member/templatetags/memberinfo.py - /apps/member/__init__.py - /apps/member/admin.py - /apps/member/apps.py - /apps/member/auth.py - /apps/member/forms.py - /apps/member/hashers.py - /apps/member/signals.py - /apps/member/tables.py - /apps/member/urls.py - /apps/member/views.py - /apps/note/api/serializers.py - /apps/note/api/urls.py - /apps/note/api/views.py - /apps/note/models/__init__.py - /apps/note/static/note/js/consos.js - /apps/note/templates/note/mails/negative_balance.txt - /apps/note/templatetags/getenv.py - /apps/note/templatetags/pretty_money.py - /apps/note/tests/test_transactions.py - /apps/note/__init__.py - /apps/note/admin.py - /apps/note/apps.py - /apps/note/forms.py - /apps/note/signals.py - /apps/note/tables.py - /apps/note/urls.py - /apps/note/views.py - /apps/permission/api/serializers.py - /apps/permission/api/urls.py - /apps/permission/api/views.py - /apps/permission/templatetags/perms.py - /apps/permission/tests/test_oauth2.py - /apps/permission/tests/test_permission_denied.py - /apps/permission/tests/test_permission_queries.py - /apps/permission/tests/test_rights_page.py - /apps/permission/__init__.py - /apps/permission/admin.py - /apps/permission/backends.py - /apps/permission/apps.py - /apps/permission/decorators.py - /apps/permission/permissions.py - /apps/permission/scopes.py - /apps/permission/signals.py - /apps/permission/tables.py - /apps/permission/urls.py - /apps/permission/views.py - /apps/registration/tests/test_registration.py - /apps/registration/__init__.py - /apps/registration/apps.py - /apps/registration/forms.py - /apps/registration/tables.py - /apps/registration/tokens.py - /apps/registration/urls.py - /apps/registration/views.py - /apps/treasury/api/serializers.py - /apps/treasury/api/urls.py - /apps/treasury/api/views.py - /apps/treasury/templatetags/escape_tex.py - /apps/treasury/tests/test_treasury.py - /apps/treasury/__init__.py - /apps/treasury/admin.py - /apps/treasury/apps.py - /apps/treasury/forms.py - /apps/treasury/signals.py - /apps/treasury/tables.py - /apps/treasury/urls.py - /apps/treasury/views.py - /apps/wei/api/serializers.py - /apps/wei/api/urls.py - /apps/wei/api/views.py - /apps/wei/forms/surveys/__init__.py - /apps/wei/forms/surveys/base.py - /apps/wei/forms/surveys/wei2021.py - /apps/wei/forms/surveys/wei2022.py - /apps/wei/forms/surveys/wei2023.py - /apps/wei/forms/__init__.py - /apps/wei/forms/registration.py - /apps/wei/management/commands/export_wei_registrations.py - /apps/wei/management/commands/import_scores.py - /apps/wei/management/commands/wei_algorithm.py - /apps/wei/templates/wei/weilist_sample.tex - /apps/wei/tests/test_wei_algorithm_2021.py - /apps/wei/tests/test_wei_algorithm_2022.py - /apps/wei/tests/test_wei_algorithm_2023.py - /apps/wei/tests/test_wei_registration.py - /apps/wei/__init__.py - /apps/wei/admin.py - /apps/wei/apps.py - /apps/wei/tables.py - /apps/wei/urls.py - /apps/wei/views.py - /note_kfet/settings/__init__.py - /note_kfet/settings/base.py - /note_kfet/settings/development.py - /note_kfet/settings/secrets_example.py - /note_kfet/static/js/base.js - /note_kfet/admin.py - /note_kfet/inputs.py - /note_kfet/middlewares.py - /note_kfet/urls.py - /note_kfet/views.py - /note_kfet/wsgi.py - /entrypoint.sh
158 lines
6.0 KiB
Python
158 lines
6.0 KiB
Python
# Copyright (C) 2018-2024 by BDE ENS Paris-Saclay
|
|
# SPDX-License-Identifier: GPL-3.0-or-later
|
|
|
|
from datetime import timedelta, date
|
|
|
|
from django.contrib.auth.models import User
|
|
from django.test import TestCase
|
|
from django.urls import reverse
|
|
from django.utils import timezone
|
|
from django.utils.crypto import get_random_string
|
|
from activity.models import Activity
|
|
from member.models import Club, Membership
|
|
from note.models import NoteUser
|
|
from wei.models import WEIClub, Bus, WEIRegistration
|
|
|
|
|
|
class TestPermissionDenied(TestCase):
|
|
"""
|
|
Load some protected pages and check that we have 403 errors.
|
|
"""
|
|
fixtures = ('initial',)
|
|
|
|
def setUp(self) -> None:
|
|
# Create sample user with no rights
|
|
self.user = User.objects.create(
|
|
username="toto",
|
|
)
|
|
NoteUser.objects.create(user=self.user)
|
|
self.client.force_login(self.user)
|
|
|
|
def test_consos(self):
|
|
response = self.client.get(reverse("note:consos"))
|
|
self.assertEqual(response.status_code, 403)
|
|
|
|
def test_create_activity(self):
|
|
response = self.client.get(reverse("activity:activity_create"))
|
|
self.assertEqual(response.status_code, 403)
|
|
|
|
def test_activity_entries(self):
|
|
activity = Activity.objects.create(
|
|
name="",
|
|
description="",
|
|
creater=self.user,
|
|
activity_type_id=1,
|
|
organizer_id=1,
|
|
attendees_club_id=1,
|
|
date_start=timezone.now(),
|
|
date_end=timezone.now(),
|
|
)
|
|
response = self.client.get(reverse("activity:activity_entry", kwargs=dict(pk=activity.pk)))
|
|
self.assertEqual(response.status_code, 403)
|
|
|
|
def test_invite_activity(self):
|
|
activity = Activity.objects.create(
|
|
name="",
|
|
description="",
|
|
creater=self.user,
|
|
activity_type_id=1,
|
|
organizer_id=1,
|
|
attendees_club_id=1,
|
|
date_start=timezone.now(),
|
|
date_end=timezone.now(),
|
|
)
|
|
response = self.client.get(reverse("activity:activity_invite", kwargs=dict(pk=activity.pk)))
|
|
self.assertEqual(response.status_code, 403)
|
|
|
|
def test_create_club(self):
|
|
response = self.client.get(reverse("member:club_create"))
|
|
self.assertEqual(response.status_code, 403)
|
|
|
|
def test_add_member_club(self):
|
|
club = Club.objects.create(name=get_random_string(127))
|
|
response = self.client.get(reverse("member:club_add_member", kwargs=dict(club_pk=club.pk)))
|
|
self.assertEqual(response.status_code, 403)
|
|
|
|
def test_renew_membership(self):
|
|
club = Club.objects.create(name=get_random_string(127))
|
|
membership = Membership.objects.create(user=self.user, club=club)
|
|
response = self.client.get(reverse("member:club_renew_membership", kwargs=dict(pk=membership.pk)))
|
|
self.assertEqual(response.status_code, 403)
|
|
|
|
def test_create_weiclub(self):
|
|
response = self.client.get(reverse("wei:wei_create"))
|
|
self.assertEqual(response.status_code, 403)
|
|
|
|
def test_create_wei_bus(self):
|
|
wei = WEIClub.objects.create(
|
|
membership_start=date.today(),
|
|
date_start=date.today() + timedelta(days=1),
|
|
date_end=date.today() + timedelta(days=1),
|
|
)
|
|
response = self.client.get(reverse("wei:add_bus", kwargs=dict(pk=wei.pk)))
|
|
self.assertEqual(response.status_code, 403)
|
|
|
|
def test_create_wei_team(self):
|
|
wei = WEIClub.objects.create(
|
|
membership_start=date.today(),
|
|
date_start=date.today() + timedelta(days=1),
|
|
date_end=date.today() + timedelta(days=1),
|
|
)
|
|
bus = Bus.objects.create(wei=wei)
|
|
response = self.client.get(reverse("wei:add_team", kwargs=dict(pk=bus.pk)))
|
|
self.assertEqual(response.status_code, 403)
|
|
|
|
def test_create_1a_weiregistration(self):
|
|
wei = WEIClub.objects.create(
|
|
membership_start=date.today(),
|
|
date_start=date.today() + timedelta(days=1),
|
|
date_end=date.today() + timedelta(days=1),
|
|
)
|
|
response = self.client.get(reverse("wei:wei_register_1A", kwargs=dict(wei_pk=wei.pk)))
|
|
self.assertEqual(response.status_code, 403)
|
|
|
|
def test_create_old_weiregistration(self):
|
|
wei = WEIClub.objects.create(
|
|
membership_start=date.today(),
|
|
date_start=date.today() + timedelta(days=1),
|
|
date_end=date.today() + timedelta(days=1),
|
|
)
|
|
response = self.client.get(reverse("wei:wei_register_2A", kwargs=dict(wei_pk=wei.pk)))
|
|
self.assertEqual(response.status_code, 403)
|
|
|
|
def test_validate_weiregistration(self):
|
|
wei = WEIClub.objects.create(
|
|
membership_start=date.today(),
|
|
date_start=date.today() + timedelta(days=1),
|
|
date_end=date.today() + timedelta(days=1),
|
|
)
|
|
registration = WEIRegistration.objects.create(wei=wei, user=self.user, birth_date="2000-01-01")
|
|
response = self.client.get(reverse("wei:validate_registration", kwargs=dict(pk=registration.pk)))
|
|
self.assertEqual(response.status_code, 403)
|
|
|
|
def test_create_invoice(self):
|
|
response = self.client.get(reverse("treasury:invoice_create"))
|
|
self.assertEqual(response.status_code, 403)
|
|
|
|
def test_list_invoices(self):
|
|
response = self.client.get(reverse("treasury:invoice_list"))
|
|
self.assertEqual(response.status_code, 403)
|
|
|
|
def test_create_remittance(self):
|
|
response = self.client.get(reverse("treasury:remittance_create"))
|
|
self.assertEqual(response.status_code, 403)
|
|
|
|
def test_list_remittance(self):
|
|
response = self.client.get(reverse("treasury:remittance_list"))
|
|
self.assertEqual(response.status_code, 403)
|
|
|
|
def test_list_soge_credits(self):
|
|
response = self.client.get(reverse("treasury:soge_credits"))
|
|
self.assertEqual(response.status_code, 403)
|
|
|
|
|
|
class TestLoginRedirect(TestCase):
|
|
def test_consos_page(self):
|
|
response = self.client.get(reverse("note:consos"))
|
|
self.assertRedirects(response, reverse("login") + "?next=" + reverse("note:consos"), 302, 200)
|