@wdio/config 5.9.5 → 5.12.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/build/constants.js +4 -22
- package/build/index.js +1 -4
- package/build/lib/ConfigParser.js +2 -93
- package/build/shim.js +1 -22
- package/build/utils.js +3 -51
- package/package.json +5 -4
package/build/constants.js
CHANGED
|
@@ -4,12 +4,7 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
6
|
exports.SUPPORTED_HOOKS = exports.DEFAULT_CONFIGS = void 0;
|
|
7
|
-
|
|
8
|
-
require("source-map-support/register");
|
|
9
|
-
|
|
10
7
|
const DEFAULT_TIMEOUT = 10000;
|
|
11
|
-
/* istanbul ignore next */
|
|
12
|
-
|
|
13
8
|
const DEFAULT_CONFIGS = {
|
|
14
9
|
sync: true,
|
|
15
10
|
specs: [],
|
|
@@ -34,10 +29,6 @@ const DEFAULT_CONFIGS = {
|
|
|
34
29
|
execArgv: [],
|
|
35
30
|
runnerEnv: {},
|
|
36
31
|
runner: 'local',
|
|
37
|
-
|
|
38
|
-
/**
|
|
39
|
-
* framework defaults
|
|
40
|
-
*/
|
|
41
32
|
mochaOpts: {
|
|
42
33
|
timeout: DEFAULT_TIMEOUT
|
|
43
34
|
},
|
|
@@ -47,10 +38,6 @@ const DEFAULT_CONFIGS = {
|
|
|
47
38
|
cucumberOpts: {
|
|
48
39
|
timeout: DEFAULT_TIMEOUT
|
|
49
40
|
},
|
|
50
|
-
|
|
51
|
-
/**
|
|
52
|
-
* hooks
|
|
53
|
-
*/
|
|
54
41
|
onPrepare: [],
|
|
55
42
|
before: [],
|
|
56
43
|
beforeSession: [],
|
|
@@ -66,18 +53,13 @@ const DEFAULT_CONFIGS = {
|
|
|
66
53
|
after: [],
|
|
67
54
|
onComplete: [],
|
|
68
55
|
onReload: [],
|
|
69
|
-
|
|
70
|
-
/**
|
|
71
|
-
* cucumber specific hooks
|
|
72
|
-
*/
|
|
73
56
|
beforeFeature: [],
|
|
74
57
|
beforeScenario: [],
|
|
75
58
|
beforeStep: [],
|
|
76
|
-
|
|
59
|
+
afterStep: [],
|
|
77
60
|
afterScenario: [],
|
|
78
|
-
|
|
61
|
+
afterFeature: []
|
|
79
62
|
};
|
|
80
63
|
exports.DEFAULT_CONFIGS = DEFAULT_CONFIGS;
|
|
81
|
-
const SUPPORTED_HOOKS = ['before', 'beforeSession', 'beforeSuite', 'beforeHook', 'beforeTest', 'beforeCommand', 'afterCommand', 'afterTest', 'afterHook', 'afterSuite', 'afterSession', 'after', 'beforeFeature', 'beforeScenario', 'beforeStep', '
|
|
82
|
-
exports.SUPPORTED_HOOKS = SUPPORTED_HOOKS;
|
|
83
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9jb25zdGFudHMuanMiXSwibmFtZXMiOlsiREVGQVVMVF9USU1FT1VUIiwiREVGQVVMVF9DT05GSUdTIiwic3luYyIsInNwZWNzIiwic3VpdGVzIiwiZXhjbHVkZSIsIm91dHB1dERpciIsInVuZGVmaW5lZCIsImxvZ0xldmVsIiwibG9nTGV2ZWxzIiwiZXhjbHVkZURyaXZlckxvZ3MiLCJiYXNlVXJsIiwiYmFpbCIsIndhaXRmb3JJbnRlcnZhbCIsIndhaXRmb3JUaW1lb3V0IiwiZnJhbWV3b3JrIiwicmVwb3J0ZXJzIiwibWF4SW5zdGFuY2VzIiwibWF4SW5zdGFuY2VzUGVyQ2FwYWJpbGl0eSIsImZpbGVzVG9XYXRjaCIsImNvbm5lY3Rpb25SZXRyeVRpbWVvdXQiLCJjb25uZWN0aW9uUmV0cnlDb3VudCIsImRlYnVnIiwiZXhlY0FyZ3YiLCJydW5uZXJFbnYiLCJydW5uZXIiLCJtb2NoYU9wdHMiLCJ0aW1lb3V0IiwiamFzbWluZU5vZGVPcHRzIiwiZGVmYXVsdFRpbWVvdXRJbnRlcnZhbCIsImN1Y3VtYmVyT3B0cyIsIm9uUHJlcGFyZSIsImJlZm9yZSIsImJlZm9yZVNlc3Npb24iLCJiZWZvcmVTdWl0ZSIsImJlZm9yZUhvb2siLCJiZWZvcmVUZXN0IiwiYmVmb3JlQ29tbWFuZCIsImFmdGVyQ29tbWFuZCIsImFmdGVyVGVzdCIsImFmdGVySG9vayIsImFmdGVyU3VpdGUiLCJhZnRlclNlc3Npb24iLCJhZnRlciIsIm9uQ29tcGxldGUiLCJvblJlbG9hZCIsImJlZm9yZUZlYXR1cmUiLCJiZWZvcmVTY2VuYXJpbyIsImJlZm9yZVN0ZXAiLCJhZnRlckZlYXR1cmUiLCJhZnRlclNjZW5hcmlvIiwiYWZ0ZXJTdGVwIiwiU1VQUE9SVEVEX0hPT0tTIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7QUFBQSxNQUFNQSxlQUFlLEdBQUcsS0FBeEI7QUFFQTs7QUFFTyxNQUFNQyxlQUFlLEdBQUc7QUFDM0JDLEVBQUFBLElBQUksRUFBRSxJQURxQjtB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X1RJTUVPVVQgPSAxMDAwMFxuXG4vKiBpc3RhbmJ1bCBpZ25vcmUgbmV4dCAqL1xuXG5leHBvcnQgY29uc3QgREVGQVVMVF9DT05GSUdTID0ge1xuICAgIHN5bmM6IHRydWUsXG4gICAgc3BlY3M6IFtdLFxuICAgIHN1aXRlczoge30sXG4gICAgZXhjbHVkZTogW10sXG4gICAgb3V0cHV0RGlyOiB1bmRlZmluZWQsXG4gICAgbG9nTGV2ZWw6ICdpbmZvJyxcbiAgICBsb2dMZXZlbHM6IHt9LFxuICAgIGV4Y2x1ZGVEcml2ZXJMb2dzOiBbXSxcbiAgICBiYXNlVXJsOiB1bmRlZmluZWQsXG4gICAgYmFpbDogMCxcbiAgICB3YWl0Zm9ySW50ZXJ2YWw6IDUwMCxcbiAgICB3YWl0Zm9yVGltZW91dDogNTAwMCxcbiAgICBmcmFtZXdvcms6ICdtb2NoYScsXG4gICAgcmVwb3J0ZXJzOiBbXSxcbiAgICBtYXhJbnN0YW5jZXM6IDEwMCxcbiAgICBtYXhJbnN0YW5jZXNQZXJDYXBhYmlsaXR5OiAxMDAsXG4gICAgZmlsZXNUb1dhdGNoOiBbXSxcbiAgICBjb25uZWN0aW9uUmV0cnlUaW1lb3V0OiA5MDAwMCxcbiAgICBjb25uZWN0aW9uUmV0cnlDb3VudDogMyxcbiAgICBkZWJ1ZzogZmFsc2UsXG4gICAgZXhlY0FyZ3Y6IFtdLFxuICAgIHJ1bm5lckVudjoge30sXG4gICAgcnVubmVyOiAnbG9jYWwnLFxuXG4gICAgLyoqXG4gICAgICogZnJhbWV3b3JrIGRlZmF1bHRzXG4gICAgICovXG4gICAgbW9jaGFPcHRzOiB7XG4gICAgICAgIHRpbWVvdXQ6IERFRkFVTFRfVElNRU9VVFxuICAgIH0sXG4gICAgamFzbWluZU5vZGVPcHRzOiB7XG4gICAgICAgIGRlZmF1bHRUaW1lb3V0SW50ZXJ2YWw6IERFRkFVTFRfVElNRU9VVFxuICAgIH0sXG4gICAgY3VjdW1iZXJPcHRzOiB7XG4gICAgICAgIHRpbWVvdXQ6IERFRkFVTFRfVElNRU9VVFxuICAgIH0sXG5cbiAgICAvKipcbiAgICAgKiBob29rc1xuICAgICAqL1xuICAgIG9uUHJlcGFyZTogW10sXG4gICAgYmVmb3JlOiBbXSxcbiAgICBiZWZvcmVTZXNzaW9uOiBbXSxcbiAgICBiZWZvcmVTdWl0ZTogW10sXG4gICAgYmVmb3JlSG9vazogW10sXG4gICAgYmVmb3JlVGVzdDogW10sXG4gICAgYmVmb3JlQ29tbWFuZDogW10sXG4gICAgYWZ0ZXJDb21tYW5kOiBbXSxcbiAgICBhZnRlclRlc3Q6IFtdLFxuICAgIGFmdGVySG9vazogW10sXG4gICAgYWZ0ZXJTdWl0ZTogW10sXG4gICAgYWZ0ZXJTZXNzaW9uOiBbXSxcbiAgICBhZnRlcjogW10sXG4gICAgb25Db21wbGV0ZTogW10sXG4gICAgb25SZWxvYWQ6IFtdLFxuXG4gICAgLyoqXG4gICAgICogY3VjdW1iZXIgc3BlY2lmaWMgaG9va3NcbiAgICAgKi9cbiAgICBiZWZvcmVGZWF0dXJlOiBbXSxcbiAgICBiZWZvcmVTY2VuYXJpbzogW10sXG4gICAgYmVmb3JlU3RlcDogW10sXG4gICAgYWZ0ZXJGZWF0dXJlOiBbXSxcbiAgICBhZnRlclNjZW5hcmlvOiBbXSxcbiAgICBhZnRlclN0ZXA6IFtdXG59XG5cbmV4cG9ydCBjb25zdCBTVVBQT1JURURfSE9PS1MgPSBbXG4gICAgJ2JlZm9yZScsICdiZWZvcmVTZXNzaW9uJywgJ2JlZm9yZVN1aXRlJywgJ2JlZm9yZUhvb2snLCAnYmVmb3JlVGVzdCcsICdiZWZvcmVDb21tYW5kJyxcbiAgICAnYWZ0ZXJDb21tYW5kJywgJ2FmdGVyVGVzdCcsICdhZnRlckhvb2snLCAnYWZ0ZXJTdWl0ZScsICdhZnRlclNlc3Npb24nLCAnYWZ0ZXInLFxuICAgICdiZWZvcmVGZWF0dXJlJywgJ2JlZm9yZVNjZW5hcmlvJywgJ2JlZm9yZVN0ZXAnLCAnYWZ0ZXJGZWF0dXJlJyxcbiAgICAnYWZ0ZXJTY2VuYXJpbycsICdhZnRlclN0ZXAnLCAnb25SZWxvYWQnLCAnb25QcmVwYXJlJywgJ29uQ29tcGxldGUnXG5dXG4iXX0=
|
|
64
|
+
const SUPPORTED_HOOKS = ['before', 'beforeSession', 'beforeSuite', 'beforeHook', 'beforeTest', 'beforeCommand', 'afterCommand', 'afterTest', 'afterHook', 'afterSuite', 'afterSession', 'after', 'beforeFeature', 'beforeScenario', 'beforeStep', 'afterStep', 'afterScenario', 'afterFeature', 'onReload', 'onPrepare', 'onComplete'];
|
|
65
|
+
exports.SUPPORTED_HOOKS = SUPPORTED_HOOKS;
|
package/build/index.js
CHANGED
|
@@ -76,8 +76,6 @@ Object.defineProperty(exports, "DEFAULT_CONFIGS", {
|
|
|
76
76
|
}
|
|
77
77
|
});
|
|
78
78
|
|
|
79
|
-
require("source-map-support/register");
|
|
80
|
-
|
|
81
79
|
var _ConfigParser = _interopRequireDefault(require("./lib/ConfigParser"));
|
|
82
80
|
|
|
83
81
|
var _utils = require("./utils");
|
|
@@ -86,5 +84,4 @@ var _shim = require("./shim");
|
|
|
86
84
|
|
|
87
85
|
var _constants = require("./constants");
|
|
88
86
|
|
|
89
|
-
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
90
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBOztBQUNBOztBQUNBOztBQUlBIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IENvbmZpZ1BhcnNlciBmcm9tICcuL2xpYi9Db25maWdQYXJzZXInXG5pbXBvcnQgeyB2YWxpZGF0ZUNvbmZpZywgZ2V0U2F1Y2VFbmRwb2ludCwgZGV0ZWN0QmFja2VuZCB9IGZyb20gJy4vdXRpbHMnXG5pbXBvcnQge1xuICAgIHdyYXBDb21tYW5kLCBydW5GbkluRmliZXJDb250ZXh0LCBydW5UZXN0SW5GaWJlckNvbnRleHQsIGV4ZWN1dGVIb29rc1dpdGhBcmdzLFxuICAgIGhhc1dkaW9TeW5jU3VwcG9ydCwgZXhlY3V0ZVN5bmMsIGV4ZWN1dGVBc3luY1xufSBmcm9tICcuL3NoaW0nXG5pbXBvcnQgeyBERUZBVUxUX0NPTkZJR1MgfSBmcm9tICcuL2NvbnN0YW50cydcblxuZXhwb3J0IHtcbiAgICB2YWxpZGF0ZUNvbmZpZyxcbiAgICBnZXRTYXVjZUVuZHBvaW50LFxuICAgIGRldGVjdEJhY2tlbmQsXG4gICAgQ29uZmlnUGFyc2VyLFxuXG4gICAgLyoqXG4gICAgICogd2Rpby1zeW5jIHNoaW1cbiAgICAgKi9cbiAgICB3cmFwQ29tbWFuZCxcbiAgICBleGVjdXRlU3luYyxcbiAgICBleGVjdXRlQXN5bmMsXG4gICAgcnVuRm5JbkZpYmVyQ29udGV4dCxcbiAgICBydW5UZXN0SW5GaWJlckNvbnRleHQsXG4gICAgZXhlY3V0ZUhvb2tzV2l0aEFyZ3MsXG4gICAgaGFzV2Rpb1N5bmNTdXBwb3J0LFxuXG4gICAgLyoqXG4gICAgICogY29uc3RhbnRzXG4gICAgICovXG4gICAgREVGQVVMVF9DT05GSUdTXG59XG4iXX0=
|
|
87
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
@@ -5,8 +5,6 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
5
5
|
});
|
|
6
6
|
exports.default = void 0;
|
|
7
7
|
|
|
8
|
-
require("source-map-support/register");
|
|
9
|
-
|
|
10
8
|
var _fs = _interopRequireDefault(require("fs"));
|
|
11
9
|
|
|
12
10
|
var _path = _interopRequireDefault(require("path"));
|
|
@@ -33,11 +31,6 @@ class ConfigParser {
|
|
|
33
31
|
this._config = _constants.DEFAULT_CONFIGS;
|
|
34
32
|
this._capabilities = [];
|
|
35
33
|
}
|
|
36
|
-
/**
|
|
37
|
-
* merges config file with default values
|
|
38
|
-
* @param {String} filename path of file relative to current directory
|
|
39
|
-
*/
|
|
40
|
-
|
|
41
34
|
|
|
42
35
|
addConfigFile(filename) {
|
|
43
36
|
if (typeof filename !== 'string') {
|
|
@@ -47,22 +40,10 @@ class ConfigParser {
|
|
|
47
40
|
var filePath = _path.default.resolve(process.cwd(), filename);
|
|
48
41
|
|
|
49
42
|
try {
|
|
50
|
-
/**
|
|
51
|
-
* clone the original config
|
|
52
|
-
*/
|
|
53
43
|
var fileConfig = (0, _deepmerge.default)(require(filePath).config, {}, MERGE_OPTIONS);
|
|
54
|
-
/**
|
|
55
|
-
* merge capabilities
|
|
56
|
-
*/
|
|
57
|
-
|
|
58
44
|
const defaultTo = Array.isArray(this._capabilities) ? [] : {};
|
|
59
45
|
this._capabilities = (0, _deepmerge.default)(this._capabilities, fileConfig.capabilities || defaultTo, MERGE_OPTIONS);
|
|
60
46
|
delete fileConfig.capabilities;
|
|
61
|
-
/**
|
|
62
|
-
* Add hooks from the file config and remove them from file config object to avoid
|
|
63
|
-
* complications when using merge function
|
|
64
|
-
*/
|
|
65
|
-
|
|
66
47
|
this.addService(fileConfig);
|
|
67
48
|
|
|
68
49
|
for (let hookName of _constants.SUPPORTED_HOOKS) {
|
|
@@ -70,18 +51,8 @@ class ConfigParser {
|
|
|
70
51
|
}
|
|
71
52
|
|
|
72
53
|
this._config = (0, _deepmerge.default)(this._config, fileConfig, MERGE_OPTIONS);
|
|
73
|
-
/**
|
|
74
|
-
* For Sauce Labs RDC we need to determine if the config file has a `testobject_api_key`
|
|
75
|
-
* If so, we need to provide a boolean to the `detectBackend` to set the correct hostname
|
|
76
|
-
*
|
|
77
|
-
* NOTE: This will not work for multi remote
|
|
78
|
-
*/
|
|
79
54
|
|
|
80
55
|
const isRDC = Array.isArray(this._capabilities) && this._capabilities.some(capability => 'testobject_api_key' in capability);
|
|
81
|
-
/**
|
|
82
|
-
* detect Selenium backend
|
|
83
|
-
*/
|
|
84
|
-
|
|
85
56
|
|
|
86
57
|
this._config = (0, _deepmerge.default)((0, _utils.detectBackend)(this._config, isRDC), this._config, MERGE_OPTIONS);
|
|
87
58
|
} catch (e) {
|
|
@@ -89,35 +60,20 @@ class ConfigParser {
|
|
|
89
60
|
throw e;
|
|
90
61
|
}
|
|
91
62
|
}
|
|
92
|
-
/**
|
|
93
|
-
* merge external object with config object
|
|
94
|
-
* @param {Object} object desired object to merge into the config object
|
|
95
|
-
*/
|
|
96
|
-
|
|
97
63
|
|
|
98
64
|
merge(object = {}) {
|
|
99
65
|
this._config = (0, _deepmerge.default)(this._config, object, MERGE_OPTIONS);
|
|
100
66
|
let spec = Array.isArray(object.spec) ? object.spec : [];
|
|
101
67
|
let exclude = Array.isArray(object.exclude) ? object.exclude : [];
|
|
102
|
-
/**
|
|
103
|
-
* overwrite config specs that got piped into the wdio command
|
|
104
|
-
*/
|
|
105
68
|
|
|
106
69
|
if (object.specs && object.specs.length > 0) {
|
|
107
70
|
this._config.specs = object.specs;
|
|
108
71
|
} else if (object.exclude && object.exclude.length > 0) {
|
|
109
72
|
this._config.exclude = object.exclude;
|
|
110
73
|
}
|
|
111
|
-
/**
|
|
112
|
-
* merge capabilities
|
|
113
|
-
*/
|
|
114
|
-
|
|
115
74
|
|
|
116
75
|
const defaultTo = Array.isArray(this._capabilities) ? [] : {};
|
|
117
76
|
this._capabilities = (0, _deepmerge.default)(this._capabilities, this._config.capabilities || defaultTo, MERGE_OPTIONS);
|
|
118
|
-
/**
|
|
119
|
-
* run single spec file only, regardless of multiple-spec specification
|
|
120
|
-
*/
|
|
121
77
|
|
|
122
78
|
if (spec.length > 0) {
|
|
123
79
|
this._config.specs = [...this.setFilePathToFilterOptions(spec, this._config.specs)];
|
|
@@ -126,12 +82,6 @@ class ConfigParser {
|
|
|
126
82
|
if (exclude.length > 0) {
|
|
127
83
|
this._config.exclude = [...this.setFilePathToFilterOptions(exclude, this._config.exclude)];
|
|
128
84
|
}
|
|
129
|
-
/**
|
|
130
|
-
* user and key could get added via cli arguments so we need to detect again
|
|
131
|
-
* Note: cli arguments are on the right and overwrite config
|
|
132
|
-
* if host and port are default, remove them to get new values
|
|
133
|
-
*/
|
|
134
|
-
|
|
135
85
|
|
|
136
86
|
let defaultBackend = (0, _utils.detectBackend)({});
|
|
137
87
|
|
|
@@ -143,11 +93,6 @@ class ConfigParser {
|
|
|
143
93
|
|
|
144
94
|
this._config = (0, _deepmerge.default)((0, _utils.detectBackend)(this._config), this._config, MERGE_OPTIONS);
|
|
145
95
|
}
|
|
146
|
-
/**
|
|
147
|
-
* Add hooks from an existing service to the runner config.
|
|
148
|
-
* @param {Object} service - an object that contains hook methods.
|
|
149
|
-
*/
|
|
150
|
-
|
|
151
96
|
|
|
152
97
|
addService(service) {
|
|
153
98
|
for (let hookName of _constants.SUPPORTED_HOOKS) {
|
|
@@ -166,25 +111,17 @@ class ConfigParser {
|
|
|
166
111
|
}
|
|
167
112
|
}
|
|
168
113
|
}
|
|
169
|
-
/**
|
|
170
|
-
* get excluded files from config pattern
|
|
171
|
-
*/
|
|
172
|
-
|
|
173
114
|
|
|
174
115
|
getSpecs(capSpecs, capExclude) {
|
|
175
116
|
let specs = ConfigParser.getFilePaths(this._config.specs);
|
|
176
117
|
let spec = Array.isArray(this._config.spec) ? this._config.spec : [];
|
|
177
118
|
let exclude = ConfigParser.getFilePaths(this._config.exclude);
|
|
178
119
|
let suites = Array.isArray(this._config.suite) ? this._config.suite : [];
|
|
179
|
-
/**
|
|
180
|
-
* check if user has specified a specific suites to run
|
|
181
|
-
*/
|
|
182
120
|
|
|
183
121
|
if (suites.length > 0) {
|
|
184
122
|
let suiteSpecs = [];
|
|
185
123
|
|
|
186
124
|
for (let suiteName of suites) {
|
|
187
|
-
// ToDo: log warning if suite was not found
|
|
188
125
|
let suite = this._config.suites[suiteName];
|
|
189
126
|
|
|
190
127
|
if (suite && Array.isArray(suite)) {
|
|
@@ -194,9 +131,7 @@ class ConfigParser {
|
|
|
194
131
|
|
|
195
132
|
if (suiteSpecs.length === 0) {
|
|
196
133
|
throw new Error(`The suite(s) "${suites.join('", "')}" you specified don't exist ` + 'in your config file or doesn\'t contain any files!');
|
|
197
|
-
}
|
|
198
|
-
// Removing any duplicate tests that could be included
|
|
199
|
-
|
|
134
|
+
}
|
|
200
135
|
|
|
201
136
|
let tmpSpecs = spec.length > 0 ? [...specs, ...suiteSpecs] : suiteSpecs;
|
|
202
137
|
|
|
@@ -222,16 +157,6 @@ class ConfigParser {
|
|
|
222
157
|
|
|
223
158
|
return specs.filter(spec => !exclude.includes(spec));
|
|
224
159
|
}
|
|
225
|
-
/**
|
|
226
|
-
* sets config attribute with file paths from filtering
|
|
227
|
-
* options from cli argument
|
|
228
|
-
*
|
|
229
|
-
* @param {String} cliArgFileList list of files in a string from
|
|
230
|
-
* @param {Object} config config object that stores the spec and exlcude attributes
|
|
231
|
-
* cli argument
|
|
232
|
-
* @return {String[]} List of files that should be included or excluded
|
|
233
|
-
*/
|
|
234
|
-
|
|
235
160
|
|
|
236
161
|
setFilePathToFilterOptions(cliArgFileList, config) {
|
|
237
162
|
const filesToFilter = new Set();
|
|
@@ -254,18 +179,10 @@ class ConfigParser {
|
|
|
254
179
|
|
|
255
180
|
return filesToFilter;
|
|
256
181
|
}
|
|
257
|
-
/**
|
|
258
|
-
* return configs
|
|
259
|
-
*/
|
|
260
|
-
|
|
261
182
|
|
|
262
183
|
getConfig() {
|
|
263
184
|
return this._config;
|
|
264
185
|
}
|
|
265
|
-
/**
|
|
266
|
-
* return capabilities
|
|
267
|
-
*/
|
|
268
|
-
|
|
269
186
|
|
|
270
187
|
getCapabilities(i) {
|
|
271
188
|
if (typeof i === 'number' && this._capabilities[i]) {
|
|
@@ -274,13 +191,6 @@ class ConfigParser {
|
|
|
274
191
|
|
|
275
192
|
return this._capabilities;
|
|
276
193
|
}
|
|
277
|
-
/**
|
|
278
|
-
* returns a flatten list of globed files
|
|
279
|
-
*
|
|
280
|
-
* @param {String[]} filenames list of files to glob
|
|
281
|
-
* @return {String[]} list of files
|
|
282
|
-
*/
|
|
283
|
-
|
|
284
194
|
|
|
285
195
|
static getFilePaths(patterns, omitWarnings) {
|
|
286
196
|
let files = [];
|
|
@@ -311,5 +221,4 @@ class ConfigParser {
|
|
|
311
221
|
|
|
312
222
|
}
|
|
313
223
|
|
|
314
|
-
exports.default = ConfigParser;
|
|
315
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/lib/ConfigParser.js"],"names":["log","MERGE_OPTIONS","clone","ConfigParser","constructor","_config","DEFAULT_CONFIGS","_capabilities","addConfigFile","filename","Error","filePath","path","resolve","process","cwd","fileConfig","require","config","defaultTo","Array","isArray","capabilities","addService","hookName","SUPPORTED_HOOKS","isRDC","some","capability","e","error","message","merge","object","spec","exclude","specs","length","setFilePathToFilterOptions","defaultBackend","hostname","port","protocol","service","push","bind","hook","getSpecs","capSpecs","capExclude","getFilePaths","suites","suite","suiteSpecs","suiteName","concat","join","tmpSpecs","Set","filter","includes","cliArgFileList","filesToFilter","fileList","forEach","filteredFile","fs","existsSync","lstatSync","isFile","add","file","match","size","getConfig","getCapabilities","i","patterns","omitWarnings","files","pattern","filenames","glob","sync","slice","map","isAbsolute","normalize","warn"],"mappings":"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","sourcesContent":["import fs from 'fs'\nimport path from 'path'\nimport glob from 'glob'\nimport merge from 'deepmerge'\n\nimport logger from '@wdio/logger'\n\nimport { detectBackend } from '../utils'\n\nimport { DEFAULT_CONFIGS, SUPPORTED_HOOKS } from '../constants'\n\nconst log = logger('@wdio/config:ConfigParser')\nconst MERGE_OPTIONS = { clone: false }\n\nexport default class ConfigParser {\n    constructor () {\n        this._config = DEFAULT_CONFIGS\n        this._capabilities = []\n    }\n\n    /**\n     * merges config file with default values\n     * @param {String} filename path of file relative to current directory\n     */\n    addConfigFile (filename) {\n        if (typeof filename !== 'string') {\n            throw new Error('addConfigFile requires filepath')\n        }\n\n        var filePath = path.resolve(process.cwd(), filename)\n\n        try {\n            /**\n             * clone the original config\n             */\n            var fileConfig = merge(require(filePath).config, {}, MERGE_OPTIONS)\n\n            /**\n             * merge capabilities\n             */\n            const defaultTo = Array.isArray(this._capabilities) ? [] : {}\n            this._capabilities = merge(this._capabilities, fileConfig.capabilities || defaultTo, MERGE_OPTIONS)\n            delete fileConfig.capabilities\n\n            /**\n             * Add hooks from the file config and remove them from file config object to avoid\n             * complications when using merge function\n             */\n            this.addService(fileConfig)\n            for (let hookName of SUPPORTED_HOOKS) {\n                delete fileConfig[hookName]\n            }\n\n            this._config = merge(this._config, fileConfig, MERGE_OPTIONS)\n\n            /**\n             * For Sauce Labs RDC we need to determine if the config file has a `testobject_api_key`\n             * If so, we need to provide a boolean to the `detectBackend` to set the correct hostname\n             *\n             * NOTE: This will not work for multi remote\n             */\n            const isRDC = Array.isArray(this._capabilities) && this._capabilities.some(capability => 'testobject_api_key' in capability)\n\n            /**\n             * detect Selenium backend\n             */\n            this._config = merge(detectBackend(this._config, isRDC), this._config, MERGE_OPTIONS)\n        } catch (e) {\n            log.error(`Failed loading configuration file: ${filePath}:`, e.message)\n            throw e\n        }\n    }\n\n    /**\n     * merge external object with config object\n     * @param  {Object} object  desired object to merge into the config object\n     */\n    merge (object = {}) {\n        this._config = merge(this._config, object, MERGE_OPTIONS)\n        let spec = Array.isArray(object.spec) ? object.spec : []\n        let exclude = Array.isArray(object.exclude) ? object.exclude : []\n\n        /**\n         * overwrite config specs that got piped into the wdio command\n         */\n        if (object.specs && object.specs.length > 0) {\n            this._config.specs = object.specs\n        } else if (object.exclude && object.exclude.length > 0) {\n            this._config.exclude = object.exclude\n        }\n\n        /**\n         * merge capabilities\n         */\n        const defaultTo = Array.isArray(this._capabilities) ? [] : {}\n        this._capabilities = merge(this._capabilities, this._config.capabilities || defaultTo, MERGE_OPTIONS)\n\n        /**\n         * run single spec file only, regardless of multiple-spec specification\n         */\n        if (spec.length > 0) {\n            this._config.specs = [...this.setFilePathToFilterOptions(spec, this._config.specs)]\n        }\n        if (exclude.length > 0) {\n            this._config.exclude = [...this.setFilePathToFilterOptions(exclude, this._config.exclude)]\n        }\n\n        /**\n         * user and key could get added via cli arguments so we need to detect again\n         * Note: cli arguments are on the right and overwrite config\n         * if host and port are default, remove them to get new values\n         */\n        let defaultBackend = detectBackend({})\n        if (\n            (this._config.hostname === defaultBackend.hostname) &&\n            (this._config.port === defaultBackend.port) &&\n            (this._config.protocol === defaultBackend.protocol)\n        ) {\n            delete this._config.hostname\n            delete this._config.port\n            delete this._config.protocol\n        }\n\n        this._config = merge(detectBackend(this._config), this._config, MERGE_OPTIONS)\n    }\n\n    /**\n     * Add hooks from an existing service to the runner config.\n     * @param {Object} service - an object that contains hook methods.\n     */\n    addService (service) {\n        for (let hookName of SUPPORTED_HOOKS) {\n            if (!service[hookName]) {\n                continue\n            }\n\n            if (typeof service[hookName] === 'function') {\n                this._config[hookName].push(service[hookName].bind(service))\n            } else if (Array.isArray(service[hookName])) {\n                for (let hook of service[hookName]) {\n                    if (typeof hook === 'function') {\n                        this._config[hookName].push(hook.bind(service))\n                    }\n                }\n            }\n        }\n    }\n\n    /**\n     * get excluded files from config pattern\n     */\n    getSpecs (capSpecs, capExclude) {\n        let specs = ConfigParser.getFilePaths(this._config.specs)\n        let spec  = Array.isArray(this._config.spec) ? this._config.spec : []\n        let exclude = ConfigParser.getFilePaths(this._config.exclude)\n        let suites = Array.isArray(this._config.suite) ? this._config.suite : []\n\n        /**\n         * check if user has specified a specific suites to run\n         */\n        if (suites.length > 0) {\n            let suiteSpecs = []\n            for (let suiteName of suites) {\n                // ToDo: log warning if suite was not found\n                let suite = this._config.suites[suiteName]\n\n                if (suite && Array.isArray(suite)) {\n                    suiteSpecs = suiteSpecs.concat(ConfigParser.getFilePaths(suite))\n                }\n            }\n\n            if (suiteSpecs.length === 0) {\n                throw new Error(`The suite(s) \"${suites.join('\", \"')}\" you specified don't exist ` +\n                                'in your config file or doesn\\'t contain any files!')\n            }\n\n            // Allow --suite and --spec to both be defined on the command line\n            // Removing any duplicate tests that could be included\n            let tmpSpecs = spec.length > 0 ? [...specs, ...suiteSpecs] : suiteSpecs\n\n            if (Array.isArray(capSpecs)) {\n                tmpSpecs = tmpSpecs.concat(ConfigParser.getFilePaths(capSpecs))\n            }\n\n            if (Array.isArray(capExclude)) {\n                exclude = exclude.concat(ConfigParser.getFilePaths(capExclude))\n            }\n\n            specs = [...new Set(tmpSpecs)]\n            return specs.filter(spec => !exclude.includes(spec))\n        }\n\n        if (Array.isArray(capSpecs)) {\n            specs = specs.concat(ConfigParser.getFilePaths(capSpecs))\n        }\n\n        if (Array.isArray(capExclude)) {\n            exclude = exclude.concat(ConfigParser.getFilePaths(capExclude))\n        }\n\n        return specs.filter(spec => !exclude.includes(spec))\n    }\n\n    /**\n     * sets config attribute with file paths from filtering\n     * options from cli argument\n     *\n     * @param  {String} cliArgFileList  list of files in a string from\n     * @param  {Object} config  config object that stores the spec and exlcude attributes\n     * cli argument\n     * @return {String[]} List of files that should be included or excluded\n     */\n    setFilePathToFilterOptions (cliArgFileList, config) {\n        const filesToFilter = new Set()\n        const fileList = ConfigParser.getFilePaths(config)\n        cliArgFileList.forEach(filteredFile => {\n            if (fs.existsSync(filteredFile) && fs.lstatSync(filteredFile).isFile()) {\n                filesToFilter.add(path.resolve(process.cwd(), filteredFile))\n            } else {\n                fileList.forEach(file => {\n                    if (file.match(filteredFile)) {\n                        filesToFilter.add(file)\n                    }\n                })\n            }\n        })\n        if (filesToFilter.size === 0) {\n            throw new Error(`spec file(s) ${cliArgFileList.join(', ')} not found`)\n        }\n        return filesToFilter\n    }\n\n    /**\n     * return configs\n     */\n    getConfig () {\n        return this._config\n    }\n\n    /**\n     * return capabilities\n     */\n    getCapabilities (i) {\n        if (typeof i === 'number' && this._capabilities[i]) {\n            return this._capabilities[i]\n        }\n\n        return this._capabilities\n    }\n\n    /**\n     * returns a flatten list of globed files\n     *\n     * @param  {String[]} filenames  list of files to glob\n     * @return {String[]} list of files\n     */\n    static getFilePaths (patterns, omitWarnings) {\n        let files = []\n\n        if (typeof patterns === 'string') {\n            patterns = [patterns]\n        }\n\n        if (!Array.isArray(patterns)) {\n            throw new Error('specs or exclude property should be an array of strings')\n        }\n\n        for (let pattern of patterns) {\n            let filenames = glob.sync(pattern)\n\n            filenames = filenames.filter(filename =>\n                filename.slice(-3) === '.js' ||\n                filename.slice(-4) === '.es6' ||\n                filename.slice(-3) === '.ts' ||\n                filename.slice(-8) === '.feature' ||\n                filename.slice(-7) === '.coffee')\n\n            filenames = filenames.map(filename =>\n                path.isAbsolute(filename) ? path.normalize(filename) : path.resolve(process.cwd(), filename))\n\n            if (filenames.length === 0 && !omitWarnings) {\n                log.warn('pattern', pattern, 'did not match any file')\n            }\n\n            files = merge(files, filenames, MERGE_OPTIONS)\n        }\n\n        return files\n    }\n}\n"]}
|
|
224
|
+
exports.default = ConfigParser;
|
package/build/shim.js
CHANGED
|
@@ -5,8 +5,6 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
5
5
|
});
|
|
6
6
|
exports.executeAsync = exports.executeSync = exports.hasWdioSyncSupport = exports.wrapCommand = exports.runFnInFiberContext = exports.runTestInFiberContext = exports.executeHooksWithArgs = void 0;
|
|
7
7
|
|
|
8
|
-
require("source-map-support/register");
|
|
9
|
-
|
|
10
8
|
var _logger = _interopRequireDefault(require("@wdio/logger"));
|
|
11
9
|
|
|
12
10
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
@@ -16,16 +14,9 @@ const log = (0, _logger.default)('@wdio/config');
|
|
|
16
14
|
const NOOP = () => {};
|
|
17
15
|
|
|
18
16
|
let executeHooksWithArgs = async function executeHooksWithArgsShim(hooks, args) {
|
|
19
|
-
/**
|
|
20
|
-
* make sure hooks are an array of functions
|
|
21
|
-
*/
|
|
22
17
|
if (!Array.isArray(hooks)) {
|
|
23
18
|
hooks = [hooks];
|
|
24
19
|
}
|
|
25
|
-
/**
|
|
26
|
-
* make sure args is an array since we are calling apply
|
|
27
|
-
*/
|
|
28
|
-
|
|
29
20
|
|
|
30
21
|
if (!Array.isArray(args)) {
|
|
31
22
|
args = [args];
|
|
@@ -40,11 +31,6 @@ let executeHooksWithArgs = async function executeHooksWithArgsShim(hooks, args)
|
|
|
40
31
|
log.error(e.stack);
|
|
41
32
|
return resolve();
|
|
42
33
|
}
|
|
43
|
-
/**
|
|
44
|
-
* if a promise is returned make sure we don't have a catch handler
|
|
45
|
-
* so in case of a rejection it won't cause the hook to fail
|
|
46
|
-
*/
|
|
47
|
-
|
|
48
34
|
|
|
49
35
|
if (result && typeof result.then === 'function') {
|
|
50
36
|
return result.then(resolve, e => {
|
|
@@ -81,15 +67,10 @@ let executeSync = (fn, _, args = []) => fn.apply(void 0, args);
|
|
|
81
67
|
exports.executeSync = executeSync;
|
|
82
68
|
|
|
83
69
|
let executeAsync = (fn, _, args = []) => fn.apply(void 0, args);
|
|
84
|
-
/**
|
|
85
|
-
* shim to make sure that we only wrap commands if wdio-sync is installed as dependency
|
|
86
|
-
*/
|
|
87
|
-
|
|
88
70
|
|
|
89
71
|
exports.executeAsync = executeAsync;
|
|
90
72
|
|
|
91
73
|
try {
|
|
92
|
-
// eslint-disable-next-line import/no-unresolved
|
|
93
74
|
const wdioSync = require('@wdio/sync');
|
|
94
75
|
|
|
95
76
|
exports.hasWdioSyncSupport = hasWdioSyncSupport = true;
|
|
@@ -99,6 +80,4 @@ try {
|
|
|
99
80
|
exports.executeHooksWithArgs = executeHooksWithArgs = wdioSync.executeHooksWithArgs;
|
|
100
81
|
exports.executeSync = executeSync = wdioSync.executeSync;
|
|
101
82
|
exports.executeAsync = executeAsync = wdioSync.executeAsync;
|
|
102
|
-
} catch (_unused) {
|
|
103
|
-
}
|
|
104
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9zaGltLmpzIl0sIm5hbWVzIjpbImxvZyIsIk5PT1AiLCJleGVjdXRlSG9va3NXaXRoQXJncyIsImV4ZWN1dGVIb29rc1dpdGhBcmdzU2hpbSIsImhvb2tzIiwiYXJncyIsIkFycmF5IiwiaXNBcnJheSIsIm1hcCIsImhvb2siLCJQcm9taXNlIiwicmVzb2x2ZSIsInJlc3VsdCIsImFwcGx5IiwiZSIsImVycm9yIiwic3RhY2siLCJ0aGVuIiwiYWxsIiwicnVuVGVzdEluRmliZXJDb250ZXh0IiwicnVuRm5JbkZpYmVyQ29udGV4dCIsImZuIiwid3JhcENvbW1hbmQiLCJfIiwib3JpZ0ZuIiwiaGFzV2Rpb1N5bmNTdXBwb3J0IiwiZXhlY3V0ZVN5bmMiLCJleGVjdXRlQXN5bmMiLCJ3ZGlvU3luYyIsInJlcXVpcmUiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7OztBQUFBOzs7O0FBRUEsTUFBTUEsR0FBRyxHQUFHLHFCQUFPLGNBQVAsQ0FBWjs7QUFDQSxNQUFNQyxJQUFJLEdBQUcsTUFBTSxDQUFFLENBQXJCOztBQUVPLElBQUlDLG9CQUFvQixHQUFHLGVBQWVDLHdCQUFmLENBQXlDQyxLQUF6QyxFQUFnREMsSUFBaEQsRUFBc0Q7QUFDcEY7OztBQUdBLE1BQUksQ0FBQ0MsS0FBSyxDQUFDQyxPQUFOLENBQWNILEtBQWQsQ0FBTCxFQUEyQjtBQUN2QkEsSUFBQUEsS0FBSyxHQUFHLENBQUNBLEtBQUQsQ0FBUjtBQUNIO0FBRUQ7Ozs7O0FBR0EsTUFBSSxDQUFDRSxLQUFLLENBQUNDLE9BQU4sQ0FBY0YsSUFBZCxDQUFMLEVBQTBCO0FBQ3RCQSxJQUFBQSxJQUFJLEdBQUcsQ0FBQ0EsSUFBRCxDQUFQO0FBQ0g7O0FBRURELEVBQUFBLEtBQUssR0FBR0EsS0FBSyxDQUFDSSxHQUFOLENBQVdDLElBQUQsSUFBVSxJQUFJQyxPQUFKLENBQWFDLE9BQUQsSUFBYTtBQUNqRCxRQUFJQyxNQUFKOztBQUVBLFFBQUk7QUFDQUEsTUFBQUEsTUFBTSxHQUFHSCxJQUFJLENBQUNJLEtBQUwsQ0FBVyxJQUFYLEVBQWlCUixJQUFqQixDQUFUO0FBQ0gsS0FGRCxDQUVFLE9BQU9TLENBQVAsRUFBVTtBQUNSZCxNQUFBQSxHQUFHLENBQUNlLEtBQUosQ0FBVUQsQ0FBQyxDQUFDRSxLQUFaO0FBQ0EsYUFBT0wsT0FBTyxFQUFkO0FBQ0g7QUFFRDs7Ozs7O0FBSUEsUUFBSUMsTUFBTSxJQUFJLE9BQU9BLE1BQU0sQ0FBQ0ssSUFBZCxLQUF1QixVQUFyQyxFQUFpRDtBQUM3QyxhQUFPTCxNQUFNLENBQUNLLElBQVAsQ0FBWU4sT0FBWixFQUFzQkcsQ0FBRCxJQUFPO0FBQy9CZCxRQUFBQSxHQUFHLENBQUNlLEtBQUosQ0FBVUQsQ0FBQyxDQUFDRSxLQUFaO0FBQ0FMLFFBQUFBLE9BQU87QUFDVixPQUhNLENBQVA7QUFJSDs7QUFFREEsSUFBQUEsT0FBTyxDQUFDQyxNQUFELENBQVA7QUFDSCxHQXRCMkIsQ0FBcEIsQ0FBUjtBQXdCQSxTQUFPRixPQUFPLENBQUNRLEdBQVIsQ0FBWWQsS0FBWixDQUFQO0FBQ0gsQ0F4Q007OztBQTBDQSxJQUFJZSxxQkFBcUIsR0FBR2xCLElBQTVCOzs7QUFDQSxJQUFJbUIsbUJBQW1CLEdBQUlDLEVBQUQsSUFBUTtBQUNyQyxTQUFPLFVBQVUsR0FBR2hCLElBQWIsRUFBbUI7QUFDdEIsV0FBT0ssT0FBTyxDQUFDQyxPQUFSLENBQWdCVSxFQUFFLENBQUNSLEtBQUgsQ0FBUyxJQUFULEVBQWVSLElBQWYsQ0FBaEIsQ0FBUDtBQUNILEdBRkQ7QUFHSCxDQUpNOzs7O0FBS0EsSUFBSWlCLFdBQVcsR0FBRyxDQUFDQyxDQUFELEVBQUlDLE1BQUosS0FBZUEsTUFBakM7OztBQUNBLElBQUlDLGtCQUFrQixHQUFHLEtBQXpCOzs7QUFDQSxJQUFJQyxXQUFXLEdBQUcsQ0FBQ0wsRUFBRCxFQUFLRSxDQUFMLEVBQVFsQixJQUFJLEdBQUcsRUFBZixLQUFzQmdCLEVBQUUsQ0FBQ1IsS0FBSCxTQUFlUixJQUFmLENBQXhDOzs7O0FBQ0EsSUFBSXNCLFlBQVksR0FBRyxDQUFDTixFQUFELEVBQUtFLENBQUwsRUFBUWxCLElBQUksR0FBRyxFQUFmLEtBQXNCZ0IsRUFBRSxDQUFDUixLQUFILFNBQWVSLElBQWYsQ0FBekM7QUFFUDs7Ozs7OztBQUdBLElBQUk7QUFDQTtBQUNBLFFBQU11QixRQUFRLEdBQUdDLE9BQU8sQ0FBQyxZQUFELENBQXhCOztBQUNBLCtCQUFBSixrQkFBa0IsR0FBRyxJQUFyQjtBQUNBLGdDQUFBTCxtQkFBbUIsR0FBR1EsUUFBUSxDQUFDUixtQkFBL0I7QUFDQSxrQ0FBQUQscUJBQXFCLEdBQUdTLFFBQVEsQ0FBQ1QscUJBQWpDO0FBQ0Esd0JBQUFHLFdBQVcsR0FBR00sUUFBUSxDQUFDTixXQUF2QjtBQUNBLGlDQUFBcEIsb0JBQW9CLEdBQUcwQixRQUFRLENBQUMxQixvQkFBaEM7QUFDQSx3QkFBQXdCLFdBQVcsR0FBR0UsUUFBUSxDQUFDRixXQUF2QjtBQUNBLHlCQUFBQyxZQUFZLEdBQUdDLFFBQVEsQ0FBQ0QsWUFBeEI7QUFDSCxDQVZELENBVUUsZ0JBQU0sQ0FDSjtBQUNIIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGxvZ2dlciBmcm9tICdAd2Rpby9sb2dnZXInXG5cbmNvbnN0IGxvZyA9IGxvZ2dlcignQHdkaW8vY29uZmlnJylcbmNvbnN0IE5PT1AgPSAoKSA9PiB7fVxuXG5leHBvcnQgbGV0IGV4ZWN1dGVIb29rc1dpdGhBcmdzID0gYXN5bmMgZnVuY3Rpb24gZXhlY3V0ZUhvb2tzV2l0aEFyZ3NTaGltIChob29rcywgYXJncykge1xuICAgIC8qKlxuICAgICAqIG1ha2Ugc3VyZSBob29rcyBhcmUgYW4gYXJyYXkgb2YgZnVuY3Rpb25zXG4gICAgICovXG4gICAgaWYgKCFBcnJheS5pc0FycmF5KGhvb2tzKSkge1xuICAgICAgICBob29rcyA9IFtob29rc11cbiAgICB9XG5cbiAgICAvKipcbiAgICAgKiBtYWtlIHN1cmUgYXJncyBpcyBhbiBhcnJheSBzaW5jZSB3ZSBhcmUgY2FsbGluZyBhcHBseVxuICAgICAqL1xuICAgIGlmICghQXJyYXkuaXNBcnJheShhcmdzKSkge1xuICAgICAgICBhcmdzID0gW2FyZ3NdXG4gICAgfVxuXG4gICAgaG9va3MgPSBob29rcy5tYXAoKGhvb2spID0+IG5ldyBQcm9taXNlKChyZXNvbHZlKSA9PiB7XG4gICAgICAgIGxldCByZXN1bHRcblxuICAgICAgICB0cnkge1xuICAgICAgICAgICAgcmVzdWx0ID0gaG9vay5hcHBseShudWxsLCBhcmdzKVxuICAgICAgICB9IGNhdGNoIChlKSB7XG4gICAgICAgICAgICBsb2cuZXJyb3IoZS5zdGFjaylcbiAgICAgICAgICAgIHJldHVybiByZXNvbHZlKClcbiAgICAgICAgfVxuXG4gICAgICAgIC8qKlxuICAgICAgICAgKiBpZiBhIHByb21pc2UgaXMgcmV0dXJuZWQgbWFrZSBzdXJlIHdlIGRvbid0IGhhdmUgYSBjYXRjaCBoYW5kbGVyXG4gICAgICAgICAqIHNvIGluIGNhc2Ugb2YgYSByZWplY3Rpb24gaXQgd29uJ3QgY2F1c2UgdGhlIGhvb2sgdG8gZmFpbFxuICAgICAgICAgKi9cbiAgICAgICAgaWYgKHJlc3VsdCAmJiB0eXBlb2YgcmVzdWx0LnRoZW4gPT09ICdmdW5jdGlvbicpIHtcbiAgICAgICAgICAgIHJldHVybiByZXN1bHQudGhlbihyZXNvbHZlLCAoZSkgPT4ge1xuICAgICAgICAgICAgICAgIGxvZy5lcnJvcihlLnN0YWNrKVxuICAgICAgICAgICAgICAgIHJlc29sdmUoKVxuICAgICAgICAgICAgfSlcbiAgICAgICAgfVxuXG4gICAgICAgIHJlc29sdmUocmVzdWx0KVxuICAgIH0pKVxuXG4gICAgcmV0dXJuIFByb21pc2UuYWxsKGhvb2tzKVxufVxuXG5leHBvcnQgbGV0IHJ1blRlc3RJbkZpYmVyQ29udGV4dCA9IE5PT1BcbmV4cG9ydCBsZXQgcnVuRm5JbkZpYmVyQ29udGV4dCA9IChmbikgPT4ge1xuICAgIHJldHVybiBmdW5jdGlvbiAoLi4uYXJncykge1xuICAgICAgICByZXR1cm4gUHJvbWlzZS5yZXNvbHZlKGZuLmFwcGx5KHRoaXMsIGFyZ3MpKVxuICAgIH1cbn1cbmV4cG9ydCBsZXQgd3JhcENvbW1hbmQgPSAoXywgb3JpZ0ZuKSA9PiBvcmlnRm5cbmV4cG9ydCBsZXQgaGFzV2Rpb1N5bmNTdXBwb3J0ID0gZmFsc2VcbmV4cG9ydCBsZXQgZXhlY3V0ZVN5bmMgPSAoZm4sIF8sIGFyZ3MgPSBbXSkgPT4gZm4uYXBwbHkodGhpcywgYXJncylcbmV4cG9ydCBsZXQgZXhlY3V0ZUFzeW5jID0gKGZuLCBfLCBhcmdzID0gW10pID0+IGZuLmFwcGx5KHRoaXMsIGFyZ3MpXG5cbi8qKlxuICogc2hpbSB0byBtYWtlIHN1cmUgdGhhdCB3ZSBvbmx5IHdyYXAgY29tbWFuZHMgaWYgd2Rpby1zeW5jIGlzIGluc3RhbGxlZCBhcyBkZXBlbmRlbmN5XG4gKi9cbnRyeSB7XG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIGltcG9ydC9uby11bnJlc29sdmVkXG4gICAgY29uc3Qgd2Rpb1N5bmMgPSByZXF1aXJlKCdAd2Rpby9zeW5jJylcbiAgICBoYXNXZGlvU3luY1N1cHBvcnQgPSB0cnVlXG4gICAgcnVuRm5JbkZpYmVyQ29udGV4dCA9IHdkaW9TeW5jLnJ1bkZuSW5GaWJlckNvbnRleHRcbiAgICBydW5UZXN0SW5GaWJlckNvbnRleHQgPSB3ZGlvU3luYy5ydW5UZXN0SW5GaWJlckNvbnRleHRcbiAgICB3cmFwQ29tbWFuZCA9IHdkaW9TeW5jLndyYXBDb21tYW5kXG4gICAgZXhlY3V0ZUhvb2tzV2l0aEFyZ3MgPSB3ZGlvU3luYy5leGVjdXRlSG9va3NXaXRoQXJnc1xuICAgIGV4ZWN1dGVTeW5jID0gd2Rpb1N5bmMuZXhlY3V0ZVN5bmNcbiAgICBleGVjdXRlQXN5bmMgPSB3ZGlvU3luYy5leGVjdXRlQXN5bmNcbn0gY2F0Y2gge1xuICAgIC8vIGRvIG5vdGhpbmdcbn1cbiJdfQ==
|
|
83
|
+
} catch (_unused) {}
|
package/build/utils.js
CHANGED
|
@@ -6,15 +6,11 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
6
6
|
exports.getSauceEndpoint = getSauceEndpoint;
|
|
7
7
|
exports.detectBackend = detectBackend;
|
|
8
8
|
exports.validateConfig = validateConfig;
|
|
9
|
-
|
|
10
|
-
require("source-map-support/register");
|
|
11
|
-
|
|
12
9
|
const DEFAULT_HOSTNAME = '127.0.0.1';
|
|
13
10
|
const DEFAULT_PORT = 4444;
|
|
14
11
|
const DEFAULT_PROTOCOL = 'http';
|
|
15
12
|
const REGION_MAPPING = {
|
|
16
13
|
'us': '',
|
|
17
|
-
// default endpoint
|
|
18
14
|
'eu': 'eu-central-1.',
|
|
19
15
|
'eu-central-1': 'eu-central-1.',
|
|
20
16
|
'us-east-1': 'us-east-1.'
|
|
@@ -29,10 +25,6 @@ function getSauceEndpoint(region, isRDC) {
|
|
|
29
25
|
|
|
30
26
|
return `ondemand.${REGION_MAPPING[shortRegion]}saucelabs.com`;
|
|
31
27
|
}
|
|
32
|
-
/**
|
|
33
|
-
* helper to detect the Selenium backend according to given capabilities
|
|
34
|
-
*/
|
|
35
|
-
|
|
36
28
|
|
|
37
29
|
function detectBackend(options = {}, isRDC = false) {
|
|
38
30
|
let {
|
|
@@ -44,10 +36,6 @@ function detectBackend(options = {}, isRDC = false) {
|
|
|
44
36
|
region,
|
|
45
37
|
headless
|
|
46
38
|
} = options;
|
|
47
|
-
/**
|
|
48
|
-
* browserstack
|
|
49
|
-
* e.g. zHcv9sZ39ip8ZPsxBVJ2
|
|
50
|
-
*/
|
|
51
39
|
|
|
52
40
|
if (typeof user === 'string' && typeof key === 'string' && key.length === 20) {
|
|
53
41
|
return {
|
|
@@ -56,11 +44,6 @@ function detectBackend(options = {}, isRDC = false) {
|
|
|
56
44
|
port: 443
|
|
57
45
|
};
|
|
58
46
|
}
|
|
59
|
-
/**
|
|
60
|
-
* testingbot
|
|
61
|
-
* e.g. ec337d7b677720a4dde7bd72be0bfc67
|
|
62
|
-
*/
|
|
63
|
-
|
|
64
47
|
|
|
65
48
|
if (typeof user === 'string' && typeof key === 'string' && key.length === 32) {
|
|
66
49
|
return {
|
|
@@ -68,16 +51,8 @@ function detectBackend(options = {}, isRDC = false) {
|
|
|
68
51
|
port: 80
|
|
69
52
|
};
|
|
70
53
|
}
|
|
71
|
-
/**
|
|
72
|
-
* Sauce Labs
|
|
73
|
-
* e.g. 50aa152c-1932-B2f0-9707-18z46q2n1mb0
|
|
74
|
-
*/
|
|
75
54
|
|
|
76
|
-
|
|
77
|
-
if (typeof user === 'string' && typeof key === 'string' && key.length === 36 || // When SC is used a user needs to be provided and `isRDC` needs to be true
|
|
78
|
-
typeof user === 'string' && isRDC || // Or only RDC
|
|
79
|
-
isRDC) {
|
|
80
|
-
// Sauce headless is currently only in us-east-1
|
|
55
|
+
if (typeof user === 'string' && typeof key === 'string' && key.length === 36 || typeof user === 'string' && isRDC || isRDC) {
|
|
81
56
|
const sauceRegion = headless ? 'us-east-1' : region;
|
|
82
57
|
return {
|
|
83
58
|
protocol: protocol || 'https',
|
|
@@ -86,21 +61,9 @@ function detectBackend(options = {}, isRDC = false) {
|
|
|
86
61
|
};
|
|
87
62
|
}
|
|
88
63
|
|
|
89
|
-
if (
|
|
90
|
-
/**
|
|
91
|
-
* user and key are set in config
|
|
92
|
-
*/
|
|
93
|
-
(typeof user === 'string' || typeof key === 'string') &&
|
|
94
|
-
/**
|
|
95
|
-
* but no custom WebDriver endpoint was configured
|
|
96
|
-
*/
|
|
97
|
-
!hostname) {
|
|
64
|
+
if ((typeof user === 'string' || typeof key === 'string') && !hostname) {
|
|
98
65
|
throw new Error('A "user" or "key" was provided but could not be connected to a ' + 'known cloud service (SauceLabs, Browerstack or Testingbot). ' + 'Please check if given user and key properties are correct!');
|
|
99
66
|
}
|
|
100
|
-
/**
|
|
101
|
-
* no cloud provider detected, fallback to local browser driver
|
|
102
|
-
*/
|
|
103
|
-
|
|
104
67
|
|
|
105
68
|
return {
|
|
106
69
|
hostname: hostname || DEFAULT_HOSTNAME,
|
|
@@ -108,21 +71,11 @@ function detectBackend(options = {}, isRDC = false) {
|
|
|
108
71
|
protocol: protocol || DEFAULT_PROTOCOL
|
|
109
72
|
};
|
|
110
73
|
}
|
|
111
|
-
/**
|
|
112
|
-
* validates configurations based on default values
|
|
113
|
-
* @param {Object} defaults object describing all allowed properties
|
|
114
|
-
* @param {Object} options option to check agains
|
|
115
|
-
* @return {Object} validated config enriched with default values
|
|
116
|
-
*/
|
|
117
|
-
|
|
118
74
|
|
|
119
75
|
function validateConfig(defaults, options) {
|
|
120
76
|
const params = {};
|
|
121
77
|
|
|
122
78
|
for (const [name, expectedOption] of Object.entries(defaults)) {
|
|
123
|
-
/**
|
|
124
|
-
* check if options is given
|
|
125
|
-
*/
|
|
126
79
|
if (typeof options[name] === 'undefined' && !expectedOption.default && expectedOption.required) {
|
|
127
80
|
throw new Error(`Required option "${name}" is missing`);
|
|
128
81
|
}
|
|
@@ -153,5 +106,4 @@ function validateConfig(defaults, options) {
|
|
|
153
106
|
}
|
|
154
107
|
|
|
155
108
|
return params;
|
|
156
|
-
}
|
|
157
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/utils.js"],"names":["DEFAULT_HOSTNAME","DEFAULT_PORT","DEFAULT_PROTOCOL","REGION_MAPPING","getSauceEndpoint","region","isRDC","shortRegion","detectBackend","options","port","hostname","user","key","protocol","headless","length","sauceRegion","Error","validateConfig","defaults","params","name","expectedOption","Object","entries","default","required","type","e","message","match"],"mappings":"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","sourcesContent":["const DEFAULT_HOSTNAME = '127.0.0.1'\nconst DEFAULT_PORT = 4444\nconst DEFAULT_PROTOCOL = 'http'\n\nconst REGION_MAPPING = {\n    'us': '', // default endpoint\n    'eu': 'eu-central-1.',\n    'eu-central-1': 'eu-central-1.',\n    'us-east-1': 'us-east-1.'\n}\n\nexport function getSauceEndpoint (region, isRDC) {\n    const shortRegion = REGION_MAPPING[region] ? region : 'us'\n    if (isRDC){\n        return `${shortRegion}1.appium.testobject.com`\n    }\n\n    return `ondemand.${REGION_MAPPING[shortRegion]}saucelabs.com`\n}\n\n/**\n * helper to detect the Selenium backend according to given capabilities\n */\nexport function detectBackend (options = {}, isRDC = false) {\n    let { port, hostname, user, key, protocol, region, headless } = options\n\n    /**\n     * browserstack\n     * e.g. zHcv9sZ39ip8ZPsxBVJ2\n     */\n    if (typeof user === 'string' && typeof key === 'string' && key.length === 20) {\n        return {\n            protocol: 'https',\n            hostname: 'hub-cloud.browserstack.com',\n            port: 443\n        }\n    }\n\n    /**\n     * testingbot\n     * e.g. ec337d7b677720a4dde7bd72be0bfc67\n     */\n    if (typeof user === 'string' && typeof key === 'string' && key.length === 32) {\n        return {\n            hostname: 'hub.testingbot.com',\n            port: 80\n        }\n    }\n\n    /**\n     * Sauce Labs\n     * e.g. 50aa152c-1932-B2f0-9707-18z46q2n1mb0\n     */\n    if ((typeof user === 'string' && typeof key === 'string' && key.length === 36) ||\n        // When SC is used a user needs to be provided and `isRDC` needs to be true\n        (typeof user === 'string' && isRDC) ||\n        // Or only RDC\n        isRDC\n    ) {\n        // Sauce headless is currently only in us-east-1\n        const sauceRegion = headless ? 'us-east-1' : region\n\n        return {\n            protocol: protocol || 'https',\n            hostname: hostname || getSauceEndpoint(sauceRegion, isRDC),\n            port: port || 443\n        }\n    }\n\n    if (\n        /**\n         * user and key are set in config\n         */\n        (typeof user === 'string' || typeof key === 'string') &&\n        /**\n         * but no custom WebDriver endpoint was configured\n         */\n        !hostname\n    ) {\n        throw new Error(\n            'A \"user\" or \"key\" was provided but could not be connected to a ' +\n            'known cloud service (SauceLabs, Browerstack or Testingbot). ' +\n            'Please check if given user and key properties are correct!'\n        )\n    }\n\n    /**\n     * no cloud provider detected, fallback to local browser driver\n     */\n    return {\n        hostname: hostname || DEFAULT_HOSTNAME,\n        port: port || DEFAULT_PORT,\n        protocol: protocol || DEFAULT_PROTOCOL\n    }\n}\n\n/**\n * validates configurations based on default values\n * @param  {Object} defaults  object describing all allowed properties\n * @param  {Object} options   option to check agains\n * @return {Object}           validated config enriched with default values\n */\nexport function validateConfig (defaults, options) {\n    const params = {}\n\n    for (const [name, expectedOption] of Object.entries(defaults)) {\n        /**\n         * check if options is given\n         */\n        if (typeof options[name] === 'undefined' && !expectedOption.default && expectedOption.required) {\n            throw new Error(`Required option \"${name}\" is missing`)\n        }\n\n        if (typeof options[name] === 'undefined' && expectedOption.default) {\n            params[name] = expectedOption.default\n        }\n\n        if (typeof options[name] !== 'undefined') {\n            if (typeof expectedOption.type === 'string' && typeof options[name] !== expectedOption.type) {\n                throw new Error(`Expected option \"${name}\" to be type of ${expectedOption.type} but was ${typeof options[name]}`)\n            }\n\n            if (typeof expectedOption.type === 'function') {\n                try {\n                    expectedOption.type(options[name])\n                } catch (e) {\n                    throw new Error(`Type check for option \"${name}\" failed: ${e.message}`)\n                }\n            }\n\n            if (expectedOption.match && !options[name].match(expectedOption.match)) {\n                throw new Error(`Option \"${name}\" doesn't match expected values: ${expectedOption.match}`)\n            }\n\n            params[name] = options[name]\n        }\n    }\n\n    return params\n}\n"]}
|
|
109
|
+
}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@wdio/config",
|
|
3
|
-
"version": "5.
|
|
3
|
+
"version": "5.12.1",
|
|
4
4
|
"description": "A helper utility to parse and validate WebdriverIO options",
|
|
5
5
|
"author": "Christian Bromann <christian@saucelabs.com>",
|
|
6
6
|
"homepage": "https://github.com/webdriverio/webdriverio/tree/master/packages/wdio-config",
|
|
@@ -30,11 +30,12 @@
|
|
|
30
30
|
"url": "https://github.com/webdriverio/webdriverio/issues"
|
|
31
31
|
},
|
|
32
32
|
"dependencies": {
|
|
33
|
-
"@wdio/logger": "^5.
|
|
34
|
-
"deepmerge": "^
|
|
33
|
+
"@wdio/logger": "^5.12.1",
|
|
34
|
+
"deepmerge": "^4.0.0",
|
|
35
35
|
"glob": "^7.1.2"
|
|
36
36
|
},
|
|
37
37
|
"publishConfig": {
|
|
38
38
|
"access": "public"
|
|
39
|
-
}
|
|
39
|
+
},
|
|
40
|
+
"gitHead": "848151e5fdcb8b694c1a273b9b69852c22875687"
|
|
40
41
|
}
|