This repository was archived by the owner on Apr 6, 2026. It is now read-only.
forked from DreamLab-AI/nostr-rust-forum
-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathplaywright.config.ts
More file actions
107 lines (86 loc) · 2.31 KB
/
playwright.config.ts
File metadata and controls
107 lines (86 loc) · 2.31 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
import { defineConfig, devices } from '@playwright/test';
/**
* Playwright E2E Test Configuration for Nostr-BBS
*
* @see https://playwright.dev/docs/test-configuration
*/
export default defineConfig({
testDir: './tests/e2e',
// Run tests in files in parallel
fullyParallel: true,
// Fail the build on CI if you accidentally left test.only in the source code
forbidOnly: !!process.env.CI,
// Retry on CI only
retries: process.env.CI ? 2 : 0,
// Opt out of parallel tests on CI
workers: process.env.CI ? 1 : undefined,
// Reporter to use
reporter: [
['html'],
['list'],
['json', { outputFile: 'test-results/results.json' }]
],
// Shared settings for all the projects below
use: {
// Base URL to use in actions like `await page.goto('/')`
baseURL: process.env.BASE_URL || 'http://localhost:5173',
// Bypass CSP for testing (CSP blocks SvelteKit inline scripts in strict-dynamic mode)
bypassCSP: true,
// Collect trace when retrying the failed test
trace: 'on-first-retry',
// Screenshot only on failure
screenshot: 'only-on-failure',
// Video only on failure
video: 'retain-on-failure',
// Viewport size
viewport: { width: 1280, height: 720 },
// Default timeout for actions
actionTimeout: 10000,
// Default navigation timeout
navigationTimeout: 30000,
},
// Test timeout
timeout: 60000,
// Expect timeout
expect: {
timeout: 10000,
},
// Configure projects for major browsers
projects: [
{
name: 'chromium',
use: {
...devices['Desktop Chrome'],
launchOptions: {
args: ['--no-sandbox', '--disable-setuid-sandbox', '--disable-dev-shm-usage'],
},
},
},
{
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'] },
},
],
// Run your local dev server before starting the tests
webServer: {
command: 'npm run dev',
url: 'http://localhost:5173',
reuseExistingServer: !process.env.CI,
timeout: 120000,
stdout: 'ignore',
stderr: 'pipe',
},
});