2022-03-09 16:52:07 +01:00
|
|
|
# -*- 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
|
|
|
|
"""
|
|
|
|
|
2022-03-10 17:43:12 +01:00
|
|
|
import requests
|
2022-03-09 16:52:07 +01:00
|
|
|
|
2022-05-04 23:11:20 +02:00
|
|
|
from tests.api.setup_test_api import API_URL, CHECK_CERTIFICATE, api_headers
|
2022-05-02 16:29:26 +02:00
|
|
|
from tests.api.tools_test_api import verify_fields
|
2022-05-05 19:50:09 +02:00
|
|
|
from tests.api.tools_test_api import ETUD_FIELDS, FSEM_FIELDS
|
2022-05-02 16:29:26 +02:00
|
|
|
|
2022-05-04 23:11:20 +02:00
|
|
|
|
|
|
|
def test_formsemestre(api_headers):
|
|
|
|
"""
|
2022-05-05 19:50:09 +02:00
|
|
|
Route: /formsemestre/<id>
|
2022-05-04 23:11:20 +02:00
|
|
|
"""
|
2022-03-10 17:43:12 +01:00
|
|
|
r = requests.get(
|
2022-05-04 23:11:20 +02:00
|
|
|
API_URL + "/formsemestre/1",
|
|
|
|
headers=api_headers,
|
2022-04-13 12:39:10 +02:00
|
|
|
verify=CHECK_CERTIFICATE,
|
|
|
|
)
|
2022-03-10 17:43:12 +01:00
|
|
|
assert r.status_code == 200
|
2022-04-20 15:50:02 +02:00
|
|
|
formsemestre = r.json()
|
2022-05-05 19:50:09 +02:00
|
|
|
assert verify_fields(formsemestre, FSEM_FIELDS)
|
2022-04-20 15:50:02 +02:00
|
|
|
|
2022-04-13 12:39:10 +02:00
|
|
|
|
2022-05-04 23:11:20 +02:00
|
|
|
def test_etudiant_bulletin(api_headers):
|
|
|
|
"""
|
|
|
|
Route:
|
|
|
|
"""
|
2022-03-10 17:43:12 +01:00
|
|
|
r = requests.get(
|
2022-05-04 23:11:20 +02:00
|
|
|
API_URL + "/formsemestre/1/etudiant/etudid/1/bulletin",
|
|
|
|
headers=api_headers,
|
2022-04-13 12:39:10 +02:00
|
|
|
verify=CHECK_CERTIFICATE,
|
|
|
|
)
|
2022-03-10 17:43:12 +01:00
|
|
|
assert r.status_code == 200
|
2022-03-09 16:52:07 +01:00
|
|
|
|
2022-03-10 17:43:12 +01:00
|
|
|
r = requests.get(
|
2022-05-04 23:11:20 +02:00
|
|
|
API_URL + "/formsemestre/1/etudiant/nip/1/bulletin",
|
|
|
|
headers=api_headers,
|
2022-04-13 12:39:10 +02:00
|
|
|
verify=CHECK_CERTIFICATE,
|
|
|
|
)
|
2022-03-10 17:43:12 +01:00
|
|
|
assert r.status_code == 200
|
2022-03-09 16:52:07 +01:00
|
|
|
|
2022-03-10 17:43:12 +01:00
|
|
|
r = requests.get(
|
2022-05-04 23:11:20 +02:00
|
|
|
API_URL + "/formsemestre/1/etudiant/ine/1/bulletin",
|
|
|
|
headers=api_headers,
|
2022-04-13 12:39:10 +02:00
|
|
|
verify=CHECK_CERTIFICATE,
|
|
|
|
)
|
2022-03-10 17:43:12 +01:00
|
|
|
assert r.status_code == 200
|
2022-03-09 16:52:07 +01:00
|
|
|
|
2022-04-13 12:39:10 +02:00
|
|
|
|
2022-05-04 23:11:20 +02:00
|
|
|
def test_bulletins(api_headers):
|
|
|
|
"""
|
|
|
|
Route:
|
|
|
|
"""
|
2022-04-27 14:11:06 +02:00
|
|
|
r = requests.get(
|
2022-05-04 23:11:20 +02:00
|
|
|
API_URL + "/formsemestre/1/bulletins",
|
|
|
|
headers=api_headers,
|
2022-04-27 14:11:06 +02:00
|
|
|
verify=CHECK_CERTIFICATE,
|
|
|
|
)
|
|
|
|
assert r.status_code == 200
|
|
|
|
|
|
|
|
|
2022-04-20 15:50:02 +02:00
|
|
|
# # jury
|
|
|
|
# def test_jury():
|
|
|
|
# r = requests.get(
|
2022-05-04 23:11:20 +02:00
|
|
|
# API_URL + "/formsemestre/1/jury",
|
|
|
|
# headers=api_headers,
|
2022-04-20 15:50:02 +02:00
|
|
|
# verify=CHECK_CERTIFICATE,
|
|
|
|
# )
|
|
|
|
# assert r.status_code == 200
|
2022-05-02 16:29:26 +02:00
|
|
|
|
2022-05-04 23:11:20 +02:00
|
|
|
# TODO A revoir
|
|
|
|
def test_semestre_index(api_headers):
|
|
|
|
"""
|
|
|
|
Route: TODO
|
|
|
|
"""
|
2022-05-02 16:29:26 +02:00
|
|
|
ue_fields = [
|
|
|
|
"semestre_idx",
|
|
|
|
"type",
|
|
|
|
"formation_id",
|
|
|
|
"ue_code",
|
|
|
|
"id",
|
|
|
|
"ects",
|
|
|
|
"acronyme",
|
|
|
|
"is_external",
|
|
|
|
"numero",
|
|
|
|
"code_apogee",
|
|
|
|
"titre",
|
|
|
|
"coefficient",
|
|
|
|
"color",
|
|
|
|
"ue_id",
|
|
|
|
]
|
|
|
|
|
|
|
|
ressource_fields = [
|
|
|
|
"heures_tp",
|
|
|
|
"code_apogee",
|
|
|
|
"titre",
|
|
|
|
"coefficient",
|
|
|
|
"module_type",
|
|
|
|
"id",
|
|
|
|
"ects",
|
|
|
|
"abbrev",
|
|
|
|
"ue_id",
|
|
|
|
"code",
|
|
|
|
"formation_id",
|
|
|
|
"heures_cours",
|
|
|
|
"matiere_id",
|
|
|
|
"heures_td",
|
|
|
|
"semestre_id",
|
|
|
|
"numero",
|
|
|
|
"module_id",
|
|
|
|
]
|
|
|
|
|
|
|
|
sae_fields = [
|
|
|
|
"heures_tp",
|
|
|
|
"code_apogee",
|
|
|
|
"titre",
|
|
|
|
"coefficient",
|
|
|
|
"module_type",
|
|
|
|
"id",
|
|
|
|
"ects",
|
|
|
|
"abbrev",
|
|
|
|
"ue_id",
|
|
|
|
"code",
|
|
|
|
"formation_id",
|
|
|
|
"heures_cours",
|
|
|
|
"matiere_id",
|
|
|
|
"heures_td",
|
|
|
|
"semestre_id",
|
|
|
|
"numero",
|
|
|
|
"module_id",
|
|
|
|
]
|
|
|
|
|
|
|
|
r = requests.get(
|
2022-05-04 23:11:20 +02:00
|
|
|
API_URL + "/formsemestre/1/programme",
|
|
|
|
headers=api_headers,
|
2022-05-02 16:29:26 +02:00
|
|
|
verify=CHECK_CERTIFICATE,
|
|
|
|
)
|
|
|
|
assert r.status_code == 200
|
|
|
|
assert len(r.json()) == 3
|
|
|
|
|
|
|
|
ue = r.json()["ues"][0]
|
|
|
|
ressource = r.json()["ressources"][0]
|
|
|
|
sae = r.json()["saes"][0]
|
|
|
|
|
|
|
|
fields_ue_OK = verify_fields(ue, ue_fields)
|
|
|
|
fields_ressource_OK = verify_fields(ressource, ressource_fields)
|
|
|
|
fields_sae_OK = verify_fields(sae, sae_fields)
|
|
|
|
|
|
|
|
assert fields_ue_OK is True
|
|
|
|
assert fields_ressource_OK is True
|
|
|
|
assert fields_sae_OK is True
|