appium 2.0.0-beta.18 → 2.0.0-beta.21
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/lib/appium-config.schema.json +0 -0
- package/build/lib/appium.js +84 -69
- package/build/lib/cli/argparse-actions.js +1 -1
- package/build/lib/cli/args.js +87 -223
- package/build/lib/cli/extension-command.js +2 -2
- package/build/lib/cli/extension.js +14 -6
- package/build/lib/cli/parser.js +142 -106
- package/build/lib/cli/utils.js +1 -1
- package/build/lib/config-file.js +141 -0
- package/build/lib/config.js +42 -64
- package/build/lib/driver-config.js +41 -20
- package/build/lib/drivers.js +1 -1
- package/build/lib/ext-config-io.js +165 -0
- package/build/lib/extension-config.js +110 -60
- package/build/lib/grid-register.js +19 -21
- package/build/lib/logsink.js +1 -1
- package/build/lib/main.js +135 -72
- package/build/lib/plugin-config.js +17 -8
- package/build/lib/schema/appium-config-schema.js +252 -0
- package/build/lib/schema/arg-spec.js +120 -0
- package/build/lib/schema/cli-args.js +173 -0
- package/build/lib/schema/cli-transformers.js +76 -0
- package/build/lib/schema/index.js +36 -0
- package/build/lib/schema/keywords.js +62 -0
- package/build/lib/schema/schema.js +357 -0
- package/build/lib/utils.js +26 -35
- package/lib/appium-config.schema.json +277 -0
- package/lib/appium.js +99 -75
- package/lib/cli/args.js +138 -335
- package/lib/cli/extension-command.js +7 -6
- package/lib/cli/extension.js +12 -4
- package/lib/cli/parser.js +248 -96
- package/lib/config-file.js +227 -0
- package/lib/config.js +71 -61
- package/lib/driver-config.js +66 -11
- package/lib/ext-config-io.js +287 -0
- package/lib/extension-config.js +209 -66
- package/lib/grid-register.js +24 -21
- package/lib/main.js +139 -68
- package/lib/plugin-config.js +32 -2
- package/lib/schema/appium-config-schema.js +286 -0
- package/lib/schema/arg-spec.js +218 -0
- package/lib/schema/cli-args.js +273 -0
- package/lib/schema/cli-transformers.js +123 -0
- package/lib/schema/index.js +2 -0
- package/lib/schema/keywords.js +119 -0
- package/lib/schema/schema.js +577 -0
- package/lib/utils.js +29 -52
- package/package.json +17 -11
- package/types/appium-config.d.ts +197 -0
- package/types/types.d.ts +201 -0
- package/LICENSE +0 -201
- package/build/lib/cli/parser-helpers.js +0 -106
- package/lib/cli/parser-helpers.js +0 -106
package/build/lib/main.js
CHANGED
|
@@ -6,39 +6,70 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
|
|
|
6
6
|
Object.defineProperty(exports, "__esModule", {
|
|
7
7
|
value: true
|
|
8
8
|
});
|
|
9
|
+
Object.defineProperty(exports, "APPIUM_HOME", {
|
|
10
|
+
enumerable: true,
|
|
11
|
+
get: function () {
|
|
12
|
+
return _extensionConfig.APPIUM_HOME;
|
|
13
|
+
}
|
|
14
|
+
});
|
|
15
|
+
Object.defineProperty(exports, "finalizeSchema", {
|
|
16
|
+
enumerable: true,
|
|
17
|
+
get: function () {
|
|
18
|
+
return _schema.finalizeSchema;
|
|
19
|
+
}
|
|
20
|
+
});
|
|
21
|
+
Object.defineProperty(exports, "getSchema", {
|
|
22
|
+
enumerable: true,
|
|
23
|
+
get: function () {
|
|
24
|
+
return _schema.getSchema;
|
|
25
|
+
}
|
|
26
|
+
});
|
|
27
|
+
exports.init = init;
|
|
9
28
|
exports.main = main;
|
|
29
|
+
Object.defineProperty(exports, "readConfigFile", {
|
|
30
|
+
enumerable: true,
|
|
31
|
+
get: function () {
|
|
32
|
+
return _configFile.readConfigFile;
|
|
33
|
+
}
|
|
34
|
+
});
|
|
35
|
+
Object.defineProperty(exports, "validate", {
|
|
36
|
+
enumerable: true,
|
|
37
|
+
get: function () {
|
|
38
|
+
return _schema.validate;
|
|
39
|
+
}
|
|
40
|
+
});
|
|
10
41
|
|
|
11
42
|
require("source-map-support/register");
|
|
12
43
|
|
|
13
|
-
var _logsink = require("./logsink");
|
|
14
|
-
|
|
15
|
-
var _logger = _interopRequireDefault(require("./logger"));
|
|
16
|
-
|
|
17
|
-
var _lodash = _interopRequireDefault(require("lodash"));
|
|
18
|
-
|
|
19
44
|
var _baseDriver = require("@appium/base-driver");
|
|
20
45
|
|
|
46
|
+
var _support = require("@appium/support");
|
|
47
|
+
|
|
21
48
|
var _asyncbox = require("asyncbox");
|
|
22
49
|
|
|
23
|
-
var
|
|
50
|
+
var _lodash = _interopRequireDefault(require("lodash"));
|
|
51
|
+
|
|
52
|
+
var _appium = require("./appium");
|
|
24
53
|
|
|
25
54
|
var _args = require("./cli/args");
|
|
26
55
|
|
|
27
|
-
var
|
|
56
|
+
var _extension = require("./cli/extension");
|
|
28
57
|
|
|
29
|
-
var
|
|
58
|
+
var _parser = _interopRequireWildcard(require("./cli/parser"));
|
|
30
59
|
|
|
31
|
-
var
|
|
60
|
+
var _config = require("./config");
|
|
32
61
|
|
|
33
|
-
var
|
|
62
|
+
var _configFile = require("./config-file");
|
|
34
63
|
|
|
35
64
|
var _extensionConfig = require("./extension-config");
|
|
36
65
|
|
|
37
|
-
var
|
|
66
|
+
var _gridRegister = _interopRequireDefault(require("./grid-register"));
|
|
38
67
|
|
|
39
|
-
var
|
|
68
|
+
var _logger = _interopRequireDefault(require("./logger"));
|
|
40
69
|
|
|
41
|
-
var
|
|
70
|
+
var _logsink = require("./logsink");
|
|
71
|
+
|
|
72
|
+
var _schema = require("./schema/schema");
|
|
42
73
|
|
|
43
74
|
var _utils = require("./utils");
|
|
44
75
|
|
|
@@ -46,13 +77,7 @@ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "functio
|
|
|
46
77
|
|
|
47
78
|
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
|
48
79
|
|
|
49
|
-
async function preflightChecks({
|
|
50
|
-
parser,
|
|
51
|
-
args,
|
|
52
|
-
driverConfig,
|
|
53
|
-
pluginConfig,
|
|
54
|
-
throwInsteadOfExit = false
|
|
55
|
-
}) {
|
|
80
|
+
async function preflightChecks(args, throwInsteadOfExit = false) {
|
|
56
81
|
try {
|
|
57
82
|
(0, _config.checkNodeOk)();
|
|
58
83
|
|
|
@@ -66,9 +91,7 @@ async function preflightChecks({
|
|
|
66
91
|
}
|
|
67
92
|
|
|
68
93
|
(0, _config.warnNodeDeprecations)();
|
|
69
|
-
(0,
|
|
70
|
-
await driverConfig.read();
|
|
71
|
-
await pluginConfig.read();
|
|
94
|
+
(0, _schema.validate)(args);
|
|
72
95
|
|
|
73
96
|
if (args.tmpDir) {
|
|
74
97
|
await (0, _config.validateTmpDir)(args.tmpDir);
|
|
@@ -106,7 +129,7 @@ async function logStartupInfo(parser, args) {
|
|
|
106
129
|
|
|
107
130
|
_logger.default.info(welcome);
|
|
108
131
|
|
|
109
|
-
let showArgs = (0, _config.
|
|
132
|
+
let showArgs = (0, _config.getNonDefaultServerArgs)(parser, args);
|
|
110
133
|
|
|
111
134
|
if (_lodash.default.size(showArgs)) {
|
|
112
135
|
logNonDefaultArgsWarning(showArgs);
|
|
@@ -124,7 +147,7 @@ function logServerPort(address, port) {
|
|
|
124
147
|
}
|
|
125
148
|
|
|
126
149
|
function getActivePlugins(args, pluginConfig) {
|
|
127
|
-
return Object.keys(pluginConfig.installedExtensions).filter(pluginName => _lodash.default.includes(args.
|
|
150
|
+
return _lodash.default.compact(Object.keys(pluginConfig.installedExtensions).filter(pluginName => _lodash.default.includes(args.usePlugins, pluginName) || args.usePlugins.length === 1 && args.usePlugins[0] === _args.USE_ALL_PLUGINS).map(pluginName => {
|
|
128
151
|
try {
|
|
129
152
|
_logger.default.info(`Attempting to load plugin ${pluginName}...`);
|
|
130
153
|
|
|
@@ -136,14 +159,12 @@ function getActivePlugins(args, pluginConfig) {
|
|
|
136
159
|
_logger.default.error(`Could not load plugin '${pluginName}', so it will not be available. Error ` + `in loading the plugin was: ${err.message}`);
|
|
137
160
|
|
|
138
161
|
_logger.default.debug(err.stack);
|
|
139
|
-
|
|
140
|
-
return false;
|
|
141
162
|
}
|
|
142
|
-
})
|
|
163
|
+
}));
|
|
143
164
|
}
|
|
144
165
|
|
|
145
166
|
function getActiveDrivers(args, driverConfig) {
|
|
146
|
-
return Object.keys(driverConfig.installedExtensions).filter(driverName => _lodash.default.includes(args.
|
|
167
|
+
return _lodash.default.compact(Object.keys(driverConfig.installedExtensions).filter(driverName => _lodash.default.includes(args.useDrivers, driverName) || args.useDrivers.length === 0).map(driverName => {
|
|
147
168
|
try {
|
|
148
169
|
_logger.default.info(`Attempting to load driver ${driverName}...`);
|
|
149
170
|
|
|
@@ -152,10 +173,8 @@ function getActiveDrivers(args, driverConfig) {
|
|
|
152
173
|
_logger.default.error(`Could not load driver '${driverName}', so it will not be available. Error ` + `in loading the driver was: ${err.message}`);
|
|
153
174
|
|
|
154
175
|
_logger.default.debug(err.stack);
|
|
155
|
-
|
|
156
|
-
return false;
|
|
157
176
|
}
|
|
158
|
-
})
|
|
177
|
+
}));
|
|
159
178
|
}
|
|
160
179
|
|
|
161
180
|
function getServerUpdaters(driverClasses, pluginClasses) {
|
|
@@ -168,75 +187,116 @@ function getExtraMethodMap(driverClasses, pluginClasses) {
|
|
|
168
187
|
}), {});
|
|
169
188
|
}
|
|
170
189
|
|
|
171
|
-
async function
|
|
172
|
-
|
|
190
|
+
async function init(args) {
|
|
191
|
+
var _configResult$config2;
|
|
192
|
+
|
|
193
|
+
const parser = await (0, _parser.default)();
|
|
173
194
|
let throwInsteadOfExit = false;
|
|
195
|
+
let parsedArgs;
|
|
174
196
|
|
|
175
197
|
if (args) {
|
|
176
|
-
|
|
198
|
+
var _args$subcommand;
|
|
177
199
|
|
|
178
200
|
if (args.throwInsteadOfExit) {
|
|
179
201
|
throwInsteadOfExit = true;
|
|
180
202
|
delete args.throwInsteadOfExit;
|
|
181
203
|
}
|
|
204
|
+
|
|
205
|
+
parsedArgs = { ...args,
|
|
206
|
+
subcommand: (_args$subcommand = args.subcommand) !== null && _args$subcommand !== void 0 ? _args$subcommand : _parser.SERVER_SUBCOMMAND
|
|
207
|
+
};
|
|
182
208
|
} else {
|
|
183
|
-
|
|
209
|
+
parsedArgs = parser.parseArgs();
|
|
210
|
+
}
|
|
211
|
+
|
|
212
|
+
const configResult = await (0, _configFile.readConfigFile)(parsedArgs.configFile);
|
|
213
|
+
|
|
214
|
+
if (!_lodash.default.isEmpty(configResult.errors)) {
|
|
215
|
+
var _configResult$reason;
|
|
216
|
+
|
|
217
|
+
throw new Error(`Errors in config file ${configResult.filepath}:\n ${(_configResult$reason = configResult.reason) !== null && _configResult$reason !== void 0 ? _configResult$reason : configResult.errors}`);
|
|
218
|
+
}
|
|
219
|
+
|
|
220
|
+
if (parsedArgs.subcommand === _parser.SERVER_SUBCOMMAND) {
|
|
221
|
+
var _configResult$config;
|
|
222
|
+
|
|
223
|
+
parsedArgs = _lodash.default.defaultsDeep(parsedArgs, (_configResult$config = configResult.config) === null || _configResult$config === void 0 ? void 0 : _configResult$config.server, (0, _schema.getDefaultsFromSchema)());
|
|
184
224
|
}
|
|
185
225
|
|
|
186
|
-
|
|
226
|
+
parsedArgs = _lodash.default.defaultsDeep(parsedArgs, (_configResult$config2 = configResult.config) !== null && _configResult$config2 !== void 0 ? _configResult$config2 : {});
|
|
227
|
+
await (0, _logsink.init)(parsedArgs);
|
|
228
|
+
|
|
229
|
+
if (parsedArgs.subcommand === _extensionConfig.DRIVER_TYPE) {
|
|
230
|
+
await (0, _extension.runExtensionCommand)(parsedArgs, parsedArgs.subcommand, _args.driverConfig);
|
|
231
|
+
return {
|
|
232
|
+
parser
|
|
233
|
+
};
|
|
234
|
+
}
|
|
187
235
|
|
|
188
|
-
if (
|
|
189
|
-
await (0, _extension.runExtensionCommand)(
|
|
190
|
-
|
|
236
|
+
if (parsedArgs.subcommand === _extensionConfig.PLUGIN_TYPE) {
|
|
237
|
+
await (0, _extension.runExtensionCommand)(parsedArgs, parsedArgs.subcommand, _args.pluginConfig);
|
|
238
|
+
return {
|
|
239
|
+
parser
|
|
240
|
+
};
|
|
191
241
|
}
|
|
192
242
|
|
|
193
|
-
if (
|
|
243
|
+
if (parsedArgs.logFilters) {
|
|
194
244
|
const {
|
|
195
245
|
issues,
|
|
196
246
|
rules
|
|
197
|
-
} = await _support.logger.loadSecureValuesPreprocessingRules(
|
|
247
|
+
} = await _support.logger.loadSecureValuesPreprocessingRules(parsedArgs.logFilters);
|
|
198
248
|
|
|
199
249
|
if (!_lodash.default.isEmpty(issues)) {
|
|
200
|
-
throw new Error(`The log filtering rules config '${
|
|
250
|
+
throw new Error(`The log filtering rules config '${parsedArgs.logFilters}' has issues: ` + JSON.stringify(issues, null, 2));
|
|
201
251
|
}
|
|
202
252
|
|
|
203
253
|
if (_lodash.default.isEmpty(rules)) {
|
|
204
|
-
_logger.default.warn(`Found no log filtering rules in '${
|
|
254
|
+
_logger.default.warn(`Found no log filtering rules in '${parsedArgs.logFilters}'. Is that expected?`);
|
|
205
255
|
} else {
|
|
206
|
-
_logger.default.info(`Loaded ${_support.util.pluralize('filtering rule', rules.length, true)} from '${
|
|
256
|
+
_logger.default.info(`Loaded ${_support.util.pluralize('filtering rule', rules.length, true)} from '${parsedArgs.logFilters}'`);
|
|
207
257
|
}
|
|
208
258
|
}
|
|
209
259
|
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
260
|
+
const appiumDriver = new _appium.AppiumDriver(parsedArgs);
|
|
261
|
+
appiumDriver.driverConfig = _args.driverConfig;
|
|
262
|
+
await preflightChecks(parsedArgs, throwInsteadOfExit);
|
|
263
|
+
return {
|
|
264
|
+
parser,
|
|
265
|
+
appiumDriver,
|
|
266
|
+
parsedArgs
|
|
267
|
+
};
|
|
268
|
+
}
|
|
269
|
+
|
|
270
|
+
async function main(args) {
|
|
271
|
+
const {
|
|
215
272
|
parser,
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
273
|
+
appiumDriver,
|
|
274
|
+
parsedArgs
|
|
275
|
+
} = await init(args);
|
|
276
|
+
|
|
277
|
+
if (!appiumDriver || !parsedArgs) {
|
|
278
|
+
return;
|
|
279
|
+
}
|
|
280
|
+
|
|
281
|
+
const pluginClasses = getActivePlugins(parsedArgs, _args.pluginConfig);
|
|
222
282
|
appiumDriver.pluginClasses = pluginClasses;
|
|
223
|
-
await logStartupInfo(parser,
|
|
283
|
+
await logStartupInfo(parser, parsedArgs);
|
|
224
284
|
let routeConfiguringFunction = (0, _baseDriver.routeConfiguringFunction)(appiumDriver);
|
|
225
|
-
const driverClasses = getActiveDrivers(
|
|
285
|
+
const driverClasses = getActiveDrivers(parsedArgs, _args.driverConfig);
|
|
226
286
|
const serverUpdaters = getServerUpdaters(driverClasses, pluginClasses);
|
|
227
287
|
const extraMethodMap = getExtraMethodMap(driverClasses, pluginClasses);
|
|
228
288
|
const serverOpts = {
|
|
229
289
|
routeConfiguringFunction,
|
|
230
|
-
port:
|
|
231
|
-
hostname:
|
|
232
|
-
allowCors:
|
|
233
|
-
basePath:
|
|
290
|
+
port: parsedArgs.port,
|
|
291
|
+
hostname: parsedArgs.address,
|
|
292
|
+
allowCors: parsedArgs.allowCors,
|
|
293
|
+
basePath: parsedArgs.basePath,
|
|
234
294
|
serverUpdaters,
|
|
235
295
|
extraMethodMap
|
|
236
296
|
};
|
|
237
297
|
|
|
238
|
-
if (
|
|
239
|
-
serverOpts.keepAliveTimeout =
|
|
298
|
+
if (parsedArgs.keepAliveTimeout) {
|
|
299
|
+
serverOpts.keepAliveTimeout = parsedArgs.keepAliveTimeout * 1000;
|
|
240
300
|
}
|
|
241
301
|
|
|
242
302
|
let server;
|
|
@@ -251,15 +311,15 @@ async function main(args = null) {
|
|
|
251
311
|
return process.exit(1);
|
|
252
312
|
}
|
|
253
313
|
|
|
254
|
-
if (
|
|
314
|
+
if (parsedArgs.allowCors) {
|
|
255
315
|
_logger.default.warn('You have enabled CORS requests from any host. Be careful not ' + 'to visit sites which could maliciously try to start Appium ' + 'sessions on your machine');
|
|
256
316
|
}
|
|
257
317
|
|
|
258
318
|
appiumDriver.server = server;
|
|
259
319
|
|
|
260
320
|
try {
|
|
261
|
-
if (
|
|
262
|
-
await (0, _gridRegister.default)(
|
|
321
|
+
if (parsedArgs.nodeconfig) {
|
|
322
|
+
await (0, _gridRegister.default)(parsedArgs.nodeconfig, parsedArgs.address, parsedArgs.port, parsedArgs.basePath);
|
|
263
323
|
}
|
|
264
324
|
} catch (err) {
|
|
265
325
|
await server.close();
|
|
@@ -285,9 +345,12 @@ async function main(args = null) {
|
|
|
285
345
|
});
|
|
286
346
|
}
|
|
287
347
|
|
|
288
|
-
logServerPort(
|
|
289
|
-
|
|
290
|
-
|
|
348
|
+
logServerPort(parsedArgs.address, parsedArgs.port);
|
|
349
|
+
|
|
350
|
+
_args.driverConfig.print();
|
|
351
|
+
|
|
352
|
+
_args.pluginConfig.print(pluginClasses.map(p => p.pluginName));
|
|
353
|
+
|
|
291
354
|
return server;
|
|
292
355
|
}
|
|
293
356
|
|
|
@@ -296,4 +359,4 @@ if (require.main === module) {
|
|
|
296
359
|
}require('source-map-support').install();
|
|
297
360
|
|
|
298
361
|
|
|
299
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/main.js"],"names":["preflightChecks","parser","args","driverConfig","pluginConfig","throwInsteadOfExit","longStacktrace","require","async_trace_limit","showConfig","process","exit","read","tmpDir","err","logger","error","message","red","logNonDefaultArgsWarning","info","logDefaultCapabilitiesWarning","caps","logStartupInfo","welcome","APPIUM_VER","appiumRev","showArgs","_","size","isEmpty","defaultCapabilities","logServerPort","address","port","logMessage","getActivePlugins","Object","keys","installedExtensions","filter","pluginName","includes","plugins","length","USE_ALL_PLUGINS","map","PluginClass","debug","stack","Boolean","getActiveDrivers","driverName","drivers","getServerUpdaters","driverClasses","pluginClasses","klass","updateServer","getExtraMethodMap","reduce","newMethodMap","main","assign","parse_args","subcommand","DRIVER_TYPE","PLUGIN_TYPE","logFilters","issues","rules","logFactory","loadSecureValuesPreprocessingRules","Error","JSON","stringify","warn","util","pluralize","appiumDriver","AppiumDriver","DriverConfig","appiumHome","PluginConfig","routeConfiguringFunction","serverUpdaters","extraMethodMap","serverOpts","hostname","allowCors","basePath","keepAliveTimeout","server","nodeconfig","close","signal","once","onSignal","deleteAllSessions","force","reason","e","print","p","module"],"mappings":"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","sourcesContent":["#!/usr/bin/env node\n// transpile:main\n\nimport { init as logsinkInit } from './logsink';\nimport logger from './logger'; // logger needs to remain first of imports\nimport _ from 'lodash';\nimport { server as baseServer, routeConfiguringFunction as makeRouter } from '@appium/base-driver';\nimport { asyncify } from 'asyncbox';\nimport { default as getParser, getDefaultServerArgs } from './cli/parser';\nimport { USE_ALL_PLUGINS } from './cli/args';\nimport { logger as logFactory, util } from '@appium/support';\nimport {\n  showConfig, checkNodeOk, validateServerArgs,\n  warnNodeDeprecations, validateTmpDir, getNonDefaultArgs,\n  getGitRev, APPIUM_VER\n} from './config';\nimport DriverConfig from './driver-config';\nimport PluginConfig from './plugin-config';\nimport { DRIVER_TYPE, PLUGIN_TYPE } from './extension-config';\nimport { runExtensionCommand } from './cli/extension';\nimport { AppiumDriver } from './appium';\nimport registerNode from './grid-register';\nimport { inspectObject } from './utils';\n\n\nasync function preflightChecks ({parser, args, driverConfig, pluginConfig, throwInsteadOfExit = false}) {\n  try {\n    checkNodeOk();\n    if (args.longStacktrace) {\n      require('longjohn').async_trace_limit = -1;\n    }\n    if (args.showConfig) {\n      await showConfig();\n      process.exit(0);\n    }\n    warnNodeDeprecations();\n    validateServerArgs(parser, args);\n    await driverConfig.read();\n    await pluginConfig.read();\n    if (args.tmpDir) {\n      await validateTmpDir(args.tmpDir);\n    }\n  } catch (err) {\n    logger.error(err.message.red);\n    if (throwInsteadOfExit) {\n      throw err;\n    }\n\n    process.exit(1);\n  }\n}\n\nfunction logNonDefaultArgsWarning (args) {\n  logger.info('Non-default server args:');\n  inspectObject(args);\n}\n\nfunction logDefaultCapabilitiesWarning (caps) {\n  logger.info('Default capabilities, which will be added to each request ' +\n              'unless overridden by desired capabilities:');\n  inspectObject(caps);\n}\n\nasync function logStartupInfo (parser, args) {\n  let welcome = `Welcome to Appium v${APPIUM_VER}`;\n  let appiumRev = await getGitRev();\n  if (appiumRev) {\n    welcome += ` (REV ${appiumRev})`;\n  }\n  logger.info(welcome);\n\n  let showArgs = getNonDefaultArgs(parser, args);\n  if (_.size(showArgs)) {\n    logNonDefaultArgsWarning(showArgs);\n  }\n  if (!_.isEmpty(args.defaultCapabilities)) {\n    logDefaultCapabilitiesWarning(args.defaultCapabilities);\n  }\n  // TODO: bring back loglevel reporting below once logger is flushed out\n  // logger.info('Console LogLevel: ' + logger.transports.console.level);\n  // if (logger.transports.file) {\n  //   logger.info('File LogLevel: ' + logger.transports.file.level);\n  // }\n}\n\nfunction logServerPort (address, port) {\n  let logMessage = `Appium REST http interface listener started on ` +\n                   `${address}:${port}`;\n  logger.info(logMessage);\n}\n\n/**\n * Find any plugin name which has been installed, and which has been requested for activation by\n * using the --plugins flag, and turn each one into its class, so we can send them as objects to\n * the server init. We also want to send/assign them to the umbrella driver so it can use them to\n * wrap command execution\n *\n * @param {Object} args - argparser parsed dict\n * @param {PluginConfig} pluginConfig - a plugin extension config\n */\nfunction getActivePlugins (args, pluginConfig) {\n  return Object.keys(pluginConfig.installedExtensions).filter((pluginName) =>\n    _.includes(args.plugins, pluginName) ||\n    (args.plugins.length === 1 && args.plugins[0] === USE_ALL_PLUGINS)\n  ).map((pluginName) => {\n    try {\n      logger.info(`Attempting to load plugin ${pluginName}...`);\n      const PluginClass = pluginConfig.require(pluginName);\n      PluginClass.pluginName = pluginName; // store the plugin name on the class so it can be used later\n      return PluginClass;\n    } catch (err) {\n      logger.error(`Could not load plugin '${pluginName}', so it will not be available. Error ` +\n                   `in loading the plugin was: ${err.message}`);\n      logger.debug(err.stack);\n      return false;\n    }\n  }).filter(Boolean);\n}\n\n/**\n * Find any driver name which has been installed, and turn each one into its class, so we can send\n * them as objects to the server init in case they need to add methods/routes or update the server.\n * If the --drivers flag was given, this method only loads the given drivers.\n *\n * @param {Object} args - argparser parsed dict\n * @param {DriverConfig} driverConfig - a driver extension config\n */\nfunction getActiveDrivers (args, driverConfig) {\n  return Object.keys(driverConfig.installedExtensions).filter((driverName) =>\n    _.includes(args.drivers, driverName) || args.drivers.length === 0\n  ).map((driverName) => {\n    try {\n      logger.info(`Attempting to load driver ${driverName}...`);\n      return driverConfig.require(driverName);\n    } catch (err) {\n      logger.error(`Could not load driver '${driverName}', so it will not be available. Error ` +\n                   `in loading the driver was: ${err.message}`);\n      logger.debug(err.stack);\n      return false;\n    }\n  }).filter(Boolean);\n}\n\nfunction getServerUpdaters (driverClasses, pluginClasses) {\n  return [...driverClasses, ...pluginClasses].map((klass) => klass.updateServer).filter(Boolean);\n}\n\nfunction getExtraMethodMap (driverClasses, pluginClasses) {\n  return [...driverClasses, ...pluginClasses].reduce(\n    (map, klass) => ({...map, ...klass.newMethodMap}),\n    {}\n  );\n}\n\nasync function main (args = null) {\n  let parser = getParser();\n  let throwInsteadOfExit = false;\n  if (args) {\n    // a containing package passed in their own args, let's fill them out\n    // with defaults\n    args = Object.assign({}, getDefaultServerArgs(), args);\n\n    // if we have a containing package instead of running as a CLI process,\n    // that package might not appreciate us calling 'process.exit' willy-\n    // nilly, so give it the option to have us throw instead of exit\n    if (args.throwInsteadOfExit) {\n      throwInsteadOfExit = true;\n      // but remove it since it's not a real server arg per se\n      delete args.throwInsteadOfExit;\n    }\n  } else {\n    // otherwise parse from CLI\n    args = parser.parse_args();\n  }\n  await logsinkInit(args);\n\n  // if the user has requested the 'driver' CLI, don't run the normal server,\n  // but instead pass control to the driver CLI\n  if (args.subcommand === DRIVER_TYPE || args.subcommand === PLUGIN_TYPE) {\n    await runExtensionCommand(args, args.subcommand);\n    process.exit();\n  }\n\n  if (args.logFilters) {\n    const {issues, rules} = await logFactory.loadSecureValuesPreprocessingRules(args.logFilters);\n    if (!_.isEmpty(issues)) {\n      throw new Error(`The log filtering rules config '${args.logFilters}' has issues: ` +\n        JSON.stringify(issues, null, 2));\n    }\n    if (_.isEmpty(rules)) {\n      logger.warn(`Found no log filtering rules in '${args.logFilters}'. Is that expected?`);\n    } else {\n      logger.info(`Loaded ${util.pluralize('filtering rule', rules.length, true)} from '${args.logFilters}'`);\n    }\n  }\n\n  let appiumDriver = new AppiumDriver(args);\n  const driverConfig = new DriverConfig(args.appiumHome);\n  // set the config on the umbrella driver so it can match drivers to caps\n  appiumDriver.driverConfig = driverConfig;\n  const pluginConfig = new PluginConfig(args.appiumHome);\n  await preflightChecks({parser, args, driverConfig, pluginConfig, throwInsteadOfExit});\n  const pluginClasses = getActivePlugins(args, pluginConfig);\n  // set the active plugins on the umbrella driver so it can use them for commands\n  appiumDriver.pluginClasses = pluginClasses;\n  await logStartupInfo(parser, args);\n  let routeConfiguringFunction = makeRouter(appiumDriver);\n\n  const driverClasses = getActiveDrivers(args, driverConfig);\n  const serverUpdaters = getServerUpdaters(driverClasses, pluginClasses);\n  const extraMethodMap = getExtraMethodMap(driverClasses, pluginClasses);\n\n  const serverOpts = {\n    routeConfiguringFunction,\n    port: args.port,\n    hostname: args.address,\n    allowCors: args.allowCors,\n    basePath: args.basePath,\n    serverUpdaters,\n    extraMethodMap,\n  };\n  if (args.keepAliveTimeout) {\n    serverOpts.keepAliveTimeout = args.keepAliveTimeout * 1000;\n  }\n  let server;\n  try {\n    server = await baseServer(serverOpts);\n  } catch (err) {\n    logger.error(`Could not configure Appium server. It's possible that a driver or plugin tried ` +\n                 `to update the server and failed. Original error: ${err.message}`);\n    logger.debug(err.stack);\n    return process.exit(1);\n  }\n\n  if (args.allowCors) {\n    logger.warn('You have enabled CORS requests from any host. Be careful not ' +\n                'to visit sites which could maliciously try to start Appium ' +\n                'sessions on your machine');\n  }\n  appiumDriver.server = server;\n  try {\n    // configure as node on grid, if necessary\n    if (args.nodeconfig !== null) {\n      await registerNode(args.nodeconfig, args.address, args.port, args.basePath);\n    }\n  } catch (err) {\n    await server.close();\n    throw err;\n  }\n\n  for (const signal of ['SIGINT', 'SIGTERM']) {\n    process.once(signal, async function onSignal () {\n      logger.info(`Received ${signal} - shutting down`);\n      try {\n        await appiumDriver.deleteAllSessions({\n          force: true,\n          reason: `The process has received ${signal} signal`,\n        });\n        await server.close();\n        process.exit(0);\n      } catch (e) {\n        logger.warn(e);\n        process.exit(1);\n      }\n    });\n  }\n\n  logServerPort(args.address, args.port);\n  driverConfig.print();\n  pluginConfig.print(pluginClasses.map((p) => p.pluginName));\n\n  return server;\n}\n\nif (require.main === module) {\n  asyncify(main);\n}\n\nexport { main };\n"],"file":"lib/main.js","sourceRoot":"../.."}
|
|
362
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/main.js"],"names":["preflightChecks","args","throwInsteadOfExit","longStacktrace","require","async_trace_limit","showConfig","process","exit","tmpDir","err","logger","error","message","red","logNonDefaultArgsWarning","info","logDefaultCapabilitiesWarning","caps","logStartupInfo","parser","welcome","APPIUM_VER","appiumRev","showArgs","_","size","isEmpty","defaultCapabilities","logServerPort","address","port","logMessage","getActivePlugins","pluginConfig","compact","Object","keys","installedExtensions","filter","pluginName","includes","usePlugins","length","USE_ALL_PLUGINS","map","PluginClass","debug","stack","getActiveDrivers","driverConfig","driverName","useDrivers","getServerUpdaters","driverClasses","pluginClasses","klass","updateServer","Boolean","getExtraMethodMap","reduce","newMethodMap","init","parsedArgs","subcommand","SERVER_SUBCOMMAND","parseArgs","configResult","configFile","errors","Error","filepath","reason","defaultsDeep","config","server","DRIVER_TYPE","PLUGIN_TYPE","logFilters","issues","rules","logFactory","loadSecureValuesPreprocessingRules","JSON","stringify","warn","util","pluralize","appiumDriver","AppiumDriver","main","routeConfiguringFunction","serverUpdaters","extraMethodMap","serverOpts","hostname","allowCors","basePath","keepAliveTimeout","nodeconfig","close","signal","once","onSignal","deleteAllSessions","force","e","print","p","module"],"mappings":"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","sourcesContent":["#!/usr/bin/env node\n\n// transpile:main\n// @ts-check\n\n// @ts-ignore\nimport { routeConfiguringFunction as makeRouter, server as baseServer } from '@appium/base-driver';\nimport { logger as logFactory, util } from '@appium/support';\nimport { asyncify } from 'asyncbox';\nimport _ from 'lodash';\nimport { AppiumDriver } from './appium';\nimport { driverConfig, pluginConfig, USE_ALL_PLUGINS } from './cli/args';\nimport { runExtensionCommand } from './cli/extension';\nimport { default as getParser, SERVER_SUBCOMMAND } from './cli/parser';\nimport { APPIUM_VER, checkNodeOk, getGitRev, getNonDefaultServerArgs, showConfig, validateTmpDir, warnNodeDeprecations } from './config';\nimport { readConfigFile } from './config-file';\nimport { DRIVER_TYPE, PLUGIN_TYPE } from './extension-config';\nimport registerNode from './grid-register';\nimport logger from './logger'; // logger needs to remain first of imports\nimport { init as logsinkInit } from './logsink';\nimport { getDefaultsFromSchema, validate } from './schema/schema';\nimport { inspectObject } from './utils';\n\n/**\n *\n * @param {ParsedArgs} args\n * @param {boolean} [throwInsteadOfExit]\n */\nasync function preflightChecks (args, throwInsteadOfExit = false) {\n  try {\n    checkNodeOk();\n    if (args.longStacktrace) {\n      require('longjohn').async_trace_limit = -1;\n    }\n    if (args.showConfig) {\n      await showConfig();\n      process.exit(0);\n    }\n    warnNodeDeprecations();\n\n    validate(args);\n\n    if (args.tmpDir) {\n      await validateTmpDir(args.tmpDir);\n    }\n  } catch (err) {\n    logger.error(err.message.red);\n    if (throwInsteadOfExit) {\n      throw err;\n    }\n\n    process.exit(1);\n  }\n}\n\nfunction logNonDefaultArgsWarning (args) {\n  logger.info('Non-default server args:');\n  inspectObject(args);\n}\n\nfunction logDefaultCapabilitiesWarning (caps) {\n  logger.info('Default capabilities, which will be added to each request ' +\n              'unless overridden by desired capabilities:');\n  inspectObject(caps);\n}\n\nasync function logStartupInfo (parser, args) {\n  let welcome = `Welcome to Appium v${APPIUM_VER}`;\n  let appiumRev = await getGitRev();\n  if (appiumRev) {\n    welcome += ` (REV ${appiumRev})`;\n  }\n  logger.info(welcome);\n\n  let showArgs = getNonDefaultServerArgs(parser, args);\n  if (_.size(showArgs)) {\n    logNonDefaultArgsWarning(showArgs);\n  }\n  if (!_.isEmpty(args.defaultCapabilities)) {\n    logDefaultCapabilitiesWarning(args.defaultCapabilities);\n  }\n  // TODO: bring back loglevel reporting below once logger is flushed out\n  // logger.info('Console LogLevel: ' + logger.transports.console.level);\n  // if (logger.transports.file) {\n  //   logger.info('File LogLevel: ' + logger.transports.file.level);\n  // }\n}\n\nfunction logServerPort (address, port) {\n  let logMessage = `Appium REST http interface listener started on ` +\n                   `${address}:${port}`;\n  logger.info(logMessage);\n}\n\n/**\n * Find any plugin name which has been installed, and which has been requested for activation by\n * using the --plugins flag, and turn each one into its class, so we can send them as objects to\n * the server init. We also want to send/assign them to the umbrella driver so it can use them to\n * wrap command execution\n *\n * @param {Object} args - argparser parsed dict\n * @param {import('./plugin-config').default} pluginConfig - a plugin extension config\n * @returns {({pluginName: string} & ((...args: any[]) => unknown))[]}\n */\nfunction getActivePlugins (args, pluginConfig) {\n  return _.compact(Object.keys(pluginConfig.installedExtensions).filter((pluginName) =>\n    _.includes(args.usePlugins, pluginName) ||\n    (args.usePlugins.length === 1 && args.usePlugins[0] === USE_ALL_PLUGINS)\n  ).map((pluginName) => {\n    try {\n      logger.info(`Attempting to load plugin ${pluginName}...`);\n      const PluginClass = /** @type {{pluginName: string} & ((...args: any[]) => unknown)} */(pluginConfig.require(pluginName));\n\n      PluginClass.pluginName = pluginName; // store the plugin name on the class so it can be used later\n      return PluginClass;\n    } catch (err) {\n      logger.error(`Could not load plugin '${pluginName}', so it will not be available. Error ` +\n                   `in loading the plugin was: ${err.message}`);\n      logger.debug(err.stack);\n    }\n  }));\n}\n\n/**\n * Find any driver name which has been installed, and turn each one into its class, so we can send\n * them as objects to the server init in case they need to add methods/routes or update the server.\n * If the --drivers flag was given, this method only loads the given drivers.\n *\n * @param {Object} args - argparser parsed dict\n * @param {import('./driver-config').default} driverConfig - a driver extension config\n */\nfunction getActiveDrivers (args, driverConfig) {\n  return _.compact(Object.keys(driverConfig.installedExtensions).filter((driverName) =>\n    _.includes(args.useDrivers, driverName) || args.useDrivers.length === 0\n  ).map((driverName) => {\n    try {\n      logger.info(`Attempting to load driver ${driverName}...`);\n      return driverConfig.require(driverName);\n    } catch (err) {\n      logger.error(`Could not load driver '${driverName}', so it will not be available. Error ` +\n                   `in loading the driver was: ${err.message}`);\n      logger.debug(err.stack);\n    }\n  }));\n}\n\nfunction getServerUpdaters (driverClasses, pluginClasses) {\n  return [...driverClasses, ...pluginClasses].map((klass) => klass.updateServer).filter(Boolean);\n}\n\nfunction getExtraMethodMap (driverClasses, pluginClasses) {\n  return [...driverClasses, ...pluginClasses].reduce(\n    (map, klass) => ({...map, ...klass.newMethodMap}),\n    {}\n  );\n}\n\n/**\n * Initializes Appium, but does not start the server.\n *\n * Use this to get at the configuration schema.\n *\n * @example\n * import {init, getSchema} from 'appium';\n * const options = {}; // config object\n * await init(options);\n * const schema = getSchema(); // entire config schema including plugins and drivers\n * @param {ParsedArgs} [args] - Parsed args\n * @returns {Promise<{parser: import('./cli/parser').ArgParser} & Partial<{appiumDriver: AppiumDriver, parsedArgs: ParsedArgs}>>}\n */\nasync function init (args) {\n  const parser = await getParser();\n  let throwInsteadOfExit = false;\n  /** @type {ParsedArgs} */\n  let parsedArgs;\n  if (args) {\n    // if we have a containing package instead of running as a CLI process,\n    // that package might not appreciate us calling 'process.exit' willy-\n    // nilly, so give it the option to have us throw instead of exit\n    if (args.throwInsteadOfExit) {\n      throwInsteadOfExit = true;\n      // but remove it since it's not a real server arg per se\n      delete args.throwInsteadOfExit;\n    }\n    parsedArgs = {...args, subcommand: args.subcommand ?? SERVER_SUBCOMMAND};\n  } else {\n    // otherwise parse from CLI\n    parsedArgs = parser.parseArgs();\n  }\n\n  const configResult = await readConfigFile(parsedArgs.configFile);\n\n  if (!_.isEmpty(configResult.errors)) {\n    throw new Error(`Errors in config file ${configResult.filepath}:\\n ${configResult.reason ?? configResult.errors}`);\n  }\n\n  // merge config and apply defaults.\n  // the order of precendece is:\n  // 1. command line args\n  // 2. config file\n  // 3. defaults from config file.\n  if (parsedArgs.subcommand === SERVER_SUBCOMMAND) {\n    parsedArgs = _.defaultsDeep(\n      parsedArgs,\n      configResult.config?.server,\n      getDefaultsFromSchema()\n    );\n  }\n\n  parsedArgs = _.defaultsDeep(\n    parsedArgs,\n    configResult.config ?? {},\n  );\n\n  await logsinkInit(parsedArgs);\n\n  // if the user has requested the 'driver' CLI, don't run the normal server,\n  // but instead pass control to the driver CLI\n  if (parsedArgs.subcommand === DRIVER_TYPE) {\n    await runExtensionCommand(parsedArgs, parsedArgs.subcommand, driverConfig);\n    return {parser};\n  }\n  if (parsedArgs.subcommand === PLUGIN_TYPE) {\n    await runExtensionCommand(parsedArgs, parsedArgs.subcommand, pluginConfig);\n    return {parser};\n  }\n\n  if (parsedArgs.logFilters) {\n    const {issues, rules} = await logFactory.loadSecureValuesPreprocessingRules(parsedArgs.logFilters);\n    if (!_.isEmpty(issues)) {\n      throw new Error(`The log filtering rules config '${parsedArgs.logFilters}' has issues: ` +\n        JSON.stringify(issues, null, 2));\n    }\n    if (_.isEmpty(rules)) {\n      logger.warn(`Found no log filtering rules in '${parsedArgs.logFilters}'. Is that expected?`);\n    } else {\n      logger.info(`Loaded ${util.pluralize('filtering rule', rules.length, true)} from '${parsedArgs.logFilters}'`);\n    }\n  }\n\n  const appiumDriver = new AppiumDriver(parsedArgs);\n  // set the config on the umbrella driver so it can match drivers to caps\n  appiumDriver.driverConfig = driverConfig;\n  await preflightChecks(parsedArgs, throwInsteadOfExit);\n\n  return {parser, appiumDriver, parsedArgs};\n}\n\n/**\n *\n * @param {ParsedArgs} [args]\n * @returns\n */\nasync function main (args) {\n  const {parser, appiumDriver, parsedArgs} = await init(args);\n\n  if (!appiumDriver || !parsedArgs) {\n    // if this branch is taken, we've run a different subcommand, so there's nothing\n    // left to do here.\n    return;\n  }\n\n  const pluginClasses = getActivePlugins(parsedArgs, pluginConfig);\n  // set the active plugins on the umbrella driver so it can use them for commands\n  appiumDriver.pluginClasses = pluginClasses;\n\n  await logStartupInfo(parser, parsedArgs);\n  let routeConfiguringFunction = makeRouter(appiumDriver);\n\n  const driverClasses = getActiveDrivers(parsedArgs, driverConfig);\n  const serverUpdaters = getServerUpdaters(driverClasses, pluginClasses);\n  const extraMethodMap = getExtraMethodMap(driverClasses, pluginClasses);\n\n  const serverOpts = {\n    routeConfiguringFunction,\n    port: parsedArgs.port,\n    hostname: parsedArgs.address,\n    allowCors: parsedArgs.allowCors,\n    basePath: parsedArgs.basePath,\n    serverUpdaters,\n    extraMethodMap,\n  };\n  if (parsedArgs.keepAliveTimeout) {\n    serverOpts.keepAliveTimeout = parsedArgs.keepAliveTimeout * 1000;\n  }\n  let server;\n  try {\n    server = await baseServer(serverOpts);\n  } catch (err) {\n    logger.error(`Could not configure Appium server. It's possible that a driver or plugin tried ` +\n                 `to update the server and failed. Original error: ${err.message}`);\n    logger.debug(err.stack);\n    return process.exit(1);\n  }\n\n  if (parsedArgs.allowCors) {\n    logger.warn('You have enabled CORS requests from any host. Be careful not ' +\n                'to visit sites which could maliciously try to start Appium ' +\n                'sessions on your machine');\n  }\n  // @ts-ignore\n  appiumDriver.server = server;\n  try {\n    // configure as node on grid, if necessary\n    // falsy values should not cause this to run\n    if (parsedArgs.nodeconfig) {\n      await registerNode(parsedArgs.nodeconfig, parsedArgs.address, parsedArgs.port, parsedArgs.basePath);\n    }\n  } catch (err) {\n    await server.close();\n    throw err;\n  }\n\n  for (const signal of ['SIGINT', 'SIGTERM']) {\n    process.once(signal, async function onSignal () {\n      logger.info(`Received ${signal} - shutting down`);\n      try {\n        await appiumDriver.deleteAllSessions({\n          force: true,\n          reason: `The process has received ${signal} signal`,\n        });\n        await server.close();\n        process.exit(0);\n      } catch (e) {\n        logger.warn(e);\n        process.exit(1);\n      }\n    });\n  }\n\n  logServerPort(parsedArgs.address, parsedArgs.port);\n  driverConfig.print();\n  pluginConfig.print(pluginClasses.map((p) => p.pluginName));\n\n  return server;\n}\n\nif (require.main === module) {\n  asyncify(main);\n}\n\n// everything below here is intended to be a public API.\nexport { main, init };\nexport { APPIUM_HOME } from './extension-config';\nexport { getSchema, validate, finalizeSchema } from './schema/schema';\nexport { readConfigFile } from './config-file';\n\n/**\n * @typedef {import('../types/types').ParsedArgs} ParsedArgs\n */\n"],"file":"lib/main.js","sourceRoot":"../.."}
|
|
@@ -7,21 +7,29 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
7
7
|
});
|
|
8
8
|
exports.default = void 0;
|
|
9
9
|
|
|
10
|
+
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
11
|
+
|
|
10
12
|
require("source-map-support/register");
|
|
11
13
|
|
|
12
14
|
var _lodash = _interopRequireDefault(require("lodash"));
|
|
13
15
|
|
|
14
|
-
var _extensionConfig =
|
|
16
|
+
var _extensionConfig = _interopRequireDefault(require("./extension-config"));
|
|
17
|
+
|
|
18
|
+
var _extConfigIo = require("./ext-config-io");
|
|
15
19
|
|
|
16
20
|
var _logger = _interopRequireDefault(require("./logger"));
|
|
17
21
|
|
|
18
|
-
|
|
22
|
+
class PluginConfig extends _extensionConfig.default {
|
|
23
|
+
constructor(appiumHome, logFn) {
|
|
24
|
+
super(appiumHome, _extConfigIo.PLUGIN_TYPE, logFn);
|
|
25
|
+
}
|
|
19
26
|
|
|
20
|
-
|
|
27
|
+
static getInstance(appiumHome, logFn) {
|
|
28
|
+
var _PluginConfig$_instan;
|
|
21
29
|
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
30
|
+
const instance = (_PluginConfig$_instan = PluginConfig._instances[appiumHome]) !== null && _PluginConfig$_instan !== void 0 ? _PluginConfig$_instan : new PluginConfig(appiumHome, logFn);
|
|
31
|
+
PluginConfig._instances[appiumHome] = instance;
|
|
32
|
+
return instance;
|
|
25
33
|
}
|
|
26
34
|
|
|
27
35
|
extensionDesc(pluginName, {
|
|
@@ -54,7 +62,8 @@ class PluginConfig extends _extensionConfig.default {
|
|
|
54
62
|
|
|
55
63
|
}
|
|
56
64
|
|
|
57
|
-
exports.default = PluginConfig;
|
|
65
|
+
exports.default = PluginConfig;
|
|
66
|
+
(0, _defineProperty2.default)(PluginConfig, "_instances", {});require('source-map-support').install();
|
|
58
67
|
|
|
59
68
|
|
|
60
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,
|
|
69
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImxpYi9wbHVnaW4tY29uZmlnLmpzIl0sIm5hbWVzIjpbIlBsdWdpbkNvbmZpZyIsIkV4dGVuc2lvbkNvbmZpZyIsImNvbnN0cnVjdG9yIiwiYXBwaXVtSG9tZSIsImxvZ0ZuIiwiUExVR0lOX1RZUEUiLCJnZXRJbnN0YW5jZSIsImluc3RhbmNlIiwiX2luc3RhbmNlcyIsImV4dGVuc2lvbkRlc2MiLCJwbHVnaW5OYW1lIiwidmVyc2lvbiIsInByaW50IiwiYWN0aXZlTmFtZXMiLCJwbHVnaW5OYW1lcyIsIk9iamVjdCIsImtleXMiLCJpbnN0YWxsZWRFeHRlbnNpb25zIiwiXyIsImlzRW1wdHkiLCJsb2ciLCJpbmZvIiwicGx1Z2luRGF0YSIsInRvUGFpcnMiLCJhY3RpdmVUeHQiLCJpbmNsdWRlcyJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7OztBQUFBOztBQUNBOztBQUNBOztBQUNBOztBQUVlLE1BQU1BLFlBQU4sU0FBMkJDLHdCQUEzQixDQUEyQztBQWtCeERDLEVBQUFBLFdBQVcsQ0FBRUMsVUFBRixFQUFjQyxLQUFkLEVBQXFCO0FBQzlCLFVBQU1ELFVBQU4sRUFBa0JFLHdCQUFsQixFQUErQkQsS0FBL0I7QUFDRDs7QUFRaUIsU0FBWEUsV0FBVyxDQUFFSCxVQUFGLEVBQWNDLEtBQWQsRUFBcUI7QUFBQTs7QUFDckMsVUFBTUcsUUFBUSw0QkFBR1AsWUFBWSxDQUFDUSxVQUFiLENBQXdCTCxVQUF4QixDQUFILHlFQUEwQyxJQUFJSCxZQUFKLENBQWlCRyxVQUFqQixFQUE2QkMsS0FBN0IsQ0FBeEQ7QUFDQUosSUFBQUEsWUFBWSxDQUFDUSxVQUFiLENBQXdCTCxVQUF4QixJQUFzQ0ksUUFBdEM7QUFDQSxXQUFPQSxRQUFQO0FBQ0Q7O0FBRURFLEVBQUFBLGFBQWEsQ0FBRUMsVUFBRixFQUFjO0FBQUNDLElBQUFBO0FBQUQsR0FBZCxFQUF5QjtBQUNwQyxXQUFRLEdBQUVELFVBQVcsSUFBR0MsT0FBUSxFQUFoQztBQUNEOztBQUVEQyxFQUFBQSxLQUFLLENBQUVDLFdBQUYsRUFBZTtBQUNsQixVQUFNQyxXQUFXLEdBQUdDLE1BQU0sQ0FBQ0MsSUFBUCxDQUFZLEtBQUtDLG1CQUFqQixDQUFwQjs7QUFFQSxRQUFJQyxnQkFBRUMsT0FBRixDQUFVTCxXQUFWLENBQUosRUFBNEI7QUFDMUJNLHNCQUFJQyxJQUFKLENBQVUsMERBQUQsR0FDQSxnREFEVDs7QUFFQTtBQUNEOztBQUVERCxvQkFBSUMsSUFBSixDQUFVLG9CQUFWOztBQUNBLFNBQUssTUFBTSxDQUFDWCxVQUFELEVBQWFZLFVBQWIsQ0FBWCxJQUF1Q0osZ0JBQUVLLE9BQUYsQ0FBVSxLQUFLTixtQkFBZixDQUF2QyxFQUE0RTtBQUMxRSxZQUFNTyxTQUFTLEdBQUdOLGdCQUFFTyxRQUFGLENBQVdaLFdBQVgsRUFBd0JILFVBQXhCLElBQXNDLFdBQXRDLEdBQW9ELEVBQXRFOztBQUNBVSxzQkFBSUMsSUFBSixDQUFVLE9BQU0sS0FBS1osYUFBTCxDQUFtQkMsVUFBbkIsRUFBK0JZLFVBQS9CLENBQTJDLEdBQUVFLFNBQVUsRUFBdkU7QUFDRDs7QUFFRCxRQUFJTixnQkFBRUMsT0FBRixDQUFVTixXQUFWLENBQUosRUFBNEI7QUFDMUJPLHNCQUFJQyxJQUFKLENBQVMsZ0ZBQVQ7QUFDRDtBQUNGOztBQXhEdUQ7Ozs4QkFBckNyQixZLGdCQVFDLEUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgXyBmcm9tICdsb2Rhc2gnO1xuaW1wb3J0IEV4dGVuc2lvbkNvbmZpZyBmcm9tICcuL2V4dGVuc2lvbi1jb25maWcnO1xuaW1wb3J0IHsgUExVR0lOX1RZUEUgfSBmcm9tICcuL2V4dC1jb25maWctaW8nO1xuaW1wb3J0IGxvZyBmcm9tICcuL2xvZ2dlcic7XG5cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIFBsdWdpbkNvbmZpZyBleHRlbmRzIEV4dGVuc2lvbkNvbmZpZyB7XG5cbiAgLyoqXG4gICAqIEEgbWFwcGluZyBvZiBgQVBQSVVNX0hPTUVgIHZhbHVlcyB0byB7QGxpbmsgUGx1Z2luQ29uZmlnfSBpbnN0YW5jZXMuXG4gICAqIEVhY2ggYEFQUElVTV9IT01FYCBzaG91bGQgb25seSBoYXZlIG9uZSBhc3NvY2lhdGVkIGBQbHVnaW5Db25maWdgIGluc3RhbmNlLlxuICAgKiBAdHlwZSB7UmVjb3JkPHN0cmluZyxQbHVnaW5Db25maWc+fVxuICAgKiBAcHJpdmF0ZVxuICAgKi9cbiAgc3RhdGljIF9pbnN0YW5jZXMgPSB7fTtcblxuICAvKipcbiAgICogQ2FsbCB7QGxpbmsgUGx1Z2luQ29uZmlnLmdldEluc3RhbmNlfSBpbnN0ZWFkLlxuICAgKlxuICAgKiBKdXN0IGNhbGxzIHRoZSBzdXBlcmNsYXNzJyBjb25zdHJ1Y3RvciB3aXRoIHRoZSBjb3JyZWN0IGV4dGVuc2lvbiB0eXBlXG4gICAqIEBwcml2YXRlXG4gICAqIEBwYXJhbSB7c3RyaW5nfSBhcHBpdW1Ib21lIC0gYEFQUElVTV9IT01FYCBwYXRoXG4gICAqIEBwYXJhbSB7KC4uLmFyZ3M6IGFueVtdKSA9PiB2b2lkKX0gW2xvZ0ZuXSAtIE9wdGlvbmFsIGxvZ2dpbmcgZnVuY3Rpb25cbiAgICovXG4gIGNvbnN0cnVjdG9yIChhcHBpdW1Ib21lLCBsb2dGbikge1xuICAgIHN1cGVyKGFwcGl1bUhvbWUsIFBMVUdJTl9UWVBFLCBsb2dGbik7XG4gIH1cblxuICAvKipcbiAgICogQ3JlYXRlcyBvciBnZXRzIGFuIGluc3RhbmNlIG9mIHtAbGluayBQbHVnaW5Db25maWd9IGJhc2VkIHZhbHVlIG9mIGBhcHBpdW1Ib21lYFxuICAgKiBAcGFyYW0ge3N0cmluZ30gYXBwaXVtSG9tZSAtIGBBUFBJVU1fSE9NRWAgcGF0aFxuICAgKiBAcGFyYW0geyguLi5hcmdzOiBhbnlbXSkgPT4gdm9pZH0gW2xvZ0ZuXSAtIE9wdGlvbmFsIGxvZ2dpbmcgZnVuY3Rpb25cbiAgICogQHJldHVybnMge1BsdWdpbkNvbmZpZ31cbiAgICovXG4gIHN0YXRpYyBnZXRJbnN0YW5jZSAoYXBwaXVtSG9tZSwgbG9nRm4pIHtcbiAgICBjb25zdCBpbnN0YW5jZSA9IFBsdWdpbkNvbmZpZy5faW5zdGFuY2VzW2FwcGl1bUhvbWVdID8/IG5ldyBQbHVnaW5Db25maWcoYXBwaXVtSG9tZSwgbG9nRm4pO1xuICAgIFBsdWdpbkNvbmZpZy5faW5zdGFuY2VzW2FwcGl1bUhvbWVdID0gaW5zdGFuY2U7XG4gICAgcmV0dXJuIGluc3RhbmNlO1xuICB9XG5cbiAgZXh0ZW5zaW9uRGVzYyAocGx1Z2luTmFtZSwge3ZlcnNpb259KSB7XG4gICAgcmV0dXJuIGAke3BsdWdpbk5hbWV9QCR7dmVyc2lvbn1gO1xuICB9XG5cbiAgcHJpbnQgKGFjdGl2ZU5hbWVzKSB7XG4gICAgY29uc3QgcGx1Z2luTmFtZXMgPSBPYmplY3Qua2V5cyh0aGlzLmluc3RhbGxlZEV4dGVuc2lvbnMpO1xuXG4gICAgaWYgKF8uaXNFbXB0eShwbHVnaW5OYW1lcykpIHtcbiAgICAgIGxvZy5pbmZvKGBObyBwbHVnaW5zIGhhdmUgYmVlbiBpbnN0YWxsZWQuIFVzZSB0aGUgXCJhcHBpdW0gcGx1Z2luXCIgYCArXG4gICAgICAgICAgICAgICAnY29tbWFuZCB0byBpbnN0YWxsIHRoZSBvbmUocykgeW91IHdhbnQgdG8gdXNlLicpO1xuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIGxvZy5pbmZvKGBBdmFpbGFibGUgcGx1Z2luczpgKTtcbiAgICBmb3IgKGNvbnN0IFtwbHVnaW5OYW1lLCBwbHVnaW5EYXRhXSBvZiBfLnRvUGFpcnModGhpcy5pbnN0YWxsZWRFeHRlbnNpb25zKSkge1xuICAgICAgY29uc3QgYWN0aXZlVHh0ID0gXy5pbmNsdWRlcyhhY3RpdmVOYW1lcywgcGx1Z2luTmFtZSkgPyAnIChBQ1RJVkUpJyA6ICcnO1xuICAgICAgbG9nLmluZm8oYCAgLSAke3RoaXMuZXh0ZW5zaW9uRGVzYyhwbHVnaW5OYW1lLCBwbHVnaW5EYXRhKX0ke2FjdGl2ZVR4dH1gKTtcbiAgICB9XG5cbiAgICBpZiAoXy5pc0VtcHR5KGFjdGl2ZU5hbWVzKSkge1xuICAgICAgbG9nLmluZm8oJ05vIHBsdWdpbnMgYWN0aXZhdGVkLiBVc2UgdGhlIC0tcGx1Z2lucyBmbGFnIHdpdGggbmFtZXMgb2YgcGx1Z2lucyB0byBhY3RpdmF0ZScpO1xuICAgIH1cbiAgfVxufVxuIl0sImZpbGUiOiJsaWIvcGx1Z2luLWNvbmZpZy5qcyIsInNvdXJjZVJvb3QiOiIuLi8uLiJ9
|