Vor ein paar Wochen haben wir unsere generator-action vorgestellt, welche die einfache Generierung von Zikula-Erweiterungen mit dem Standalone Generator von ModuleStudio erlaubt. Diese Action wird als Docker Image bereitgestellt und kann auch losgelöst von GitHub Actions verwendet werden.
Die zikula-action
Analog dazu steht auch eine weitere GitHub Action zur Verfügung: die zikula-action. Dieses Docker Image basiert auf der ebenfalls bereits vorgestellten phpqa-Toolbox und hat somit Zugriff auf zahlreiche Tools rund um Analyse, Tests und Qualitätssicherung.
Die Idee besteht darin, dass man die gewünschte Zikula-Version auswählt und die Liste der gewünschten Tools und Prüfungen angibt, die ausgeführt werden sollen. Es war eine bewusste Entscheidung, hier auf Einstellbarkeit im Detail zu verzichten und dafür die Dinge schnell und einfach steuern zu können (convention over configuration). Denn so lassen sich Änderungen zentral in der Action vornehmen und werden von dort aus auf alle möglichen Extensions angewendet.
Was steckt drin?
Grundsätzlich führt die zikula-action folgende Schritte aus:
- Ausführen von Composer zur Installation von Abhängigkeiten des entsprechenden Moduls.
- Herunterladen der gewünschten Zikula Core Version (entweder Releases oder Entwicklungsversionen von Git)
- Ausführen von Composer zur Installation von Abhängigkeiten des Cores (nur bei Entwicklungsversionen).
- CLI-basierte Installation von Zikula.
- CLI-basierte Installation des Moduls.
- Ausführen diverser Tools (einstellbar): Linter, Coding Style, PHPUnit, Sicherheitsprüfungen, Infos über diverse Metriken, andere Checks bzgl. Deprecations, Code Smells etc.
- Paketierung des Moduls inklusive erneuter Installation der Abhängigkeiten (ohne Entwicklungsswerkzeugen).
Ein Workflow als Beispiel
Damit die Installation von Zikula funktioniert, muss eine Datenbank bereitgestellt werden. Das geht zum Glück mit GitHub Actions sehr einfach. Hier ein Beispiel für einen kompletten Workflow. Am Ende wird dann das Verzeichnis mit den Release-Archiven als Artefakt hochgeladen.