-
Notifications
You must be signed in to change notification settings - Fork 8
Expand file tree
/
Copy pathplaywright.config.ts
More file actions
123 lines (109 loc) · 4.06 KB
/
playwright.config.ts
File metadata and controls
123 lines (109 loc) · 4.06 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
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
import { defineConfig, devices } from '@playwright/test';
import type { LaravelOptions } from '@saucebase/laravel-playwright';
import 'dotenv/config';
import { collectModulePlaywrightConfigs } from './module-loader.js';
const BASE_URL = process.env.APP_URL ?? 'http://localhost';
export type ModulePlaywrightConfig = {
name: string;
testDir: string;
use?: Record<string, unknown>;
// allow arbitrary extra properties
[key: string]: unknown;
};
async function createConfig() {
// Collect Playwright configs from all modules
// cast to ModulePlaywrightConfig[] so modules can include extra keys beyond name/testDir/use
const { projects: moduleProjects, setups: moduleSetups } =
((await collectModulePlaywrightConfigs()) || {
projects: [],
setups: [],
}) as {
projects: ModulePlaywrightConfig[];
setups: ModulePlaywrightConfig[];
};
const testDevices = [
'Desktop Chrome',
// 'Desktop Firefox',
// 'Desktop Safari',
// 'iPhone 14',
// Add more devices here if needed
];
const projects = [
/**
* Default project for core E2E tests
*/
{
name: '@Core',
testDir: './tests/e2e',
use: {}, // will be extended below
dependencies: ['database.setup'], // Ensure database setup runs before core tests
} as ModulePlaywrightConfig,
// Add more projects here if needed
]
.concat(moduleProjects)
.map((project) => {
// Extend each project with the selected devices
return testDevices.map((device) => {
return {
...project,
name: `${project.name} [${device}]`,
use: { ...devices[device], ...(project.use ?? {}) },
};
});
})
.flat();
/**
* @see https://playwright.dev/docs/test-configuration
*/
return defineConfig<LaravelOptions>({
/* 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. See https://playwright.dev/docs/test-reporters */
reporter: [['html', { outputFolder: 'playwright-report' }], ['list']],
/* Folder for test artifacts such as screenshots, videos, traces, etc. */
testDir: './tests/e2e',
/* Shared settings for all the projects below. See https://playwright.dev/docs/api/class-testoptions. */
use: {
/* Base URL to use in actions like `await page.goto('/')`. */
baseURL: BASE_URL,
/* Collect trace when retrying the failed test. See https://playwright.dev/docs/trace-viewer */
trace: 'on-first-retry',
/* Take screenshot only on failures */
screenshot: 'only-on-failure',
/* Record video only on failures */
video: 'retain-on-failure',
/* Ignore HTTPS errors */
ignoreHTTPSErrors: true,
/** Laravel Playwright integration */
laravelBaseUrl: `${BASE_URL}/playwright`,
laravelSecret: process.env.PLAYWRIGHT_SECRET,
},
/* Configure projects for major browsers */
projects: [
/**
* Global setup
*/
{
name: 'database.setup',
testMatch: /database\.setup\.ts/,
},
...moduleSetups,
...projects,
],
/* Only start webServer locally (not in CI where we build assets) */
...(!process.env.CI && {
webServer: {
command: `npx vite --port 5173`,
timeout: 10 * 1000,
reuseExistingServer: true,
},
}),
});
}
export default createConfig();