1e896adeaa
global-setup.ts: - Usa launchPersistentContext en vez de browser.newContext() - Reemplaza storageState por marker file para cache de sesion - Captura logs de consola del browser para debug - Screenshots y HTML dump en caso de error playwright.config.ts: - Elimina storageState (ahora via persistent context fixture) - Screenshots siempre activas, video y trace en failures Tests (login, assistant-bot, asistente-2): - Importan test/expect desde persistent-context fixture - Usan handleElementDialogs() en vez de espera manual de rooms - Nuevo test de threads en asistente-2: verifica que el bot responde dentro del thread cuando se le habla por thread Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
40 lines
927 B
TypeScript
40 lines
927 B
TypeScript
import { defineConfig, devices } from "@playwright/test";
|
|
import * as dotenv from "dotenv";
|
|
import * as path from "path";
|
|
|
|
dotenv.config({ path: path.resolve(__dirname, ".env") });
|
|
|
|
export default defineConfig({
|
|
testDir: "./tests",
|
|
fullyParallel: false,
|
|
forbidOnly: !!process.env.CI,
|
|
retries: process.env.CI ? 1 : 0,
|
|
workers: 1,
|
|
reporter: "list",
|
|
|
|
// LLMs son lentos — timeouts generosos
|
|
timeout: 60_000,
|
|
expect: { timeout: 30_000 },
|
|
|
|
use: {
|
|
baseURL: process.env.ELEMENT_URL || "http://localhost:8080",
|
|
headless: true,
|
|
screenshot: "on",
|
|
trace: "retain-on-failure",
|
|
video: "retain-on-failure",
|
|
actionTimeout: 30_000,
|
|
// NO usamos storageState — usamos persistent context para preservar IndexedDB
|
|
},
|
|
|
|
outputDir: "./test-results",
|
|
|
|
globalSetup: "./global-setup.ts",
|
|
|
|
projects: [
|
|
{
|
|
name: "chromium",
|
|
use: { ...devices["Desktop Chrome"] },
|
|
},
|
|
],
|
|
});
|