Update opolka/ScoDoc from ScoDoc/ScoDoc #2

Merged
opolka merged 1272 commits from ScoDoc/ScoDoc:master into master 2024-05-27 09:11:04 +02:00
2 changed files with 58 additions and 1 deletions
Showing only changes of commit b8767c7536 - Show all commits

View File

@ -253,7 +253,7 @@ class ScoDocSiteConfig(db.Model):
cfg = ScoDocSiteConfig.query.filter_by(name=name).first() cfg = ScoDocSiteConfig.query.filter_by(name=name).first()
if cfg is None: if cfg is None:
return default return default
return cfg.value or "" return cls.NAMES.get(name, lambda x: x)(cfg.value or "")
@classmethod @classmethod
def set(cls, name: str, value: str) -> bool: def set(cls, name: str, value: str) -> bool:

View File

@ -0,0 +1,57 @@
# -*- coding: utf-8 -*-
"""Test ScoDocSiteConfig (paramétrage général)
Utiliser comme:
pytest tests/unit/test_site_config.py
"""
from app.models import ScoDocSiteConfig
from app.comp.bonus_spo import BonusIUTRennes1
from app.scodoc import sco_utils as scu
def test_scodoc_site_config(test_client):
"""Classe pour paramètres généraux"""
cfg = ScoDocSiteConfig.get_dict()
assert cfg == {} # aucune valeur au départ
try:
ScoDocSiteConfig.set_bonus_sport_class("invalid")
assert False # la ligne precédente doit lancer une exception
except NameError:
pass
bonus_sport = "bonus_iut_rennes1"
ScoDocSiteConfig.set_bonus_sport_class(bonus_sport)
cfg = ScoDocSiteConfig.get_dict()
assert tuple(ScoDocSiteConfig.get_dict().values()) == (bonus_sport,)
assert ScoDocSiteConfig.get_bonus_sport_class_name() == bonus_sport
assert ScoDocSiteConfig.get_bonus_sport_class() == BonusIUTRennes1
bonus_sport_class_names = ScoDocSiteConfig.get_bonus_sport_class_names()
assert isinstance(bonus_sport_class_names, list)
assert "" in bonus_sport_class_names
assert bonus_sport in bonus_sport_class_names
assert len(bonus_sport_class_names) > 5
assert all([x == "" or x.startswith("bonus_") for x in bonus_sport_class_names])
apo_dict = ScoDocSiteConfig.get_codes_apo_dict()
assert isinstance(apo_dict, dict)
assert "ABAN" in apo_dict
assert "ADM" in apo_dict
assert len(apo_dict) > 5
ScoDocSiteConfig.set_code_apo("ADSUP", "AZERTY")
assert ScoDocSiteConfig.get_codes_apo_dict()["ADSUP"] == "AZERTY"
assert ScoDocSiteConfig.get_code_apo("ADSUP") == "AZERTY"
assert ScoDocSiteConfig.get("azerty") == "" # default empty string
assert ScoDocSiteConfig.set("azerty", 99)
assert ScoDocSiteConfig.get("azerty") == "99" # converted to string
assert "azerty" in ScoDocSiteConfig.get_dict()
assert ScoDocSiteConfig.set("always_require_ine", 99)
# Converti en bool car déclaré dans NAMES:
assert ScoDocSiteConfig.get_dict()["always_require_ine"] == True
assert ScoDocSiteConfig.get("always_require_ine") == True
#
assert (
ScoDocSiteConfig.get_month_debut_annee_scolaire()
== scu.MONTH_DEBUT_ANNEE_SCOLAIRE
)