-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathplaywright.config.ts
143 lines (131 loc) · 3.88 KB
/
playwright.config.ts
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
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
import path from 'path';
import { loadEnvConfig } from '@next/env';
import type { PlaywrightTestConfig } from '@playwright/test';
import { devices } from '@playwright/test';
import pc from 'picocolors';
const webServerModes = ['DEV', 'START', 'BUILD_AND_START'] as const;
type WebServerMode = typeof webServerModes[number];
const isCI = ['true', '1'].includes(process.env?.CI ?? '');
const webServerMode =
(process.env?.E2E_WEBSERVER_MODE as WebServerMode) ?? 'NOT_SET';
const webServerPort = 3000;
const outputDir = path.join(__dirname, 'e2e/.out');
type WebServerConfig = { cmd: string; timeout: number; retries: number };
const webServerConfigs: Record<WebServerMode, WebServerConfig> = {
START: {
cmd: `yarn start -p ${webServerPort}`,
timeout: isCI ? 90_000 : 30_000,
retries: isCI ? 3 : 1,
},
DEV: {
cmd: `yarn dev -p ${webServerPort}`,
timeout: 30_000,
retries: 1,
},
BUILD_AND_START: {
cmd: `NEXT_IGNORE_TYPECHECKS=1 yarn build --no-lint && yarn start -p ${webServerPort}`,
timeout: isCI ? 180_000 : 120_000,
retries: isCI ? 3 : 1,
},
};
if (typeof webServerConfigs?.[webServerMode] !== 'object') {
console.error(
`${pc.red(
'error'
)} - E2E_WEBSERVER_MODE must be one of '${webServerModes.join(', ')}'`
);
process.exit(1);
} else {
console.log(
`${pc.green('notice')} - Using E2E_WEBSERVER_MODE: '${webServerMode}'`
);
}
const webServerConfig = webServerConfigs[webServerMode];
function getNextJsEnv(): Record<string, string> {
const { combinedEnv, loadedEnvFiles } = loadEnvConfig(__dirname);
loadedEnvFiles.forEach((file) => {
console.log(
`${pc.green('notice')}- Loaded nextjs environment file: './${file.path}'`
);
});
return Object.keys(combinedEnv).reduce<Record<string, string>>((acc, key) => {
const v = combinedEnv[key];
if (v !== undefined) acc[key] = v;
return acc;
}, {});
}
// Reference: https://playwright.dev/docs/test-configuration
/**
* @type {Partial<import('@playwright/test').PlaywrightTestConfig>}
*/
const config: PlaywrightTestConfig = {
testDir: path.join(__dirname, 'e2e'),
/* Maximum time one test can run for. */
timeout: webServerConfig.timeout,
retries: webServerConfig.retries,
/* Opt out of parallel tests on CI. */
workers: process.env.CI ? 1 : undefined,
// Artifacts folder where screenshots, videos, and traces are stored.
outputDir: `${outputDir}/output`,
preserveOutput: 'always',
reporter: [
isCI ? ['github'] : ['list'],
['json', { outputFile: `${outputDir}/reports/test-results.json` }],
[
'html',
{
outputFolder: `${outputDir}/reports/html`,
open: isCI ? 'never' : 'on-failure',
},
],
],
// https://playwright.dev/docs/test-advanced#launching-a-development-web-server-during-the-tests
webServer: {
command: webServerConfig.cmd,
port: webServerPort,
timeout: webServerConfig.timeout,
reuseExistingServer: !isCI,
env: getNextJsEnv(),
},
use: {
// Retry a test if it's failing with enabled tracing. This allows you to analyse the DOM, console logs, network traffic etc.
// More information: https://playwright.dev/docs/trace-viewer
trace: 'retry-with-trace',
contextOptions: {
ignoreHTTPSErrors: true,
},
},
projects: [
{
name: 'Desktop Chrome',
use: {
...devices['Desktop Chrome'],
},
},
// {
// name: 'Desktop Firefox',
// use: {
// ...devices['Desktop Firefox'],
// },
// },
// {
// name: 'Desktop Safari',
// use: {
// ...devices['Desktop Safari'],
// },
// },
// Test against mobile viewports.
{
name: 'Mobile Chrome',
use: {
...devices['Pixel 5'],
},
},
// Mobile Safari is not supported on CI/Linux yet.
// {
// name: 'Mobile Safari',
// use: devices['iPhone 12'],
// },
],
};
export default config;