-
Notifications
You must be signed in to change notification settings - Fork 1
/
playwright.config.ts
149 lines (123 loc) · 4.14 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
144
145
146
147
148
149
import type { PlaywrightTestConfig } from '@playwright/test';
import { devices } from '@playwright/test';
/**
* Read environment variables from file.
* https://github.com/motdotla/dotenv
*/
// require('dotenv').config();
/**
* See https://playwright.dev/docs/test-configuration.
*/
const config: PlaywrightTestConfig = {
// Path to the global setup file. This file will be required and run before all the tests. It must export a single function.
//globalSetup: './global/global-setup',
// Path to the global teardown file. This file will be required and run after all the tests. It must export a single function.
//globalTeardown: './global/global-teardown',
// Directory with the test files.
testDir: './regression-suite',
// Glob patterns or regular expressions that should be ignored when looking for the test files. For example, '**/test-assets'.
//testIgnore: '**/test-assets',
/* Maximum time one test can run for. */
timeout: 30 * 1000,
expect: {
/**
* Maximum time expect() should wait for the condition to be met.
* For example in `await expect(locator).toHaveText();`
*/
timeout: 5000
},
/* Whether to exit with an error if any tests are marked as test.only. Useful on CI.
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: [ ['line'], ['allure-playwright', { outputFolder: 'allure-results' }], ['html'] ],
/* Shared settings for all the projects below. See https://playwright.dev/docs/api/class-testoptions. */
use: {
/*Use - Configure projects for major browsers for paralle else mentioned
Name of the browser that will run the tests, one of chromium, firefox, or webkit */
// browserName: 'chromium',
//Whether to run the browser in headless mode.
// headless: false,
//Viewport used for all pages in the context.
// viewport: { width: 1280, height: 720 },
// ignoreHTTPSErrors: true,
/* Maximum time each action such as `click()` can take. Defaults to 0 (no limit). */
actionTimeout: 0,
/* Base URL to use in actions like `await page.goto('/')`. */
baseURL: 'http://shore-qa.otaliodev.com',
extraHTTPHeaders: {
// We set this header for REST API.
'Accept': 'application/json',
// Add authorization token to all requests.
// Assuming personal access token available in the environment.
'Authorization': `token ${process.env.API_TOKEN}`,
},
/* Collect trace when retrying the failed test. See https://playwright.dev/docs/trace-viewer */
trace: 'on',
screenshot: 'on',
video: 'on',
locale: 'en-EN',
geolocation: { longitude: 48.858455, latitude: 2.294474 },
permissions: ['geolocation'],
},
/* Configure projects for major browsers */
projects: [
{
name: 'Regression Test Suite',
testIgnore: /.*bla-bla.spec.ts/,
use: {
...devices['Desktop Chrome'],
},
},
// {
// name: 'firefox',
// use: {
// ...devices['Desktop Firefox'],
// },
// },
// {
// name: 'webkit',
// use: {
// ...devices['Desktop Safari'],
// },
// },
/* Test against mobile viewports. */
// {
// name: 'Mobile Chrome',
// use: {
// ...devices['Pixel 5'],
// },
// },
// {
// name: 'Mobile Safari',
// use: {
// ...devices['iPhone 12'],
// },
// },
/* Test against branded browsers. */
// {
// name: 'Microsoft Edge',
// use: {
// channel: 'msedge',
// },
// },
// {
// name: 'Google Chrome',
// use: {
// channel: 'chrome',
// },
// },
],
/* Folder for test artifacts such as screenshots, videos, traces, etc. */
outputDir: 'test-results/',
/* Run your local dev server before starting the tests */
// webServer: {
// command: 'npm run start',
// port: 3000,
// },
};
export default config;