-
Notifications
You must be signed in to change notification settings - Fork 38
/
Copy pathwdio-shared.conf.js
106 lines (103 loc) · 4.54 KB
/
wdio-shared.conf.js
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
require('@babel/register');
global.baseDir = __dirname;
const percySnapshot = require('@percy/webdriverio');
const { getTestConfiguration, setTestReporters } = require('./test/configuration/configuration-helper');
const configuration = getTestConfiguration();
const { CI } = process.env;
exports.config = {
baseUrl: configuration.baseUrl,
// ==================
// Specify Test Files
// ==================
// Define which test specs should run. The pattern is relative to the directory
// from which `wdio` was called. Notice that, if you are calling `wdio` from an
// NPM script (see https://docs.npmjs.com/cli/run-script) then the current working
// directory is where your package.json resides, so `wdio` will be called from there.
//
// Specs are defined in test/configuration/chrome/chrome.settings.js
specs: configuration.testType.specs,
// Options to be passed to Mocha.
// See the full list at http://mochajs.org/
mochaOpts: {
// Babel setup
require: ['@babel/register'],
ui: 'bdd',
timeout: configuration.mochaOpts.timeout
},
// ===================
// Test Configurations
// ===================
// Define all options that are relevant for the WebdriverIO instance here
//
// Level of logging verbosity: trace | debug | info | warn | error | silent
logLevel: configuration.logLevel,
// Default timeout for all waitFor* commands.
waitforTimeout: configuration.mochaOpts.waitforTimeout,
// Default timeout in milliseconds for request
// if browser driver or grid doesn't send response
connectionRetryTimeout: configuration.connectionRetryTimeout,
//
// Default request retries count
connectionRetryCount: configuration.connectionRetryTimeout,
// Framework you want to run your specs with.
// The following are supported: Mocha, Jasmine, and Cucumber
// see also: https://webdriver.io/docs/frameworks.html
//
// Make sure you have the wdio adapter package for the specific framework installed
// before running any tests.
framework: 'mocha',
reporters: setTestReporters(configuration),
/**
* Gets executed before test execution begins. At this point you can access to all global
* variables like `browser`. It is the perfect place to define custom commands.
* @param {Array.<Object>} capabilities list of capabilities details
* @param {Array.<String>} specs List of spec file paths that are to be run
*/
before: async () => {
console.log('Using the following WDIO Config:', JSON.stringify(configuration));
if (configuration.testType.services.includes('percy')) {
await browser.addCommand('percyScreenshot', async (screenshotName, featureType) => {
const formattedFeatureType = featureType.toLowerCase();
if (formattedFeatureType !== 'mobile' && formattedFeatureType !== 'desktop') {
throw new Error(`Feature type ${formattedFeatureType} is not supported. Please use 'mobile' or 'desktop'`);
}
await percySnapshot(`${screenshotName} - ${featureType}`, {
widths: configuration.availableServices.percy.viewports[formattedFeatureType]
});
});
}
},
/**
* Function to be executed before a test (in Mocha/Jasmine)
*/
beforeTest: async (test) => {
if (test.file.includes('mobile')) {
await browser.setWindowSize(414, 731);
}
},
/**
* Function to be executed after a test (in Mocha/Jasmine)
*/
afterTest: async () => {
await browser.takeScreenshot();
await browser.deleteAllCookies();
},
/**
* Gets executed after all tests are done. You still have access to all global variables from
* the test.
* @param {Number} result 0 - test pass, 1 - test fail
* @param {Array.<Object>} capabilities list of capabilities details
* @param {Array.<String>} specs List of spec file paths that ran
*/
// eslint-disable-next-line consistent-return
after: () => {
if (!CI) {
console.log(
'-----------------------------------------------------', '\n',
'For more error logs, add "allure" to "testReporters" in "test/configuration/local.config.js".', '\n', '\n', 'To then see the ALLURE REPORT, please head to the route of the directory and run', '\n',
'yarn allure:open', '\n',
'-----------------------------------------------------'
);
}
}
};