-
Notifications
You must be signed in to change notification settings - Fork 5
Expand file tree
/
Copy pathplaywright.config.ts
More file actions
72 lines (58 loc) · 1.74 KB
/
playwright.config.ts
File metadata and controls
72 lines (58 loc) · 1.74 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
import { defineConfig, devices } from '@playwright/test';
/**
* Playwright Configuration for Real Browser Testing
*
* Purpose: Test SDK in actual browsers (Chrome, Firefox, Safari)
* This catches issues that jsdom might miss!
*
* Installation:
* npm install --save-dev @playwright/test
* npx playwright install
*
* Usage:
* npm run test:e2e
*/
export default defineConfig({
testDir: './test/e2e',
// Output directory for test artifacts (NOT test-results to avoid conflicts)
outputDir: 'reports/playwright-test-results',
// Run tests 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: [
['list'],
['json', { outputFile: 'test-results/playwright-results.json' }],
],
// Shared settings for all projects
use: {
// Base URL for tests
baseURL: 'http://localhost:3000',
// Collect trace when retrying the failed test
trace: 'on-first-retry',
// Screenshot on failure
screenshot: 'only-on-failure',
},
// Configure project for Chrome only (Phase 2 - Quick & Essential)
projects: [
{
name: 'chromium',
use: { ...devices['Desktop Chrome'] },
},
],
// Run local dev server before starting tests (if needed)
// Run a local web server for browser tests (to avoid CORS issues with file://)
webServer: {
command: 'npx http-server . -p 8765 --cors -s --silent',
port: 8765,
reuseExistingServer: !process.env.CI,
timeout: 30000,
stdout: 'ignore',
stderr: 'pipe',
},
});