Files
event-manager/playwright.config.ts
xadm 786cbc724f
CI / Server (push) Has been cancelled
Linters / Frappe Linter (push) Has been cancelled
Linters / Vulnerable Dependency Check (push) Has been cancelled
UI Tests / Playwright E2E Tests (push) Has been cancelled
Initialize fork and rebrand app to event_manager
2026-05-11 09:56:57 +02:00

177 lines
4.1 KiB
TypeScript

import { defineConfig, devices } from "@playwright/test";
// Auth state file path (added to .gitignore)
const authFile = "e2e/.auth/user.json";
/**
* Playwright configuration for Pohodex Event Manager E2E tests.
*
* Uses the recommended "setup project" pattern for authentication:
* 1. Setup project runs first and saves auth state to file
* 2. Other projects depend on setup and reuse the stored auth state
*
* @see https://playwright.dev/docs/auth
* @see https://playwright.dev/docs/test-configuration
*/
export default defineConfig({
testDir: "./e2e/tests",
fullyParallel: false, // Sequential for Frappe state consistency
forbidOnly: !!process.env.CI,
retries: process.env.CI ? 2 : 0,
workers: 1, // Single worker for Frappe session management
reporter: process.env.CI ? [["github"], ["html", { open: "never" }]] : "html",
timeout: 60000,
expect: {
timeout: 10000,
},
/* Shared settings for all the projects below. See https://playwright.dev/docs/api/class-testoptions. */
use: {
baseURL: process.env.BASE_URL || "http://event_manager.test:8000",
trace: "on-first-retry",
video: "retain-on-failure",
screenshot: "only-on-failure",
actionTimeout: 15000,
navigationTimeout: 30000,
},
/* Configure projects for major browsers */
projects: [
{
name: "setup",
testMatch: /auth\.setup\.ts/,
},
{
name: "event-setup",
testMatch: /event\.setup\.ts/,
use: {
storageState: authFile,
},
dependencies: ["setup"],
},
{
name: "login-modal",
testMatch: /login-modal\.spec\.ts/,
use: {
...devices["Desktop Chrome"],
storageState: { cookies: [], origins: [] },
},
dependencies: ["setup"],
},
{
name: "chromium",
testIgnore: /guest-booking|custom-forms|event-proposal|login-modal/,
use: {
...devices["Desktop Chrome"],
storageState: authFile,
},
dependencies: ["setup", "event-setup"],
},
{
name: "guest-event-setup",
testMatch: /guest-event\.setup\.ts/,
use: {
storageState: authFile,
},
dependencies: ["setup"],
},
{
name: "guest-chromium",
testMatch: /guest-booking\.spec\.ts/,
use: {
...devices["Desktop Chrome"],
},
dependencies: ["guest-event-setup"],
},
{
name: "custom-forms-setup",
testMatch: /custom-forms\.setup\.ts/,
use: {
storageState: authFile,
},
dependencies: ["setup"],
},
{
name: "custom-forms-chromium",
testMatch: /custom-forms\.spec\.ts/,
use: {
...devices["Desktop Chrome"],
storageState: authFile,
},
dependencies: ["custom-forms-setup"],
},
{
name: "event-proposal-setup",
testMatch: /event-proposal\.setup\.ts/,
use: {
storageState: authFile,
},
dependencies: ["setup"],
},
{
name: "event-proposal-chromium",
testMatch: /event-proposal\.spec\.ts/,
use: {
...devices["Desktop Chrome"],
storageState: authFile,
},
dependencies: ["event-proposal-setup"],
},
{
name: "offline-payment-setup",
testMatch: /offline-payment\.setup\.ts/,
use: {
storageState: authFile,
},
dependencies: ["setup"],
},
{
name: "offline-payment-chromium",
testMatch: /offline-payment\.spec\.ts/,
use: {
...devices["Desktop Chrome"],
storageState: authFile,
},
dependencies: ["offline-payment-setup"],
},
// {
// name: "firefox",
// use: { ...devices["Desktop Firefox"] },
// },
// {
// name: "webkit",
// use: { ...devices["Desktop Safari"] },
// },
/* Test against mobile viewports. */
// {
// name: 'Mobile Chrome',
// use: { ...devices['Pixel 5'] },
// },
// {
// name: 'Mobile Safari',
// use: { ...devices['iPhone 12'] },
// },
/* Test against branded browsers. */
// {
// name: 'Microsoft Edge',
// use: { ...devices['Desktop Edge'], channel: 'msedge' },
// },
// {
// name: 'Google Chrome',
// use: { ...devices['Desktop Chrome'], channel: 'chrome' },
// },
],
/* Run your local dev server before starting the tests */
// webServer: {
// command: 'npm run start',
// url: 'http://localhost:3000',
// reuseExistingServer: !process.env.CI,
// },
});