Skip to content

ProjektAdLer/MoodlePluginLocal

Repository files navigation

AdLer Moodle Plugin

Coverage Status

Dependencies

Note

Dieses Projekt folgt nicht vollständig dem Moodle-Ansatz zur Angabe von Abhängigkeiten in der version.php-Datei, da dies Probleme bei Updates und Deinstallationen verursacht.

Plugin Version
availability_adler ~3.0.0
local_logging jede

Kompabilität

Folgende Versionen werden unterstützt (mit mariadb und postresql getestet):

Moodle Branch PHP Version
MOODLE_401_STABLE (LTS) 8.1
MOODLE_402_STABLE 8.1
MOODLE_402_STABLE 8.2
MOODLE_403_STABLE 8.1
MOODLE_403_STABLE 8.2
MOODLE_404_STABLE 8.1
MOODLE_404_STABLE 8.2
MOODLE_404_STABLE 8.3

MBZ api endpunkt

Damit der mbz api endpunkt auch mit größeren Dateien funktioniert sind folgende Änderungen an der php.ini notwendig:

- `post_max_size` auf mindestens 2048M setzen
- `upload_max_filesize` auf 2048M setzen
- `max_input_time` auf 600 setzen
- `memory_limit` auf mindestens 256M setzen
- `max_execution_time` auf mindestens 60 setzen
- `output_buffering` auf 8192 setzen

Setup

  1. Dependencies beachten
  2. Plugin in moodle in den Ordner local entpacken (bspw. moodle/local/adler/lib.php muss es geben)
  3. Moodle upgrade ausführen

Kurs mit Testdaten seeden

Für Testzwecke können bestehende normale Kurse mit dummy Daten gefüllt werden. Im Ordner dev_utils liegt dazu das Skript seed.php.

Beispiel:
Für den Kurs mit der ID 142 werden Daten für folgende Elemente geseedet:

  • Kurs: Markierung als Adler Kurs
  • Section (Räume): availability conditions & required points to complete
  • course modules (Lernelemente): AdLer Scoring Befehl: php local/adler/dev_utils/seed.php --course-id=142 -c -m -s

Nun kann dieser Kurs zum Testen genutzt werden.

Dev Setup / Tests

Dieses Plugin nutzt Mockery für Tests. Die composer.json von Moodle enthält Mockery nicht, daher enthält das Plugin eine eigene composer.json.

Für das weitere Test-Setup siehe AdlerDevelopmentEnvironment, dort sind auch die Schritte zur weiteren PHPStorm Konfiguration beschrieben.

Hinweise:

  • Um Tests lokal nicht in @RunTestsInSeparateProcesses ausführen zu müssen in der Datei moodle/lib/setuplib.php in der Funktion require_phpunit_isolation() vor der Exception return; einfügen. \

  • Achtung: Dies kann potenziell unerwartete Nebeneffekte haben! Tests werden nicht umsonst normalerweise in isolierten Prozessen ausgeführt.

Löschen eines Kurses / von Lernelementen

  • Moodle hat einen Trashbin, das tatsächliche Löschen findet zeitverzögert statt.
  • Wird ein Kurs gelöscht gibt es keine Möglichkeit zu wissen, welche Lernelemente dabei entfernt wurden. Nach dem Löschen eines Kurses wird für alle Adler Einträge verglichen, ob das dazugehörige cm noch existiert. Dies könnte bei sehr großen Moodle Instanzen zu Performance Problemen führen. Ein workaround wäre eine redundante Datenhaltung der Kurs-ID bei jedem Eintrag.
Anzahl verbleibende Lernelemente mit Adler-Scores Anzahl der Lernelemente mit Adler-Scores des gelöschten Kurses Zeit
1k 100 0,12s
10k 100 2,5s
100k 100 186s