feat: Tracer automatiquement les événements notes et évaluations dans l'audit trail
Story 1-7 avait posé les fondations d'audit trail mais laissé en dehors du
périmètre initial les événements notes/évaluations, qui étaient alors non
couverts par les domaines. Avec la clôture des epics notation, ces actions
sensibles (création/modification/suppression d'évaluation, saisie/modification
de note, publication) doivent maintenant être tracées pour répondre aux
exigences RGPD et faciliter la résolution des litiges parent/enseignant.
Les événements de domaine existants ne transportaient pas tous les champs
nécessaires à l'audit (ancien/nouveau titre, description, barème, coefficient,
date, studentId). L'enrichissement de leur payload permet aux handlers d'audit
de journaliser les diffs complets via AuditLogger, sans que les autres
consommateurs (recalcul de moyennes) n'aient besoin de changer leur logique.
Au passage, le test E2E student-grades AC5 ("Nouveau" badge) visait
séquentiellement '.grade-card' puis '.badge-new' : la fenêtre de 3 s avant
markGradesSeen pouvait se refermer entre les deux attentes sur Firefox CI.
Un seul expect combiné '.grade-card .badge-new' élimine cette course.
This commit is contained in:
@@ -47,6 +47,10 @@ final class EvaluationTest extends TestCase
|
||||
self::assertCount(1, $events);
|
||||
self::assertInstanceOf(EvaluationCreee::class, $events[0]);
|
||||
self::assertSame($evaluation->id, $events[0]->evaluationId);
|
||||
self::assertSame($evaluation->title, $events[0]->title);
|
||||
self::assertSame($evaluation->description, $events[0]->description);
|
||||
self::assertSame($evaluation->gradeScale->maxValue, $events[0]->gradeScale);
|
||||
self::assertSame($evaluation->coefficient->value, $events[0]->coefficient);
|
||||
}
|
||||
|
||||
#[Test]
|
||||
@@ -136,6 +140,16 @@ final class EvaluationTest extends TestCase
|
||||
self::assertCount(1, $events);
|
||||
self::assertInstanceOf(EvaluationModifiee::class, $events[0]);
|
||||
self::assertSame($evaluation->id, $events[0]->evaluationId);
|
||||
self::assertSame('Contrôle chapitre 5', $events[0]->oldTitle);
|
||||
self::assertSame('Titre modifié', $events[0]->newTitle);
|
||||
self::assertSame('Évaluation sur les fonctions', $events[0]->oldDescription);
|
||||
self::assertSame('Nouvelle description', $events[0]->newDescription);
|
||||
self::assertSame(1.0, $events[0]->oldCoefficient);
|
||||
self::assertSame(2.0, $events[0]->newCoefficient);
|
||||
self::assertEquals(new DateTimeImmutable('2026-04-15'), $events[0]->oldEvaluationDate);
|
||||
self::assertEquals($newDate, $events[0]->newEvaluationDate);
|
||||
self::assertSame(20, $events[0]->oldGradeScale);
|
||||
self::assertSame(20, $events[0]->newGradeScale);
|
||||
}
|
||||
|
||||
#[Test]
|
||||
|
||||
@@ -179,6 +179,7 @@ final class GradeTest extends TestCase
|
||||
$events = $grade->pullDomainEvents();
|
||||
self::assertCount(1, $events);
|
||||
self::assertInstanceOf(NoteModifiee::class, $events[0]);
|
||||
self::assertSame(self::STUDENT_ID, $events[0]->studentId);
|
||||
self::assertSame(15.5, $events[0]->oldValue);
|
||||
self::assertSame(18.0, $events[0]->newValue);
|
||||
self::assertSame('graded', $events[0]->oldStatus);
|
||||
|
||||
Reference in New Issue
Block a user