forked from ScoDoc/DocScoDoc
259 lines
8.0 KiB
Python
259 lines
8.0 KiB
Python
# -*- coding: utf-8 -*-
|
|
|
|
"""Test Logos
|
|
|
|
Utilisation :
|
|
créer les variables d'environnement: (indiquer les valeurs
|
|
pour le serveur ScoDoc que vous voulez interroger)
|
|
|
|
export SCODOC_URL="https://scodoc.xxx.net/"
|
|
export SCODOC_USER="xxx"
|
|
export SCODOC_PASSWD="xxx"
|
|
export CHECK_CERTIFICATE=0 # ou 1 si serveur de production avec certif SSL valide
|
|
|
|
(on peut aussi placer ces valeurs dans un fichier .env du répertoire tests/api).
|
|
|
|
Lancer :
|
|
pytest tests/api/test_api_formsemestre.py
|
|
"""
|
|
|
|
import requests
|
|
from app.api.formsemestres import formsemestre
|
|
|
|
from tests.api.setup_test_api import API_URL, CHECK_CERTIFICATE, api_headers
|
|
from tests.api.tools_test_api import (
|
|
MODIMPL_FIELDS,
|
|
verify_fields,
|
|
EVAL_FIELDS,
|
|
SAISIE_NOTES_FIELDS,
|
|
)
|
|
from tests.api.tools_test_api import FSEM_FIELDS, UE_FIELDS, MODULE_FIELDS
|
|
|
|
# Etudiant pour les tests
|
|
ETUDID = 1
|
|
NIP = "1"
|
|
INE = "INE1"
|
|
|
|
|
|
def test_formsemestre(api_headers):
|
|
"""
|
|
Route: /formsemestre/<id>
|
|
"""
|
|
r = requests.get(
|
|
API_URL + "/formsemestre/1",
|
|
headers=api_headers,
|
|
verify=CHECK_CERTIFICATE,
|
|
)
|
|
assert r.status_code == 200
|
|
formsemestre = r.json()
|
|
assert verify_fields(formsemestre, FSEM_FIELDS)
|
|
|
|
|
|
# XXX TODO ajouter une etape_apo dans la base de test
|
|
# def test_formsemestre_apo(api_headers):
|
|
# r = requests.get(
|
|
# API_URL + "/formation/apo/<string:etape_apo>",
|
|
# headers=api_headers,
|
|
# verify=CHECK_CERTIFICATE,
|
|
# )
|
|
# assert r.status_code == 200
|
|
|
|
|
|
def test_bulletins(api_headers):
|
|
"""
|
|
Route: /formsemestre/<int:formsemestre_id>/bulletins
|
|
"""
|
|
r = requests.get(
|
|
API_URL + "/formsemestre/1/bulletins",
|
|
headers=api_headers,
|
|
verify=CHECK_CERTIFICATE,
|
|
)
|
|
assert r.status_code == 200
|
|
|
|
|
|
# # jury
|
|
# def test_jury():
|
|
# r = requests.get(
|
|
# API_URL + "/formsemestre/1/jury",
|
|
# headers=api_headers,
|
|
# verify=CHECK_CERTIFICATE,
|
|
# )
|
|
# assert r.status_code == 200
|
|
|
|
|
|
# def test_formsemestre_etudiants(api_headers):
|
|
# """
|
|
# Route: /formsemestre/<int:formsemestre_id>/etudiants, /formsemestre/<int:formsemestre_id>/etudiants/demissionnaires, /formsemestre/<int:formsemestre_id>/etudiants/defaillants
|
|
# """
|
|
# r = requests.get(
|
|
# API_URL + "/formsemestre/<int:formsemestre_id>/etudiants",
|
|
# headers=api_headers,
|
|
# verify=CHECK_CERTIFICATE,
|
|
# )
|
|
# assert r.status_code == 200
|
|
#
|
|
# r = requests.get(
|
|
# API_URL + "/formsemestre/<int:formsemestre_id>/etudiants/demissionnaires",
|
|
# headers=api_headers,
|
|
# verify=CHECK_CERTIFICATE,
|
|
# )
|
|
# assert r.status_code == 200
|
|
#
|
|
# r = requests.get(
|
|
# API_URL + "/formsemestre/<int:formsemestre_id>/etudiants/defaillants",
|
|
# headers=api_headers,
|
|
# verify=CHECK_CERTIFICATE,
|
|
# )
|
|
# assert r.status_code == 200
|
|
|
|
|
|
def test_formsemestre_programme(api_headers):
|
|
"""
|
|
Route: /formsemestre/1/programme
|
|
"""
|
|
|
|
r = requests.get(
|
|
API_URL + "/formsemestre/1/programme",
|
|
headers=api_headers,
|
|
verify=CHECK_CERTIFICATE,
|
|
)
|
|
assert r.status_code == 200
|
|
prog = r.json()
|
|
assert isinstance(prog, dict)
|
|
assert "ues" in prog
|
|
assert "modules" in prog
|
|
assert "ressources" in prog
|
|
assert "saes" in prog
|
|
assert isinstance(prog["ues"], list)
|
|
assert isinstance(prog["modules"], list)
|
|
ue = prog["ues"][0]
|
|
modules = prog["modules"]
|
|
# Il y a toujours au moins une SAE et une ressources dans notre base de test
|
|
ressource = prog["ressources"][0]
|
|
sae = prog["saes"][0]
|
|
|
|
assert verify_fields(ue, UE_FIELDS)
|
|
if len(modules) > 1:
|
|
assert verify_fields(modules[0], MODIMPL_FIELDS)
|
|
assert verify_fields(ressource, MODIMPL_FIELDS)
|
|
assert verify_fields(sae, MODIMPL_FIELDS)
|
|
|
|
|
|
def test_etat_evals(
|
|
api_headers,
|
|
):
|
|
"""
|
|
Route : /formsemestre/<int:formsemestre_id>/etat_evals
|
|
"""
|
|
r = requests.get(
|
|
API_URL + "/formsemestre/1/etat_evals",
|
|
headers=api_headers,
|
|
verify=CHECK_CERTIFICATE,
|
|
)
|
|
assert r.status_code == 200
|
|
|
|
etat_evals = r.json()
|
|
|
|
assert len(etat_evals) == 3
|
|
|
|
for ue in etat_evals.values():
|
|
for module in ue:
|
|
assert isinstance(module["id"], int)
|
|
assert isinstance(module["titre"], str)
|
|
assert isinstance(module["evaluations"], list)
|
|
|
|
for eval in module["evaluations"]:
|
|
assert verify_fields(eval, EVAL_FIELDS)
|
|
assert isinstance(eval["id"], int)
|
|
assert eval["description"] is None or isinstance(
|
|
eval["description"], str
|
|
)
|
|
assert eval["datetime_epreuve"] is None or isinstance(
|
|
eval["datetime_epreuve"], str
|
|
)
|
|
assert isinstance(eval["heure_fin"], str)
|
|
assert isinstance(eval["coefficient"], float)
|
|
assert isinstance(eval["comptee"], str)
|
|
assert isinstance(eval["inscrits"], int)
|
|
assert isinstance(eval["manquantes"], int)
|
|
assert isinstance(eval["ABS"], int)
|
|
assert isinstance(eval["ATT"], int)
|
|
assert isinstance(eval["EXC"], int)
|
|
assert isinstance(eval["saisie_notes"], dict)
|
|
|
|
list_eval_id = [e["id"] for e in module["evaluations"]]
|
|
all_unique = True
|
|
for id in list_eval_id:
|
|
if list_eval_id.count(id) > 1:
|
|
all_unique = False
|
|
assert all_unique is True
|
|
|
|
saisie_notes = eval["saisie_notes"]
|
|
assert verify_fields(saisie_notes, SAISIE_NOTES_FIELDS)
|
|
assert eval["saisie_notes"]["datetime_debut"] is None or isinstance(
|
|
eval["saisie_notes"]["datetime_debut"], str
|
|
)
|
|
assert eval["saisie_notes"]["datetime_debut"] is None or isinstance(
|
|
eval["saisie_notes"]["datetime_fin"], str
|
|
)
|
|
assert eval["saisie_notes"]["datetime_debut"] is None or isinstance(
|
|
eval["saisie_notes"]["datetime_mediane"], str
|
|
)
|
|
|
|
if (
|
|
eval["saisie_notes"]["datetime_fin"] is not None
|
|
and eval["saisie_notes"]["datetime_mediane"] is not None
|
|
and eval["saisie_notes"]["datetime_debut"] is not None
|
|
):
|
|
assert (
|
|
eval["saisie_notes"]["datetime_fin"]
|
|
> eval["saisie_notes"]["datetime_mediane"]
|
|
)
|
|
assert (
|
|
eval["saisie_notes"]["datetime_fin"]
|
|
> eval["saisie_notes"]["datetime_debut"]
|
|
)
|
|
assert (
|
|
eval["saisie_notes"]["datetime_mediane"]
|
|
> eval["saisie_notes"]["datetime_debut"]
|
|
)
|
|
|
|
list_id_ue1 = []
|
|
list_titre_ue1 = []
|
|
|
|
list_id_ue2 = []
|
|
list_titre_ue2 = []
|
|
|
|
list_id_ue3 = []
|
|
list_titre_ue3 = []
|
|
i = 0
|
|
for ue in etat_evals.values():
|
|
i += 1
|
|
for module in ue:
|
|
if i == 1:
|
|
list_id_ue1.append(module["id"])
|
|
list_titre_ue1.append(module["id"])
|
|
elif i == 2:
|
|
list_id_ue2.append(module["id"])
|
|
list_titre_ue2.append(module["id"])
|
|
elif i == 3:
|
|
list_id_ue3.append(module["id"])
|
|
list_titre_ue3.append(module["id"])
|
|
|
|
assert list_id_ue1 != list_id_ue2
|
|
assert list_id_ue1 != list_titre_ue3
|
|
assert list_id_ue2 != list_titre_ue3
|
|
|
|
assert list_titre_ue1 != list_titre_ue2
|
|
assert list_titre_ue1 != list_titre_ue3
|
|
assert list_titre_ue2 != list_titre_ue3
|
|
|
|
##### ERROR #####
|
|
fake_eval_id = 153165161656849846516511321651651
|
|
r = requests.get(
|
|
f"{API_URL}/formsemestre/{fake_eval_id}/etat_evals",
|
|
headers=api_headers,
|
|
verify=CHECK_CERTIFICATE,
|
|
)
|
|
assert r.status_code == 404
|