mamweb/docs/skripty.rst

109 lines
4.8 KiB
ReStructuredText
Raw Normal View History

2022-11-21 23:48:12 +01:00
Skripty pro práci s repozitářem
===================
Máme dvě hlavní sady skriptů/příkazů na ovládání webu a repozitáře. Skripty pro
práci s webem psané v Pythonu jsou uložené ve složkách
``<aplikace>/management/commands/``, případně vestavěné, a volají se pomocí
``./manage.py <příkaz>``. Oproti tomu skripty pro práci s repozitářem a pro
úpravy databáze a souborů „zvenčí“ se nejčastěji nacházejí ve složce ``make/``
a volají se pomocí cesty: ``make/<příkaz>``.
Občas existují i nějaké další skripty na různých jiných místech. Všechny by
měly být ideálně popsány asi tady.
Make skripty
----
Skripty v ``make/`` se označují jako „Make skripty“. Slouží často k velkým
úkonům s repozitářem, jako je nasazení celého webu, zprovoznění lokálního webu
a podobně.
2022-11-21 23:52:58 +01:00
.. note:: Označení pro tyto skripty je dáno tím, že byly původně volány pomocí
2022-11-21 23:48:12 +01:00
make (tj. z Makefile). Ve skutečnosti je lze stále volat i jako ``make
<skript>``, ale pak není možné předávat parametry a obecně je tato cesta
zastaralá a existuje jen pro zpětnou kompatibilitu se svalovou pamětí.
Tyto skripty jsou samonosné, dají se spustit rovnou a v případě problémů si
budou hlasitě stěžovat. Pro účely debugování různých věcí jsou ale (bohužel?)
hlasité i při normálním spuštění, konkrétně vypisují všechny příkazy, které se
spouštějí (\ ``set -x``). Tyto příkazy jsou vidět za jedním či více plusky (\ ``+``).
.. tip:: Pokud některý make skript selže, tak by na konci měl vypsat, že se něco nepovedlo.
Knihovna ``make/lib.sh``
^^^^^^
Pro pohodlí při psaní velká část z nich využívá knihovnu uloženou
v ``make/lib.sh``. Jsou zde definované užitečné proměnné, kontroly a společný
kód. Kromě toho při inicializaci otestuje, že je skript spuštěn z kořene
repozitáře (takže to pak není potřeba zkoumat v ostatních skriptech).
Proměnné
"""""
Popsány jsou jen užitečné proměnné, ve skutečnosti jich je definovaných víc,
ale jsou triviální a samopopisné.
2022-11-22 00:00:22 +01:00
``VENV_PATH``
2022-11-21 23:48:12 +01:00
Cesta virtuálního prostředí. Též lze přepsat.
2022-11-22 00:00:22 +01:00
``REPO``
2022-11-21 23:48:12 +01:00
Cesta ke gitovému repozitáři na serveru, rovnou použitelná v ``git clone``
2022-11-22 00:00:22 +01:00
``GIMLI_LOGIN``
2022-11-21 23:48:12 +01:00
Přihlašovací údaje ke Gimlimu
2022-11-22 00:00:22 +01:00
``PRODWEB`` a ``TESTWEB``
2022-11-21 23:48:12 +01:00
Cesty ke složkám s produkčním a testovacím webem
Funkce a další zkratky
""""""
2022-11-22 00:00:22 +01:00
``ensure_venv``
2022-11-21 23:48:12 +01:00
Zajistí, že se zbytek skriptu spustí ve virtuálním prostředí, a pokud neexistuje, tak jej založí.
2022-11-22 00:00:22 +01:00
``ensure_web_installed``
2022-11-21 23:48:12 +01:00
Vyzkouší, že je web (django) aspoň elementárně zprovozněno a pokud ne, tak vyzve uživatele, aby to spravil.
2022-11-22 00:00:22 +01:00
``gimli_only``
2022-11-21 23:48:12 +01:00
Otestuje, že je příkaz spuštěn na Gimlim, pokud tomu tak není, zeptá se, jestli si uživatel skutečně přeje zbytek skriptu vykonat
2022-11-22 00:00:22 +01:00
``only_in_directory <složka>``
2022-11-21 23:48:12 +01:00
Otestuje, že skript běží z konkrétní složky. Zejména použitelné s ``gimli_only`` a ``$TESTWEB``
2022-11-22 00:00:22 +01:00
``safe_checkout_branch <větev>``
2022-11-21 23:48:12 +01:00
Bezpečně přepne repozitář na jinou větev. Pokud by mělo dojít k přepsání
knihovny nebo volajícího make skriptu, vyzve uživatele, aby přepnul ručně.
2022-11-22 00:00:22 +01:00
``install_everything``
2022-11-21 23:48:12 +01:00
Společná část kódu pro nasazování produkce a testwebu.
Skripty pro lokální vývoj
^^^^^^^
2022-11-22 00:00:22 +01:00
``make/install_web`` (nebo ekvivalentně ``make/install``)
2022-11-21 23:48:12 +01:00
Vytvoří virtualenv a nainstaluje do něj závislosti webu podle ``requirements.txt``. Následně popíše, jak vyrobit zbytek lokálního webu.
2022-11-22 00:00:22 +01:00
``make/run``
2022-11-21 23:48:12 +01:00
Spustí lokální web (ekvivalentní s ``./manage.py runserver``)
2022-11-22 00:00:22 +01:00
``make/schema``
2022-11-21 23:48:12 +01:00
Vykreslí závislosti a atributy modelů
2022-11-22 00:00:22 +01:00
``make/sync_prod_flatpages``
2022-11-21 23:48:12 +01:00
Stáhne z produkce aktuální statické stránky a uloží je do složky ``data/``
2022-11-22 00:00:22 +01:00
``make/test``
2022-11-21 23:48:12 +01:00
Spustí testy (ekvivalentní s ``./manage.py test -v2``)
2022-11-22 00:00:22 +01:00
``make/init_local``
2022-11-21 23:48:12 +01:00
Zkratka za posloupnost ``make/install_web``, ``./manage.py testdata``, ``./manage.py loaddata data/*``, ``make/sync_prod_flatpages``
Práce s testwebem
^^^^^^^
2022-11-22 00:00:22 +01:00
``make/deploy``
2022-11-21 23:48:12 +01:00
Nasadí testweb. Volitelně bere jako parametr jméno větve, kterou má nasadit.
Rovnou nastaví přihlašování a vygeneruje příslušnou verzi dokumentace `sem <https://mam-test.ks.matfyz.cz/docs>`_.
2022-11-22 00:00:22 +01:00
``make/push_compiled_vue_to_test``
2022-11-21 23:48:12 +01:00
**Neotestováno** Nahraje Vue z lokálního počítače na testweb. (Gimli často má moc starou verzi Node.js, takže nejde zkompilovat tam)
2022-11-22 00:00:22 +01:00
``make/sync_test_db_aggressive``
2022-11-21 23:48:12 +01:00
Zkopíruje databázi z produkčního webu.
2022-11-22 00:00:22 +01:00
``make/sync_test_media``
2022-11-21 23:48:12 +01:00
Zkopíruje média (obrázky, nahrané soubory) z produkčního webu.
2022-11-22 00:00:22 +01:00
``make/sync_test``
2022-11-21 23:48:12 +01:00
Zkratka za ``make/sync_test_db_aggressive`` + ``make/sync_test_media``.
Nasazení produkce
^^^^
``make/deploy_prod``. Před samotným nasazením zálohuje databázi a zkontroluje, že se nasazuje větev ``master``.