-
Notifications
You must be signed in to change notification settings - Fork 0
/
playwright.config.ts
91 lines (90 loc) · 2.66 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
import { defineConfig, devices } from '@playwright/test'
import path from 'path'
export default defineConfig({
expect: {
toHaveScreenshot: { maxDiffPixels: 30 },
},
fullyParallel: true,
outputDir: 'integration-results',
preserveOutput: 'failures-only',
projects: [
...[
{
name: 'Desktop Chrome',
use: { ...devices['Desktop Chrome'], contextOptions: { reducedMotion: 'reduce' as const } },
},
{
name: 'Desktop Chrome (high contrast)',
use: {
...devices['Desktop Chrome'],
colorScheme: 'dark' as const,
contextOptions: { forcedColors: 'active' as const, reducedMotion: 'reduce' as const },
},
},
{
name: 'Mobile Chrome (high contrast)',
use: {
...devices['Pixel 5'],
colorScheme: 'dark' as const,
contextOptions: { forcedColors: 'active' as const, reducedMotion: 'reduce' as const },
},
},
{
name: 'Desktop Firefox',
use: { ...devices['Desktop Firefox'] },
},
{
name: 'iPhone 11',
use: { ...devices['iPhone 11'] },
},
].flatMap(env => [env, { name: `${env.name} (no JavaScript)`, use: { ...env.use, javaScriptEnabled: false } }]),
...[
{
name: 'Desktop Chrome',
use: { ...devices['Desktop Chrome'], contextOptions: { reducedMotion: 'reduce' as const } },
},
{
name: 'Desktop Chrome (high contrast)',
use: {
...devices['Desktop Chrome'],
colorScheme: 'dark' as const,
contextOptions: { forcedColors: 'active' as const, reducedMotion: 'reduce' as const },
},
},
{
name: 'Mobile Chrome (high contrast)',
use: {
...devices['Pixel 5'],
colorScheme: 'dark' as const,
contextOptions: { forcedColors: 'active' as const, reducedMotion: 'reduce' as const },
},
},
{
name: 'Desktop Firefox',
use: { ...devices['Desktop Firefox'] },
},
{
name: 'iPhone 11',
use: { ...devices['iPhone 11'] },
},
]
.map(env => ({
...env,
name: `${env.name} Visual Regression`,
testDir: 'visual-regression',
snapshotDir: path.resolve('visual-regression', 'snapshots'),
}))
.flatMap(env => [
env,
{ ...env, name: `${env.name} (no JavaScript)`, use: { ...env.use, javaScriptEnabled: false } },
]),
],
snapshotDir: path.resolve('integration', 'snapshots'),
testDir: 'integration',
use: {
javaScriptEnabled: true,
screenshot: 'only-on-failure',
trace: 'on-first-retry',
video: 'on-first-retry',
},
})