appium 2.0.0-beta.17 → 2.0.0-beta.20
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 +16 -11
- package/types/appium-config.d.ts +197 -0
- package/types/types.d.ts +201 -0
- package/build/lib/cli/parser-helpers.js +0 -106
- package/lib/cli/parser-helpers.js +0 -106
|
@@ -5,32 +5,43 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
|
|
|
5
5
|
Object.defineProperty(exports, "__esModule", {
|
|
6
6
|
value: true
|
|
7
7
|
});
|
|
8
|
-
exports.
|
|
8
|
+
exports.DEFAULT_APPIUM_HOME = exports.APPIUM_HOME = void 0;
|
|
9
|
+
Object.defineProperty(exports, "DRIVER_TYPE", {
|
|
10
|
+
enumerable: true,
|
|
11
|
+
get: function () {
|
|
12
|
+
return _extConfigIo.DRIVER_TYPE;
|
|
13
|
+
}
|
|
14
|
+
});
|
|
15
|
+
exports.INSTALL_TYPE_NPM = exports.INSTALL_TYPE_LOCAL = exports.INSTALL_TYPE_GITHUB = exports.INSTALL_TYPE_GIT = exports.INSTALL_TYPES = void 0;
|
|
16
|
+
Object.defineProperty(exports, "PLUGIN_TYPE", {
|
|
17
|
+
enumerable: true,
|
|
18
|
+
get: function () {
|
|
19
|
+
return _extConfigIo.PLUGIN_TYPE;
|
|
20
|
+
}
|
|
21
|
+
});
|
|
22
|
+
exports.default = void 0;
|
|
9
23
|
|
|
10
24
|
require("source-map-support/register");
|
|
11
25
|
|
|
12
26
|
var _lodash = _interopRequireDefault(require("lodash"));
|
|
13
27
|
|
|
14
|
-
var
|
|
15
|
-
|
|
16
|
-
var _support = require("@appium/support");
|
|
28
|
+
var _os = _interopRequireDefault(require("os"));
|
|
17
29
|
|
|
18
30
|
var _path = _interopRequireDefault(require("path"));
|
|
19
31
|
|
|
20
|
-
var
|
|
32
|
+
var _resolveFrom = _interopRequireDefault(require("resolve-from"));
|
|
21
33
|
|
|
22
|
-
var
|
|
34
|
+
var _extConfigIo = require("./ext-config-io");
|
|
23
35
|
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
exports.PLUGIN_TYPE = PLUGIN_TYPE;
|
|
36
|
+
var _logger = _interopRequireDefault(require("./logger"));
|
|
37
|
+
|
|
38
|
+
var _schema = require("./schema/schema");
|
|
28
39
|
|
|
29
40
|
const DEFAULT_APPIUM_HOME = _path.default.resolve(_os.default.homedir(), '.appium');
|
|
30
41
|
|
|
31
42
|
exports.DEFAULT_APPIUM_HOME = DEFAULT_APPIUM_HOME;
|
|
32
|
-
const
|
|
33
|
-
|
|
43
|
+
const APPIUM_HOME = process.env.APPIUM_HOME || DEFAULT_APPIUM_HOME;
|
|
44
|
+
exports.APPIUM_HOME = APPIUM_HOME;
|
|
34
45
|
const INSTALL_TYPE_NPM = 'npm';
|
|
35
46
|
exports.INSTALL_TYPE_NPM = INSTALL_TYPE_NPM;
|
|
36
47
|
const INSTALL_TYPE_LOCAL = 'local';
|
|
@@ -43,28 +54,21 @@ const INSTALL_TYPES = [INSTALL_TYPE_GIT, INSTALL_TYPE_GITHUB, INSTALL_TYPE_LOCAL
|
|
|
43
54
|
exports.INSTALL_TYPES = INSTALL_TYPES;
|
|
44
55
|
|
|
45
56
|
class ExtensionConfig {
|
|
46
|
-
constructor(appiumHome, extensionType, logFn
|
|
47
|
-
|
|
48
|
-
logFn = _logger.default.error.bind(_logger.default);
|
|
49
|
-
}
|
|
50
|
-
|
|
57
|
+
constructor(appiumHome, extensionType, logFn) {
|
|
58
|
+
const logger = _lodash.default.isFunction(logFn) ? logFn : _logger.default.error.bind(_logger.default);
|
|
51
59
|
this.appiumHome = appiumHome;
|
|
52
|
-
this.configFile = _path.default.resolve(this.appiumHome, CONFIG_FILE_NAME);
|
|
53
60
|
this.installedExtensions = {};
|
|
61
|
+
this.io = (0, _extConfigIo.getExtConfigIOInstance)(appiumHome);
|
|
54
62
|
this.extensionType = extensionType;
|
|
55
63
|
this.configKey = `${extensionType}s`;
|
|
56
|
-
this.
|
|
57
|
-
[`${DRIVER_TYPE}s`]: {},
|
|
58
|
-
[`${PLUGIN_TYPE}s`]: {}
|
|
59
|
-
};
|
|
60
|
-
this.log = logFn;
|
|
64
|
+
this.log = logger;
|
|
61
65
|
}
|
|
62
66
|
|
|
63
67
|
validate(exts) {
|
|
64
68
|
const foundProblems = {};
|
|
65
69
|
|
|
66
70
|
for (const [extName, extData] of _lodash.default.toPairs(exts)) {
|
|
67
|
-
foundProblems[extName] = [...this.getGenericConfigProblems(extData), ...this.getConfigProblems(extData)];
|
|
71
|
+
foundProblems[extName] = [...this.getGenericConfigProblems(extData, extName), ...this.getConfigProblems(extData, extName), ...this.getSchemaProblems(extData, extName)];
|
|
68
72
|
}
|
|
69
73
|
|
|
70
74
|
const problemSummaries = [];
|
|
@@ -83,7 +87,7 @@ class ExtensionConfig {
|
|
|
83
87
|
}
|
|
84
88
|
|
|
85
89
|
if (!_lodash.default.isEmpty(problemSummaries)) {
|
|
86
|
-
this.log(`Appium encountered one or more errors while validating ` + `the ${this.configKey} extension file (${this.
|
|
90
|
+
this.log(`Appium encountered one or more errors while validating ` + `the ${this.configKey} extension file (${this.io.filepath}):`);
|
|
87
91
|
|
|
88
92
|
for (const summary of problemSummaries) {
|
|
89
93
|
this.log(summary);
|
|
@@ -93,7 +97,50 @@ class ExtensionConfig {
|
|
|
93
97
|
return exts;
|
|
94
98
|
}
|
|
95
99
|
|
|
96
|
-
|
|
100
|
+
getSchemaProblems(extData, extName) {
|
|
101
|
+
const problems = [];
|
|
102
|
+
const {
|
|
103
|
+
schema: argSchemaPath
|
|
104
|
+
} = extData;
|
|
105
|
+
|
|
106
|
+
if (argSchemaPath) {
|
|
107
|
+
if (_lodash.default.isString(argSchemaPath)) {
|
|
108
|
+
if ((0, _schema.isAllowedSchemaFileExtension)(argSchemaPath)) {
|
|
109
|
+
try {
|
|
110
|
+
this.readExtensionSchema(extName, extData);
|
|
111
|
+
} catch (err) {
|
|
112
|
+
problems.push({
|
|
113
|
+
err: `Unable to register schema at path ${argSchemaPath}; ${err.message}`,
|
|
114
|
+
val: argSchemaPath
|
|
115
|
+
});
|
|
116
|
+
}
|
|
117
|
+
} else {
|
|
118
|
+
problems.push({
|
|
119
|
+
err: `Schema file has unsupported extension. Allowed: ${[..._schema.ALLOWED_SCHEMA_EXTENSIONS].join(', ')}`,
|
|
120
|
+
val: argSchemaPath
|
|
121
|
+
});
|
|
122
|
+
}
|
|
123
|
+
} else if (_lodash.default.isPlainObject(argSchemaPath)) {
|
|
124
|
+
try {
|
|
125
|
+
this.readExtensionSchema(extName, extData);
|
|
126
|
+
} catch (err) {
|
|
127
|
+
problems.push({
|
|
128
|
+
err: `Unable to register embedded schema; ${err.message}`,
|
|
129
|
+
val: argSchemaPath
|
|
130
|
+
});
|
|
131
|
+
}
|
|
132
|
+
} else {
|
|
133
|
+
problems.push({
|
|
134
|
+
err: 'Incorrectly formatted schema field; must be a path to a schema file or a schema object.',
|
|
135
|
+
val: argSchemaPath
|
|
136
|
+
});
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
|
|
140
|
+
return problems;
|
|
141
|
+
}
|
|
142
|
+
|
|
143
|
+
getGenericConfigProblems(extData, extName) {
|
|
97
144
|
const {
|
|
98
145
|
version,
|
|
99
146
|
pkgName,
|
|
@@ -101,7 +148,7 @@ class ExtensionConfig {
|
|
|
101
148
|
installType,
|
|
102
149
|
installPath,
|
|
103
150
|
mainClass
|
|
104
|
-
} =
|
|
151
|
+
} = extData;
|
|
105
152
|
const problems = [];
|
|
106
153
|
|
|
107
154
|
if (!_lodash.default.isString(version)) {
|
|
@@ -149,44 +196,18 @@ class ExtensionConfig {
|
|
|
149
196
|
return problems;
|
|
150
197
|
}
|
|
151
198
|
|
|
152
|
-
getConfigProblems() {
|
|
199
|
+
getConfigProblems(extData, extName) {
|
|
153
200
|
return [];
|
|
154
201
|
}
|
|
155
202
|
|
|
156
|
-
applySchemaMigrations() {
|
|
157
|
-
if (this.yamlData.schemaRev < 2 && _lodash.default.isUndefined(this.yamlData[PLUGIN_TYPE])) {
|
|
158
|
-
this.yamlData[PLUGIN_TYPE] = {};
|
|
159
|
-
}
|
|
160
|
-
}
|
|
161
|
-
|
|
162
203
|
async read() {
|
|
163
|
-
await
|
|
164
|
-
|
|
165
|
-
try {
|
|
166
|
-
this.yamlData = _yaml.default.parse(await _support.fs.readFile(this.configFile, 'utf8'));
|
|
167
|
-
this.applySchemaMigrations();
|
|
168
|
-
this.installedExtensions = this.validate(this.yamlData[this.configKey]);
|
|
169
|
-
} catch (err) {
|
|
170
|
-
if (await _support.fs.exists(this.configFile)) {
|
|
171
|
-
throw new Error(`Appium had trouble loading the extension installation ` + `cache file (${this.configFile}). Ensure it exists and is ` + `readable. Specific error: ${err.message}`);
|
|
172
|
-
}
|
|
173
|
-
|
|
174
|
-
try {
|
|
175
|
-
await this.write();
|
|
176
|
-
} catch {
|
|
177
|
-
throw new Error(`Appium could not read or write from the Appium Home directory ` + `(${this.appiumHome}). Please ensure it is writable.`);
|
|
178
|
-
}
|
|
179
|
-
}
|
|
180
|
-
|
|
204
|
+
const extensions = await this.io.read(this.extensionType);
|
|
205
|
+
this.installedExtensions = this.validate(extensions);
|
|
181
206
|
return this.installedExtensions;
|
|
182
207
|
}
|
|
183
208
|
|
|
184
209
|
async write() {
|
|
185
|
-
|
|
186
|
-
schemaRev: CONFIG_SCHEMA_REV,
|
|
187
|
-
[this.configKey]: this.installedExtensions
|
|
188
|
-
};
|
|
189
|
-
await _support.fs.writeFile(this.configFile, _yaml.default.stringify(newYamlData), 'utf8');
|
|
210
|
+
return await this.io.write();
|
|
190
211
|
}
|
|
191
212
|
|
|
192
213
|
async addExtension(extName, extData) {
|
|
@@ -222,8 +243,8 @@ class ExtensionConfig {
|
|
|
222
243
|
}
|
|
223
244
|
}
|
|
224
245
|
|
|
225
|
-
extensionDesc() {
|
|
226
|
-
throw new Error('This must be implemented in a
|
|
246
|
+
extensionDesc(extName, extData) {
|
|
247
|
+
throw new Error('This must be implemented in a subclass');
|
|
227
248
|
}
|
|
228
249
|
|
|
229
250
|
getExtensionRequirePath(extName) {
|
|
@@ -262,9 +283,38 @@ class ExtensionConfig {
|
|
|
262
283
|
return _lodash.default.includes(Object.keys(this.installedExtensions), extName);
|
|
263
284
|
}
|
|
264
285
|
|
|
286
|
+
static _readExtensionSchema(appiumHome, extType, extName, extData) {
|
|
287
|
+
const {
|
|
288
|
+
installPath,
|
|
289
|
+
pkgName,
|
|
290
|
+
schema: argSchemaPath
|
|
291
|
+
} = extData;
|
|
292
|
+
|
|
293
|
+
if (!argSchemaPath) {
|
|
294
|
+
throw new TypeError(`No \`schema\` property found in config for ${extType} ${pkgName} -- why is this function being called?`);
|
|
295
|
+
}
|
|
296
|
+
|
|
297
|
+
let moduleObject;
|
|
298
|
+
|
|
299
|
+
if (_lodash.default.isString(argSchemaPath)) {
|
|
300
|
+
const schemaPath = (0, _resolveFrom.default)(_path.default.resolve(appiumHome, installPath), _path.default.normalize(`${pkgName}/${argSchemaPath}`));
|
|
301
|
+
moduleObject = require(schemaPath);
|
|
302
|
+
} else {
|
|
303
|
+
moduleObject = argSchemaPath;
|
|
304
|
+
}
|
|
305
|
+
|
|
306
|
+
const schema = moduleObject.__esModule ? moduleObject.default : moduleObject;
|
|
307
|
+
(0, _schema.registerSchema)(extType, extName, schema);
|
|
308
|
+
return schema;
|
|
309
|
+
}
|
|
310
|
+
|
|
311
|
+
readExtensionSchema(extName, extData) {
|
|
312
|
+
return ExtensionConfig._readExtensionSchema(this.appiumHome, this.extensionType, extName, extData);
|
|
313
|
+
}
|
|
314
|
+
|
|
265
315
|
}
|
|
266
316
|
|
|
267
317
|
exports.default = ExtensionConfig;require('source-map-support').install();
|
|
268
318
|
|
|
269
319
|
|
|
270
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/extension-config.js"],"names":["DRIVER_TYPE","PLUGIN_TYPE","DEFAULT_APPIUM_HOME","path","resolve","os","homedir","CONFIG_FILE_NAME","CONFIG_SCHEMA_REV","INSTALL_TYPE_NPM","INSTALL_TYPE_LOCAL","INSTALL_TYPE_GITHUB","INSTALL_TYPE_GIT","INSTALL_TYPES","ExtensionConfig","constructor","appiumHome","extensionType","logFn","log","error","bind","configFile","installedExtensions","configKey","yamlData","validate","exts","foundProblems","extName","extData","_","toPairs","getGenericConfigProblems","getConfigProblems","problemSummaries","problems","isEmpty","push","problem","err","JSON","stringify","val","summary","ext","version","pkgName","installSpec","installType","installPath","mainClass","isString","includes","applySchemaMigrations","schemaRev","isUndefined","read","YAML","parse","fs","readFile","exists","Error","message","write","newYamlData","writeFile","addExtension","updateExtension","removeExtension","print","extNames","Object","keys","info","extensionDesc","getExtensionRequirePath","getInstallPath","require","reqPath","reqResolved","process","env","APPIUM_RELOAD_EXTENSIONS","cache","debug","isInstalled"],"mappings":"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","sourcesContent":["import _ from 'lodash';\nimport log from './logger';\nimport { fs, mkdirp } from '@appium/support';\nimport path from 'path';\nimport os from 'os';\nimport YAML from 'yaml';\n\nconst DRIVER_TYPE = 'driver';\nconst PLUGIN_TYPE = 'plugin';\nconst DEFAULT_APPIUM_HOME = path.resolve(os.homedir(), '.appium');\n\nconst CONFIG_FILE_NAME = 'extensions.yaml';\nconst CONFIG_SCHEMA_REV = 2;\n\nconst INSTALL_TYPE_NPM = 'npm';\nconst INSTALL_TYPE_LOCAL = 'local';\nconst INSTALL_TYPE_GITHUB = 'github';\nconst INSTALL_TYPE_GIT = 'git';\nconst INSTALL_TYPES = [\n  INSTALL_TYPE_GIT,\n  INSTALL_TYPE_GITHUB,\n  INSTALL_TYPE_LOCAL,\n  INSTALL_TYPE_NPM\n];\n\n\nexport default class ExtensionConfig {\n  constructor (appiumHome, extensionType, logFn = null) {\n    if (logFn === null) {\n      logFn = log.error.bind(log);\n    }\n    this.appiumHome = appiumHome;\n    this.configFile = path.resolve(this.appiumHome, CONFIG_FILE_NAME);\n    this.installedExtensions = {};\n    this.extensionType = extensionType;\n    this.configKey = `${extensionType}s`;\n    this.yamlData = {[`${DRIVER_TYPE}s`]: {}, [`${PLUGIN_TYPE}s`]: {}};\n    this.log = logFn;\n  }\n\n  validate (exts) {\n    const foundProblems = {};\n    for (const [extName, extData] of _.toPairs(exts)) {\n      foundProblems[extName] = [\n        ...this.getGenericConfigProblems(extData),\n        ...this.getConfigProblems(extData)\n      ];\n    }\n\n    const problemSummaries = [];\n    for (const [extName, problems] of _.toPairs(foundProblems)) {\n      if (_.isEmpty(problems)) {\n        continue;\n      }\n      // remove this extension from the list since it's not valid\n      delete exts[extName];\n      problemSummaries.push(`${this.extensionType} ${extName} had errors and will not ` +\n                            `be available. Errors:`);\n      for (const problem of problems) {\n        problemSummaries.push(`  - ${problem.err} (Actual value: ` +\n                              `${JSON.stringify(problem.val)})`);\n      }\n    }\n\n    if (!_.isEmpty(problemSummaries)) {\n      this.log(`Appium encountered one or more errors while validating ` +\n               `the ${this.configKey} extension file (${this.configFile}):`);\n      for (const summary of problemSummaries) {\n        this.log(summary);\n      }\n    }\n\n    return exts;\n  }\n\n  getGenericConfigProblems (ext) {\n    const {version, pkgName, installSpec, installType, installPath, mainClass} = ext;\n    const problems = [];\n\n    if (!_.isString(version)) {\n      problems.push({err: 'Missing or incorrect version', val: version});\n    }\n\n    if (!_.isString(pkgName)) {\n      problems.push({err: 'Missing or incorrect NPM package name', val: pkgName});\n    }\n\n    if (!_.isString(installSpec)) {\n      problems.push({err: 'Missing or incorrect installation spec', val: installSpec});\n    }\n\n    if (!_.includes(INSTALL_TYPES, installType)) {\n      problems.push({err: 'Missing or incorrect install type', val: installType});\n    }\n\n    if (!_.isString(installPath)) {\n      problems.push({err: 'Missing or incorrect installation path', val: installPath});\n    }\n\n    if (!_.isString(mainClass)) {\n      problems.push({err: 'Missing or incorrect driver class name', val: mainClass});\n    }\n\n    return problems;\n  }\n\n  getConfigProblems (/*ext*/) {\n    // shoud override this method if special validation is necessary for this extension type\n    return [];\n  }\n\n  applySchemaMigrations () {\n    if (this.yamlData.schemaRev < 2 && _.isUndefined(this.yamlData[PLUGIN_TYPE])) {\n      // at schema revision 2, we started including plugins as well as drivers in the file,\n      // so make sure we at least have an empty section for it\n      this.yamlData[PLUGIN_TYPE] = {};\n    }\n  }\n\n  async read () {\n    await mkdirp(this.appiumHome); // ensure appium home exists\n    try {\n      this.yamlData = YAML.parse(await fs.readFile(this.configFile, 'utf8'));\n      this.applySchemaMigrations();\n\n      // set the list of drivers the user has installed\n      this.installedExtensions = this.validate(this.yamlData[this.configKey]);\n    } catch (err) {\n      if (await fs.exists(this.configFile)) {\n        // if the file exists and we couldn't parse it, that's a problem\n        throw new Error(`Appium had trouble loading the extension installation ` +\n                        `cache file (${this.configFile}). Ensure it exists and is ` +\n                        `readable. Specific error: ${err.message}`);\n      }\n\n      // if the config file doesn't exist, try to write an empty one, to make\n      // sure we actually have write privileges, and complain if we don't\n      try {\n        await this.write();\n      } catch {\n        throw new Error(`Appium could not read or write from the Appium Home directory ` +\n                        `(${this.appiumHome}). Please ensure it is writable.`);\n      }\n    }\n    return this.installedExtensions;\n  }\n\n\n  async write () {\n    const newYamlData = {\n      ...this.yamlData,\n      schemaRev: CONFIG_SCHEMA_REV,\n      [this.configKey]: this.installedExtensions\n    };\n    await fs.writeFile(this.configFile, YAML.stringify(newYamlData), 'utf8');\n  }\n\n  async addExtension (extName, extData) {\n    this.installedExtensions[extName] = extData;\n    await this.write();\n  }\n\n  async updateExtension (extName, extData) {\n    this.installedExtensions[extName] = {\n      ...this.installedExtensions[extName],\n      ...extData,\n    };\n    await this.write();\n  }\n\n  async removeExtension (extName) {\n    delete this.installedExtensions[extName];\n    await this.write();\n  }\n\n  print () {\n    const extNames = Object.keys(this.installedExtensions);\n    if (_.isEmpty(extNames)) {\n      log.info(`No ${this.configKey} have been installed. Use the \"appium ${this.extensionType}\" ` +\n               'command to install the one(s) you want to use.');\n      return;\n    }\n\n    log.info(`Available ${this.configKey}:`);\n    for (const [extName, extData] of _.toPairs(this.installedExtensions)) {\n      log.info(`  - ${this.extensionDesc(extName, extData)}`);\n    }\n  }\n\n  extensionDesc () {\n    throw new Error('This must be implemented in a final class');\n  }\n\n  getExtensionRequirePath (extName) {\n    const {pkgName, installPath} = this.installedExtensions[extName];\n    return path.resolve(this.appiumHome, installPath, 'node_modules', pkgName);\n  }\n\n  getInstallPath (extName) {\n    const {installPath} = this.installedExtensions[extName];\n    return path.resolve(this.appiumHome, installPath);\n  }\n\n  require (extName) {\n    const {mainClass} = this.installedExtensions[extName];\n    const reqPath = this.getExtensionRequirePath(extName);\n    const reqResolved = require.resolve(reqPath);\n    if (process.env.APPIUM_RELOAD_EXTENSIONS && require.cache[reqResolved]) {\n      log.debug(`Removing ${reqResolved} from require cache`);\n      delete require.cache[reqResolved];\n    }\n    return require(reqPath)[mainClass];\n  }\n\n  isInstalled (extName) {\n    return _.includes(Object.keys(this.installedExtensions), extName);\n  }\n}\n\nexport {\n  INSTALL_TYPE_NPM, INSTALL_TYPE_GIT, INSTALL_TYPE_LOCAL, INSTALL_TYPE_GITHUB,\n  INSTALL_TYPES, DEFAULT_APPIUM_HOME, DRIVER_TYPE, PLUGIN_TYPE,\n};\n"],"file":"lib/extension-config.js","sourceRoot":"../.."}
|
|
320
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/extension-config.js"],"names":["DEFAULT_APPIUM_HOME","path","resolve","os","homedir","APPIUM_HOME","process","env","INSTALL_TYPE_NPM","INSTALL_TYPE_LOCAL","INSTALL_TYPE_GITHUB","INSTALL_TYPE_GIT","INSTALL_TYPES","ExtensionConfig","constructor","appiumHome","extensionType","logFn","logger","_","isFunction","log","error","bind","installedExtensions","io","configKey","validate","exts","foundProblems","extName","extData","toPairs","getGenericConfigProblems","getConfigProblems","getSchemaProblems","problemSummaries","problems","isEmpty","push","problem","err","JSON","stringify","val","filepath","summary","schema","argSchemaPath","isString","readExtensionSchema","message","ALLOWED_SCHEMA_EXTENSIONS","join","isPlainObject","version","pkgName","installSpec","installType","installPath","mainClass","includes","read","extensions","write","addExtension","updateExtension","removeExtension","print","extNames","Object","keys","info","extensionDesc","Error","getExtensionRequirePath","getInstallPath","require","reqPath","reqResolved","APPIUM_RELOAD_EXTENSIONS","cache","debug","isInstalled","_readExtensionSchema","extType","TypeError","moduleObject","schemaPath","normalize","__esModule","default"],"mappings":"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","sourcesContent":["// @ts-check\n\nimport _ from 'lodash';\nimport os from 'os';\nimport path from 'path';\nimport resolveFrom from 'resolve-from';\nimport { getExtConfigIOInstance } from './ext-config-io';\nimport log from './logger';\nimport { ALLOWED_SCHEMA_EXTENSIONS, isAllowedSchemaFileExtension, registerSchema } from './schema/schema';\n\nconst DEFAULT_APPIUM_HOME = path.resolve(os.homedir(), '.appium');\nconst APPIUM_HOME = process.env.APPIUM_HOME || DEFAULT_APPIUM_HOME;\n\nconst INSTALL_TYPE_NPM = 'npm';\nconst INSTALL_TYPE_LOCAL = 'local';\nconst INSTALL_TYPE_GITHUB = 'github';\nconst INSTALL_TYPE_GIT = 'git';\nconst INSTALL_TYPES = [\n  INSTALL_TYPE_GIT,\n  INSTALL_TYPE_GITHUB,\n  INSTALL_TYPE_LOCAL,\n  INSTALL_TYPE_NPM\n];\n\nexport default class ExtensionConfig {\n  /**\n   *\n   * @param {string} appiumHome - `APPIUM_HOME`\n   * @param {ExtensionType} extensionType - Type of extension\n   * @param {(...args: any[]) => void} [logFn]\n   */\n  constructor (appiumHome, extensionType, logFn) {\n    const logger = _.isFunction(logFn) ? logFn : log.error.bind(log);\n    /** @type {string} */\n    this.appiumHome = appiumHome;\n    /** @type {Record<string,object>} */\n    this.installedExtensions = {};\n    /** @type {import('./ext-config-io').ExtensionConfigIO} */\n    this.io = getExtConfigIOInstance(appiumHome);\n    /** @type {ExtensionType} */\n    this.extensionType = extensionType;\n    /** @type {'drivers'|'plugins'} */\n    this.configKey = `${extensionType}s`; // todo use template type\n    /**\n     * @type {(...args: any[])=>void}\n     */\n    this.log = logger;\n  }\n\n  /**\n   * Checks extensions for problems\n   * @template ExtData\n   * @param {ExtData[]} exts - Array of extData objects\n   * @returns {ExtData[]}\n   */\n  validate (exts) {\n    const foundProblems = {};\n    for (const [extName, extData] of _.toPairs(exts)) {\n      foundProblems[extName] = [\n        ...this.getGenericConfigProblems(extData, extName),\n        ...this.getConfigProblems(extData, extName),\n        ...this.getSchemaProblems(extData, extName)\n      ];\n    }\n\n    const problemSummaries = [];\n    for (const [extName, problems] of _.toPairs(foundProblems)) {\n      if (_.isEmpty(problems)) {\n        continue;\n      }\n      // remove this extension from the list since it's not valid\n      delete exts[extName];\n      problemSummaries.push(`${this.extensionType} ${extName} had errors and will not ` +\n                            `be available. Errors:`);\n      for (const problem of problems) {\n        problemSummaries.push(`  - ${problem.err} (Actual value: ` +\n                              `${JSON.stringify(problem.val)})`);\n      }\n    }\n\n    if (!_.isEmpty(problemSummaries)) {\n      this.log(`Appium encountered one or more errors while validating ` +\n               `the ${this.configKey} extension file (${this.io.filepath}):`);\n      for (const summary of problemSummaries) {\n        this.log(summary);\n      }\n    }\n\n    return exts;\n  }\n\n  /**\n   * @param {object} extData\n   * @param {string} extName\n   * @returns {Problem[]}\n   */\n  getSchemaProblems (extData, extName) {\n    const problems = [];\n    const {schema: argSchemaPath} = extData;\n    if (argSchemaPath) {\n      if (_.isString(argSchemaPath)) {\n        if (isAllowedSchemaFileExtension(argSchemaPath)) {\n          try {\n            this.readExtensionSchema(extName, extData);\n          } catch (err) {\n            problems.push({err: `Unable to register schema at path ${argSchemaPath}; ${err.message}`, val: argSchemaPath});\n          }\n        } else {\n          problems.push({\n            err: `Schema file has unsupported extension. Allowed: ${[...ALLOWED_SCHEMA_EXTENSIONS].join(', ')}`,\n            val: argSchemaPath\n          });\n        }\n      } else if (_.isPlainObject(argSchemaPath)) {\n        try {\n          this.readExtensionSchema(extName, extData);\n        } catch (err) {\n          problems.push({err: `Unable to register embedded schema; ${err.message}`, val: argSchemaPath});\n        }\n      } else {\n        problems.push({\n          err: 'Incorrectly formatted schema field; must be a path to a schema file or a schema object.',\n          val: argSchemaPath\n        });\n      }\n    }\n    return problems;\n  }\n\n  /**\n   * @param {object} extData\n   * @param {string} extName\n   * @returns {Problem[]}\n   */\n  // eslint-disable-next-line no-unused-vars\n  getGenericConfigProblems (extData, extName) {\n    const {version, pkgName, installSpec, installType, installPath, mainClass} = extData;\n    const problems = [];\n\n    if (!_.isString(version)) {\n      problems.push({err: 'Missing or incorrect version', val: version});\n    }\n\n    if (!_.isString(pkgName)) {\n      problems.push({err: 'Missing or incorrect NPM package name', val: pkgName});\n    }\n\n    if (!_.isString(installSpec)) {\n      problems.push({err: 'Missing or incorrect installation spec', val: installSpec});\n    }\n\n    if (!_.includes(INSTALL_TYPES, installType)) {\n      problems.push({err: 'Missing or incorrect install type', val: installType});\n    }\n\n    if (!_.isString(installPath)) {\n      problems.push({err: 'Missing or incorrect installation path', val: installPath});\n    }\n\n    if (!_.isString(mainClass)) {\n      problems.push({err: 'Missing or incorrect driver class name', val: mainClass});\n    }\n\n    return problems;\n  }\n\n  /**\n   * @param {object} extData\n   * @param {string} extName\n   * @returns {Problem[]}\n   */\n  // eslint-disable-next-line no-unused-vars\n  getConfigProblems (extData, extName) {\n    // shoud override this method if special validation is necessary for this extension type\n    return [];\n  }\n\n  /**\n   * @returns {Promise<typeof this.installedExtensions>}\n   */\n  async read () {\n    const extensions = await this.io.read(this.extensionType);\n    this.installedExtensions = this.validate(extensions);\n    return this.installedExtensions;\n  }\n\n  /**\n   * @returns {Promise<boolean>}\n   */\n  async write () {\n    return await this.io.write();\n  }\n\n  /**\n   * @param {string} extName\n   * @param {object} extData\n   * @returns {Promise<void>}\n   */\n  async addExtension (extName, extData) {\n    this.installedExtensions[extName] = extData;\n    await this.write();\n  }\n\n  /**\n   * @param {string} extName\n   * @param {object} extData\n   * @returns {Promise<void>}\n   */\n  async updateExtension (extName, extData) {\n    this.installedExtensions[extName] = {\n      ...this.installedExtensions[extName],\n      ...extData,\n    };\n    await this.write();\n  }\n\n  /**\n   * @param {string} extName\n   * @returns {Promise<void>}\n   */\n  async removeExtension (extName) {\n    delete this.installedExtensions[extName];\n    await this.write();\n  }\n\n  print () {\n    const extNames = Object.keys(this.installedExtensions);\n    if (_.isEmpty(extNames)) {\n      log.info(`No ${this.configKey} have been installed. Use the \"appium ${this.extensionType}\" ` +\n               'command to install the one(s) you want to use.');\n      return;\n    }\n\n    log.info(`Available ${this.configKey}:`);\n    for (const [extName, extData] of _.toPairs(this.installedExtensions)) {\n      log.info(`  - ${this.extensionDesc(extName, extData)}`);\n    }\n  }\n\n  /**\n   * Returns a string describing the extension. Subclasses must implement.\n   * @param {string} extName - Extension name\n   * @param {object} extData - Extension data\n   * @returns {string}\n   * @abstract\n   */\n  // eslint-disable-next-line no-unused-vars\n  extensionDesc (extName, extData) {\n    throw new Error('This must be implemented in a subclass');\n  }\n\n  /**\n   * @param {string} extName\n   * @returns {string}\n   */\n  getExtensionRequirePath (extName) {\n    const {pkgName, installPath} = this.installedExtensions[extName];\n    return path.resolve(this.appiumHome, installPath, 'node_modules', pkgName);\n  }\n\n  /**\n   * @param {string} extName\n   * @returns {string}\n   */\n  getInstallPath (extName) {\n    const {installPath} = this.installedExtensions[extName];\n    return path.resolve(this.appiumHome, installPath);\n  }\n\n  /**\n   * Loads extension and returns its main class\n   * @param {string} extName\n   * @returns {(...args: any[]) => object }\n   */\n  require (extName) {\n    const {mainClass} = this.installedExtensions[extName];\n    const reqPath = this.getExtensionRequirePath(extName);\n    const reqResolved = require.resolve(reqPath);\n    if (process.env.APPIUM_RELOAD_EXTENSIONS && require.cache[reqResolved]) {\n      log.debug(`Removing ${reqResolved} from require cache`);\n      delete require.cache[reqResolved];\n    }\n    return require(reqPath)[mainClass];\n  }\n\n  /**\n   * @param {string} extName\n   * @returns {boolean}\n   */\n  isInstalled (extName) {\n    return _.includes(Object.keys(this.installedExtensions), extName);\n  }\n\n  /**\n   * Intended to be called by corresponding instance methods of subclass.\n   * @private\n   * @param {string} appiumHome\n   * @param {ExtensionType} extType\n   * @param {string} extName - Extension name (unique to its type)\n   * @param {ExtData} extData - Extension config\n   * @returns {import('ajv').SchemaObject|undefined}\n   */\n  static _readExtensionSchema (appiumHome, extType, extName, extData) {\n    const {installPath, pkgName, schema: argSchemaPath} = extData;\n    if (!argSchemaPath) {\n      throw new TypeError(\n        `No \\`schema\\` property found in config for ${extType} ${pkgName} -- why is this function being called?`,\n      );\n    }\n    let moduleObject;\n    if (_.isString(argSchemaPath)) {\n      const schemaPath = resolveFrom(\n        path.resolve(appiumHome, installPath),\n        // this path sep is fine because `resolveFrom` uses Node's module resolution\n        path.normalize(`${pkgName}/${argSchemaPath}`),\n      );\n      moduleObject = require(schemaPath);\n    } else {\n      moduleObject = argSchemaPath;\n    }\n    // this sucks. default exports should be destroyed\n    const schema = moduleObject.__esModule\n      ? moduleObject.default\n      : moduleObject;\n    registerSchema(extType, extName, schema);\n    return schema;\n  }\n\n  /**\n   * If an extension provides a schema, this will load the schema and attempt to\n   * register it with the schema registrar.\n   * @param {string} extName - Name of extension\n   * @param {ExtData} extData - Extension data\n   * @returns {import('ajv').SchemaObject|undefined}\n   */\n  readExtensionSchema (extName, extData) {\n    return ExtensionConfig._readExtensionSchema(this.appiumHome, this.extensionType, extName, extData);\n  }\n}\n\nexport { DRIVER_TYPE, PLUGIN_TYPE } from './ext-config-io';\nexport {\n  INSTALL_TYPE_NPM, INSTALL_TYPE_GIT, INSTALL_TYPE_LOCAL, INSTALL_TYPE_GITHUB,\n  INSTALL_TYPES, DEFAULT_APPIUM_HOME, APPIUM_HOME\n};\n\n/**\n * Config problem\n * @typedef {Object} Problem\n * @property {string} err - Error message\n * @property {any} val - Associated value\n */\n\n/**\n * Alias\n * @typedef {import('./ext-config-io').ExtensionType} ExtensionType\n */\n\n/**\n * Extension data (pulled from config YAML)\n * @typedef {Object} ExtData\n * @property {string|import('ajv').SchemaObject} [schema] - Optional schema path if the ext defined it\n * @property {string} pkgName - Package name\n * @property {string} installPath - Actually looks more like a module identifier? Resolved from `APPIUM_HOME`\n */\n\n"],"file":"lib/extension-config.js","sourceRoot":"../.."}
|
|
@@ -22,21 +22,27 @@ const hubUri = config => {
|
|
|
22
22
|
return `${protocol}://${config.hubHost}:${config.hubPort}`;
|
|
23
23
|
};
|
|
24
24
|
|
|
25
|
-
async function registerNode(
|
|
26
|
-
let
|
|
25
|
+
async function registerNode(data, addr, port, basePath) {
|
|
26
|
+
let configFilePath;
|
|
27
27
|
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
} catch (err) {
|
|
31
|
-
_logger.default.error(`Unable to load node configuration file to register with grid: ${err.message}`);
|
|
28
|
+
if (_lodash.default.isString(data)) {
|
|
29
|
+
configFilePath = data;
|
|
32
30
|
|
|
33
|
-
|
|
34
|
-
|
|
31
|
+
try {
|
|
32
|
+
data = await _support.fs.readFile(data, 'utf-8');
|
|
33
|
+
} catch (err) {
|
|
34
|
+
_logger.default.error(`Unable to load node configuration file ${configFilePath} to register with grid: ${err.message}`);
|
|
35
35
|
|
|
36
|
-
|
|
37
|
-
|
|
36
|
+
return;
|
|
37
|
+
}
|
|
38
38
|
|
|
39
|
-
|
|
39
|
+
try {
|
|
40
|
+
data = JSON.parse(data);
|
|
41
|
+
} catch (err) {
|
|
42
|
+
_logger.default.errorAndThrow(`Syntax error in node configuration file ${configFilePath}: ${err.message}`);
|
|
43
|
+
|
|
44
|
+
return;
|
|
45
|
+
}
|
|
40
46
|
}
|
|
41
47
|
|
|
42
48
|
postRequest(data, addr, port, basePath);
|
|
@@ -58,15 +64,7 @@ async function registerToGrid(postOptions, configHolder) {
|
|
|
58
64
|
}
|
|
59
65
|
}
|
|
60
66
|
|
|
61
|
-
function postRequest(
|
|
62
|
-
let configHolder;
|
|
63
|
-
|
|
64
|
-
try {
|
|
65
|
-
configHolder = JSON.parse(data);
|
|
66
|
-
} catch (err) {
|
|
67
|
-
_logger.default.errorAndThrow(`Syntax error in node configuration file: ${err.message}`);
|
|
68
|
-
}
|
|
69
|
-
|
|
67
|
+
function postRequest(configHolder, addr, port, basePath) {
|
|
70
68
|
if (!_lodash.default.has(configHolder, 'configuration')) {
|
|
71
69
|
let configuration = {};
|
|
72
70
|
|
|
@@ -154,4 +152,4 @@ var _default = registerNode;
|
|
|
154
152
|
exports.default = _default;require('source-map-support').install();
|
|
155
153
|
|
|
156
154
|
|
|
157
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/grid-register.js"],"names":["hubUri","config","protocol","hubProtocol","hubHost","hubPort","registerNode","configFile","addr","port","basePath","data","fs","readFile","err","logger","error","message","postRequest","registerToGrid","postOptions","configHolder","status","Error","debug","configuration","JSON","parse","errorAndThrow","_","has","property","url","host","id","regRequest","method","register","registerCycleInterval","registerCycle","isNaN","warn","first","setInterval","registerRetry","isAlreadyRegistered","timeout","success","msg"],"mappings":"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","sourcesContent":["import axios from 'axios';\nimport { fs } from '@appium/support';\nimport logger from './logger';\nimport _ from 'lodash';\n\n\nconst hubUri = (config) => {\n  const protocol = config.hubProtocol || 'http';\n  return `${protocol}://${config.hubHost}:${config.hubPort}`;\n};\n\nasync function registerNode (configFile, addr, port, basePath) {\n  let data;\n  try {\n    data = await fs.readFile(configFile, 'utf-8');\n  } catch (err) {\n    logger.error(`Unable to load node configuration file to register with grid: ${err.message}`);\n    return;\n  }\n\n  // Check presence of data before posting  it to the selenium grid\n  if (!data) {\n    logger.error('No data found in the node configuration file to send to the grid');\n    return;\n  }\n  postRequest(data, addr, port, basePath);\n}\n\nasync function registerToGrid (postOptions, configHolder) {\n  try {\n    const {status} = await axios(postOptions);\n    if (status !== 200) {\n      throw new Error(`Request failed with code ${status}`);\n    }\n    logger.debug(`Appium successfully registered with the the grid on ` +\n      hubUri(configHolder.configuration));\n  } catch (err) {\n    logger.error(`An attempt to register with the grid was unsuccessful: ${err.message}`);\n  }\n}\n\nfunction postRequest (data, addr, port, basePath) {\n  // parse json to get hub host and port\n  let configHolder;\n  try {\n    configHolder = JSON.parse(data);\n  } catch (err) {\n    logger.errorAndThrow(`Syntax error in node configuration file: ${err.message}`);\n  }\n\n  // Move Selenium 3 configuration properties to configuration object\n  if (!_.has(configHolder, 'configuration')) {\n    let configuration = {};\n    for (const property in configHolder) {\n      if (_.has(configHolder, property) && property !== 'capabilities') {\n        configuration[property] = configHolder[property];\n        delete configHolder[property];\n      }\n    }\n    configHolder.configuration = configuration;\n  }\n\n  // if the node config does not have the appium/webdriver url, host, and port,\n  // automatically add it based on how appium was initialized\n  // otherwise, we will take whatever the user setup\n  // because we will always set localhost/127.0.0.1. this won't work if your\n  // node and grid aren't in the same place\n  if (!configHolder.configuration.url || !configHolder.configuration.host || !configHolder.configuration.port) {\n    configHolder.configuration.url = `http://${addr}:${port}${basePath}`;\n    configHolder.configuration.host = addr;\n    configHolder.configuration.port = port;\n  }\n  // if the node config does not have id automatically add it\n  if (!configHolder.configuration.id) {\n    configHolder.configuration.id = `http://${configHolder.configuration.host}:${configHolder.configuration.port}`;\n  }\n\n  // the post options\n  const regRequest = {\n    url: `${hubUri(configHolder.configuration)}/grid/register`,\n    method: 'POST',\n    data: configHolder,\n  };\n\n  if (configHolder.configuration.register !== true) {\n    logger.debug(`No registration sent (${configHolder.configuration.register} = false)`);\n    return;\n  }\n\n  const registerCycleInterval = configHolder.configuration.registerCycle;\n  if (isNaN(registerCycleInterval) || registerCycleInterval <= 0) {\n    logger.warn(`'registerCycle' is not a valid positive number. ` +\n      `No registration request will be sent to the grid.`);\n    return;\n  }\n  // initiate a new Thread\n  let first = true;\n  logger.debug(`Starting auto register thread for the grid. ` +\n    `Will try to register every ${registerCycleInterval} ms.`);\n  setInterval(async function registerRetry () {\n    if (first) {\n      first = false;\n      await registerToGrid(regRequest, configHolder);\n    } else if (!await isAlreadyRegistered(configHolder)) {\n      // make the http POST to the grid for registration\n      await registerToGrid(regRequest, configHolder);\n    }\n  }, registerCycleInterval);\n}\n\nasync function isAlreadyRegistered (configHolder) {\n  //check if node is already registered\n  const id = configHolder.configuration.id;\n  try {\n    const {data, status} = await axios({\n      url: `${hubUri(configHolder.configuration)}/grid/api/proxy?id=${id}`,\n      timeout: 10000,\n    });\n    if (status !== 200) {\n      throw new Error(`Request failed with code ${status}`);\n    }\n    if (!data.success) {\n      // if register fail, print the debug msg\n      logger.debug(`Grid registration error: ${data.msg}`);\n    }\n    return data.success;\n  } catch (err) {\n    logger.debug(`Hub down or not responding: ${err.message}`);\n  }\n}\n\n\nexport default registerNode;\n"],"file":"lib/grid-register.js","sourceRoot":"../.."}
|
|
155
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/grid-register.js"],"names":["hubUri","config","protocol","hubProtocol","hubHost","hubPort","registerNode","data","addr","port","basePath","configFilePath","_","isString","fs","readFile","err","logger","error","message","JSON","parse","errorAndThrow","postRequest","registerToGrid","postOptions","configHolder","status","Error","debug","configuration","has","property","url","host","id","regRequest","method","register","registerCycleInterval","registerCycle","isNaN","warn","first","setInterval","registerRetry","isAlreadyRegistered","timeout","success","msg"],"mappings":"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","sourcesContent":["import axios from 'axios';\nimport { fs } from '@appium/support';\nimport logger from './logger';\nimport _ from 'lodash';\n\n\nconst hubUri = (config) => {\n  const protocol = config.hubProtocol || 'http';\n  return `${protocol}://${config.hubHost}:${config.hubPort}`;\n};\n\n/**\n * Registers a new node with a selenium grid\n * @param {string|object} data - Path or object representing selenium grid node config file\n * @param {string} addr - Bind to this address\n * @param {number} port - Bind to this port\n * @param {string} basePath - Base path for the grid\n */\nasync function registerNode (data, addr, port, basePath) {\n  let configFilePath;\n  if (_.isString(data)) {\n    configFilePath = data;\n    try {\n      data = await fs.readFile(data, 'utf-8');\n    } catch (err) {\n      logger.error(`Unable to load node configuration file ${configFilePath} to register with grid: ${err.message}`);\n      return;\n    }\n    try {\n      data = JSON.parse(data);\n    } catch (err) {\n      logger.errorAndThrow(`Syntax error in node configuration file ${configFilePath}: ${err.message}`);\n      return;\n    }\n  }\n\n  postRequest(data, addr, port, basePath);\n}\n\nasync function registerToGrid (postOptions, configHolder) {\n  try {\n    const {status} = await axios(postOptions);\n    if (status !== 200) {\n      throw new Error(`Request failed with code ${status}`);\n    }\n    logger.debug(`Appium successfully registered with the the grid on ` +\n      hubUri(configHolder.configuration));\n  } catch (err) {\n    logger.error(`An attempt to register with the grid was unsuccessful: ${err.message}`);\n  }\n}\n\nfunction postRequest (configHolder, addr, port, basePath) {\n  // Move Selenium 3 configuration properties to configuration object\n  if (!_.has(configHolder, 'configuration')) {\n    let configuration = {};\n    for (const property in configHolder) {\n      if (_.has(configHolder, property) && property !== 'capabilities') {\n        configuration[property] = configHolder[property];\n        delete configHolder[property];\n      }\n    }\n    configHolder.configuration = configuration;\n  }\n\n  // if the node config does not have the appium/webdriver url, host, and port,\n  // automatically add it based on how appium was initialized\n  // otherwise, we will take whatever the user setup\n  // because we will always set localhost/127.0.0.1. this won't work if your\n  // node and grid aren't in the same place\n  if (!configHolder.configuration.url || !configHolder.configuration.host || !configHolder.configuration.port) {\n    configHolder.configuration.url = `http://${addr}:${port}${basePath}`;\n    configHolder.configuration.host = addr;\n    configHolder.configuration.port = port;\n  }\n  // if the node config does not have id automatically add it\n  if (!configHolder.configuration.id) {\n    configHolder.configuration.id = `http://${configHolder.configuration.host}:${configHolder.configuration.port}`;\n  }\n\n  // the post options\n  const regRequest = {\n    url: `${hubUri(configHolder.configuration)}/grid/register`,\n    method: 'POST',\n    data: configHolder,\n  };\n\n  if (configHolder.configuration.register !== true) {\n    logger.debug(`No registration sent (${configHolder.configuration.register} = false)`);\n    return;\n  }\n\n  const registerCycleInterval = configHolder.configuration.registerCycle;\n  if (isNaN(registerCycleInterval) || registerCycleInterval <= 0) {\n    logger.warn(`'registerCycle' is not a valid positive number. ` +\n      `No registration request will be sent to the grid.`);\n    return;\n  }\n  // initiate a new Thread\n  let first = true;\n  logger.debug(`Starting auto register thread for the grid. ` +\n    `Will try to register every ${registerCycleInterval} ms.`);\n  setInterval(async function registerRetry () {\n    if (first) {\n      first = false;\n      await registerToGrid(regRequest, configHolder);\n    } else if (!await isAlreadyRegistered(configHolder)) {\n      // make the http POST to the grid for registration\n      await registerToGrid(regRequest, configHolder);\n    }\n  }, registerCycleInterval);\n}\n\nasync function isAlreadyRegistered (configHolder) {\n  //check if node is already registered\n  const id = configHolder.configuration.id;\n  try {\n    const {data, status} = await axios({\n      url: `${hubUri(configHolder.configuration)}/grid/api/proxy?id=${id}`,\n      timeout: 10000,\n    });\n    if (status !== 200) {\n      throw new Error(`Request failed with code ${status}`);\n    }\n    if (!data.success) {\n      // if register fail, print the debug msg\n      logger.debug(`Grid registration error: ${data.msg}`);\n    }\n    return data.success;\n  } catch (err) {\n    logger.debug(`Hub down or not responding: ${err.message}`);\n  }\n}\n\n\nexport default registerNode;\n"],"file":"lib/grid-register.js","sourceRoot":"../.."}
|
package/build/lib/logsink.js
CHANGED
|
@@ -5,9 +5,9 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
|
|
|
5
5
|
Object.defineProperty(exports, "__esModule", {
|
|
6
6
|
value: true
|
|
7
7
|
});
|
|
8
|
-
exports.init = init;
|
|
9
8
|
exports.clear = clear;
|
|
10
9
|
exports.default = void 0;
|
|
10
|
+
exports.init = init;
|
|
11
11
|
|
|
12
12
|
require("source-map-support/register");
|
|
13
13
|
|