fix: Corriger les 84 échecs E2E pré-existants
Les tests E2E échouaient pour trois raisons principales : 1. Initialisation asynchrone TipTap — L'éditeur rich-text s'initialise via des imports dynamiques dans onMount(). Les tests interagissaient avec .rich-text-content avant que l'élément n'existe dans le DOM. Ajout d'attentes explicites avant chaque interaction avec l'éditeur. 2. Pollution inter-tests — Les fonctions de nettoyage (classes, subjects) ne supprimaient pas les tables dépendantes (homework, evaluations, schedule_slots), provoquant des erreurs FK silencieuses dans les try/catch. De plus, homework_submissions n'a pas de ON DELETE CASCADE sur homework_id, nécessitant une suppression explicite. 3. État partagé du tenant — Les règles de devoirs (homework_rules) et le calendrier scolaire (school_calendar_entries avec Vacances de Printemps) persistaient entre les fichiers de test, bloquant la création de devoirs dans des tests non liés aux règles.
This commit is contained in:
@@ -65,11 +65,14 @@ test.describe('Sessions Management', () => {
|
||||
// Page should load
|
||||
await expect(page.getByRole('heading', { name: /mes sessions/i })).toBeVisible();
|
||||
|
||||
// Should show at least one session
|
||||
await expect(page.getByText(/session.* active/i)).toBeVisible();
|
||||
// Wait for sessions to load (header text indicates data is present)
|
||||
await expect(page.getByText(/sessions? actives?/i)).toBeVisible({ timeout: 10000 });
|
||||
|
||||
// Wait for session cards to appear (data fully rendered)
|
||||
await expect(page.locator('.session-card').first()).toBeVisible({ timeout: 10000 });
|
||||
|
||||
// Current session should have the badge
|
||||
await expect(page.getByText(/session actuelle/i)).toBeVisible();
|
||||
await expect(page.getByText(/session actuelle/i)).toBeVisible({ timeout: 10000 });
|
||||
});
|
||||
|
||||
test('displays session metadata', async ({ page }, testInfo) => {
|
||||
|
||||
Reference in New Issue
Block a user