forked from belgattitude/nextjs-monorepo-example
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathplaywright.config.ts
133 lines (121 loc) · 3.49 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
import path from 'path';
import { type Env, 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(): Env {
const { combinedEnv, loadedEnvFiles } = loadEnvConfig(__dirname);
loadedEnvFiles.forEach((file) => {
console.log(
`${pc.green('notice')}- Loaded nextjs environement file: './${file.path}'`
);
});
return combinedEnv;
}
// Reference: https://playwright.dev/docs/test-configuration
const config: PlaywrightTestConfig = {
testDir: path.join(__dirname, 'e2e'),
timeout: webServerConfig.timeout,
retries: webServerConfig.retries,
// Artifacts folder where screenshots, videos, and traces are stored.
outputDir: outputDir,
preserveOutput: 'always',
reporter: [
isCI ? ['github'] : ['list'],
['json', { outputFile: `${outputDir}/test-results.json` }],
[
'html',
{
outputFolder: `${outputDir}/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;