Kisapalvelu, Kipa, on puhdas web-applikaatio. Laskenta on toteutettu Pythonilla. Web näkymät on rakennettu Django-ohjelmistokehyksen päälle, joka on toteuttu pythonilla. Kaikki syötteet tallennetaan sqlite-kantaan, jonka yhteydet hoitaa Django. SQLite-toiminnalisuus tulee Pythonin mukana. Web-palvelimena on käytetty Apachea sekä djangon kehitysserveriä, mutta ei pitäisi olla esteitä toteuttaa toiminnallisuutta millä tahansa web-palvelimella joka tukee Pythonin suorittamista. Django tukee myös MySQL- sekä PostegreSQL-kantoja, pienellä muutoksella settings.py tiedostoon. Mikäli haluat rakentaa julkisen verkkopalvelun jossa voluumi voi olla kovempi kannattaa tämä pitää mielessä.
Normaalikäytössä ei Kipa nosta mainittavasti koneen CPU-kuormaa. Yhdellä kannettavalla voidaan hyvin ajaa kisatoimiston palveluja. Piikkittäisiä kuormituksia syntyy ainoastaan tulosten laskemisesta, isohkoissa kilpailussa, jossa on tuhansia syötteitä, vie kaavojen parsiminen ja laskenta isoille sarjoille joissain tapauksissa joitain sekunteja. Testien mukaan kuorma kuitenkin säikeistyy käytössä olevien threadien määrän mukaan - kuitenkin vain yksi per istunto.
Alkuperäisessä Kehitysvaiheessa on testejä ajettu pitkään (muinaisella) 850Mhz Pentiumilla jossa 128Mt muistia - tälläiselläkään koneella ei suorituskykyongelmia tule muuta kuin hetkellisesti laskennassa.
Testimielessä Kipan kantaan on ajettu yhtäaikaa parikymmentä kilpailua kokonaisuudessaan, jolloin syötteiden määrä on noussut tuhansiin, tällä ei kuitenkaan ole nähty olevan vaikutusta suorituskykyyn.
- Luo Kipalle virtuaaliympäristö jonnekkin:
python -m venv /tmp/venv
- Ota virtuaaliympäristö käyttöön:
source /tmp/venv/bin/activate
- Asenna riippuvuudet:
pip install -r requirements.txt
- Luo jonnekkin väliaikainen hakemisto tietokannalle:
mkdir /tmp/tietokanta
- Kopioi kehitystietokanta:
cp docs/initial.db /tmp/tietokanta/kipa.db
cp ./web/settings/local.py.example ./web/settings/local.py
- Muokkaa edellisessä luotuun asetustiedostoon tietokantatiedostolle polku
/tmp/tietokanta/kipa.db
cd web
python manage.py migrate --fake-initial --noinput
python manage.py runserver
cd web
python manage.py test
Kipaa voi myös käyttää testipalvelimen kanssa, joka on muuten samanlainen kuin runserver, paitsi että se käyttää virtuaalista tietokantaa muistissa. Ei tee mitään muutoksia tiedostoihin. Turvallinen erilaisiin kokeiluihin. Voidaan täyttää halutulla tietokantapohjalla (fixture). esim.
python manage.py testserver fixtures/tests/katuu.xml
- Käynnistä Kipan kehityspalvelin
python -m venv ./robot-venv
source ./robot-venv/bin/activate
pip install robotframework robotframework-seleniumlibrary
robot --outputdir /tmp/test-report --variable BROWSER:headlessfirefox \ --exitonfailure ./web/robot/perustoiminnot.robot
Hakemistosta ./web/roobt
löytyy myös toinen robot-tiedosto nimeltään
autentikointi.txt
, mutta sen ajaminen ei taida onnistua, ellei ensin
toteuta Kipaan suunniteltua kirjautumista.
Koodi noudattaa Black-autoformatterin vesion 24.10.0 mukaista tyyliä.
Blackille annetaan lippu --target-version py312
. Templaatit formatoidaan
käyttäen djLint:tiä, joka ajetaan seuraavasti:
djlint --reformat --profile=django .
. Toisin kuin Black, djLint ei takaa
tiedostojen ehjänä pysymistä, joten muutosten tarkastaminen manuaalisesti
formatoinnin jälkeen voi olla tarpeen. Formatoinnit tarkastetaan osana
CI-putkea.
web/tupa/
admin.py
- Djangon luoman admin sivun määritely.
AritmeettinenLaskin.py
- Laskin joka laskee matemaattisia lauekeita merkkijonosta jossa on merkejä +-/*() sekä numeroita.
duplicate.py
- Tiedon monistaminen. Tehtävien kopiointi, XML-tietokantatiedoston luonti.
formit.py
- Perus formien määritys. Formeja käytetään näkymissä (views.py)
logger.py
- Kirjaus, ja nauhoitus. Kirjaa laskimen välivaiheita. Nauhoittaa post dataa.
models.py
- Django datamalli. Koko systeemin ydin.
- Datamalliin pohjatuu sekä tietokanta että näkymät.
- Myös laskin käyttää datamallia tiedon haussa.
TehatavanMaaritys.py
- Tehtävän määrityksen formit.
tests.py
- Yksikkötestit, Testaa järjestelmää erilaisilla testeillä.
- Aritmeettisen laskimen perustoimitukset.
- Sarjakohtaisten tulosten testaus.
- Kaikkien näkymien avautuminen testidatalla.
- Tiedon tallentuminen näkymillä.
- Yksikkötestit, Testaa järjestelmää erilaisilla testeillä.
Tuloslaskin.py
- Laskee tulokset tietokannan tietojen pohjalta.
urls.py
- Näkymien hakemistopolut.
views.py
- Näkymät, jokaisen sivun aivot.
web/tupa/templates/
404.html
500.html
base.html
web/tupa/templates/tupa/
- Näkymien templaatit
web/tupa/templates/tupa/forms/
- lomakekohtaiset templaatit
web/media/
- kuvat
- css
- yms. tiedostot