@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.
@@ -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
- afterFeature: [],
59
+ afterStep: [],
77
60
  afterScenario: [],
78
- afterStep: []
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', 'afterFeature', 'afterScenario', 'afterStep', 'onReload', 'onPrepare', 'onComplete'];
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
- } // Allow --suite and --spec to both be defined on the command line
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) {// do nothing
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.9.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.9.3",
34
- "deepmerge": "^3.2.0",
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
  }