2024-03-26 22:09:12 +01:00
|
|
|
from django.test import TestCase, tag
|
2021-09-19 00:45:23 +02:00
|
|
|
from django.urls import reverse
|
2024-10-30 15:03:17 +01:00
|
|
|
from personalni.models import Skola
|
2024-08-05 11:46:38 +02:00
|
|
|
from personalni.utils import sync_skoly
|
2021-09-19 00:45:23 +02:00
|
|
|
|
2024-03-26 22:09:12 +01:00
|
|
|
@tag('stejny-model-na-produkci')
|
2021-09-19 00:45:23 +02:00
|
|
|
class OrgSkolyAutocompleteTestCase(TestCase):
|
|
|
|
@classmethod
|
|
|
|
def setUpClass(cls):
|
|
|
|
super().setUpClass()
|
|
|
|
sync_skoly('https://mam.mff.cuni.cz/')
|
|
|
|
# Správné školy podle toho, co orgové poslali: (prefix, ID školy)
|
|
|
|
# NOTE: Pozor, jedná se o databázové indexy. Pokud se to někdy rozbije, bude potřeba je přepsat nebo předělat na IZO
|
2023-02-06 22:31:42 +01:00
|
|
|
# TODO: Opravit zakomentované školy.
|
2021-09-19 00:45:23 +02:00
|
|
|
cls.spravna_data = [
|
|
|
|
('gymnázium kolín', 53),
|
|
|
|
('kolín', 53),
|
2023-02-06 21:58:16 +01:00
|
|
|
#('gasoš', 96),
|
2021-09-19 00:45:23 +02:00
|
|
|
('Rokycany', 96),
|
2023-02-06 21:58:16 +01:00
|
|
|
#('gasoš Rokycany', 96),
|
|
|
|
#('SPŠE Pardubice', 815),
|
2021-09-19 00:45:23 +02:00
|
|
|
('Jaroše', 164),
|
2023-02-06 21:58:16 +01:00
|
|
|
#("Gymnázium, Brno, tř. Kpt. Jaroše", 164),
|
2021-09-19 00:45:23 +02:00
|
|
|
("Jírovcova", 157),
|
|
|
|
('České Budějovice', 157),
|
|
|
|
("Gymnázium, České Budějovice, Jírovcova 8", 157),
|
2023-02-06 21:58:16 +01:00
|
|
|
#("první soukromé", 2),
|
2021-09-19 00:45:23 +02:00
|
|
|
("Gymnázium Elgartova", 147),
|
|
|
|
("Jihlava", 45),
|
|
|
|
('Milevsko', 223),
|
|
|
|
("Gymnázium Milevsko", 223),
|
|
|
|
("Gymnázium Žamberk", 257),
|
|
|
|
("Žamberk", 257),
|
|
|
|
("Mendelovo", 201),
|
|
|
|
("Omská", 1038),
|
|
|
|
("Omsk", 1038),
|
|
|
|
("machar", 15),
|
|
|
|
("J. S. Machar", 15),
|
|
|
|
("Brandýs", 15),
|
|
|
|
]
|
|
|
|
|
|
|
|
def test_view_funguje(self):
|
|
|
|
"""Jen se pokusí udělat na ten view dotaz a kouká na odpověď"""
|
|
|
|
resp = self.client.get(reverse('autocomplete_skola'))
|
|
|
|
self.assertEqual(resp.status_code, 200)
|
|
|
|
|
|
|
|
def test_skoly_vraceny(self):
|
|
|
|
"""Testuje, že pro každého orga je jeho škola ve výsledném QuerySetu"""
|
|
|
|
for pfx, id in self.spravna_data:
|
|
|
|
with self.subTest(prefix=pfx, spravne_id=id):
|
2024-10-30 15:03:17 +01:00
|
|
|
spravna_skola = Skola.objects.get(id=id)
|
2021-09-19 00:45:23 +02:00
|
|
|
# Zeptáme se view, co si myslí
|
|
|
|
resp = self.client.get(reverse('autocomplete_skola')+'?q='+pfx).json()
|
|
|
|
ids = [int(x['id']) for x in resp['results']]
|
|
|
|
self.assertIn(spravna_skola.id, ids, f"Škola nenalezena v odpovědi")
|
|
|
|
|
|
|
|
def test_skoly_pocet(self):
|
|
|
|
"""Testuje, že se pro dané prefixy nevrací moc škol"""
|
|
|
|
limit = 20
|
|
|
|
for pfx, id in self.spravna_data:
|
|
|
|
# Kopírování …
|
|
|
|
with self.subTest(prefix=pfx, spravne_id=id):
|
|
|
|
resp = self.client.get(reverse('autocomplete_skola')+'?q='+pfx).json()
|
|
|
|
self.assertLessEqual(len(resp['results']), limit, f"Dotaz vrací moc škol")
|
|
|
|
|