appium 2.0.0-beta.25 → 2.0.0-beta.26
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 +278 -0
- package/build/lib/appium.js +45 -66
- package/build/lib/cli/args.js +19 -39
- package/build/lib/cli/driver-command.js +5 -9
- package/build/lib/cli/extension-command.js +73 -64
- package/build/lib/cli/extension.js +10 -23
- package/build/lib/cli/parser.js +9 -19
- package/build/lib/cli/plugin-command.js +5 -9
- package/build/lib/cli/utils.js +2 -4
- package/build/lib/config-file.js +2 -4
- package/build/lib/config.js +7 -6
- package/build/lib/constants.js +60 -0
- package/build/lib/extension/driver-config.js +190 -0
- package/build/lib/extension/extension-config.js +297 -0
- package/build/lib/extension/index.js +77 -0
- package/build/lib/extension/manifest.js +246 -0
- package/build/lib/extension/package-changed.js +68 -0
- package/build/lib/extension/plugin-config.js +87 -0
- package/build/lib/grid-register.js +2 -4
- package/build/lib/logger.js +2 -4
- package/build/lib/logsink.js +2 -4
- package/build/lib/main.js +40 -68
- package/build/lib/schema/appium-config-schema.js +2 -4
- package/build/lib/schema/arg-spec.js +11 -14
- package/build/lib/schema/cli-args.js +2 -4
- package/build/lib/schema/cli-transformers.js +2 -4
- package/build/lib/schema/index.js +2 -4
- package/build/lib/schema/keywords.js +2 -4
- package/build/lib/schema/schema.js +55 -37
- package/build/lib/utils.js +1 -32
- package/lib/appium.js +50 -68
- package/lib/cli/args.js +19 -23
- package/lib/cli/driver-command.js +10 -2
- package/lib/cli/extension-command.js +216 -135
- package/lib/cli/extension.js +7 -15
- package/lib/cli/parser.js +6 -14
- package/lib/cli/plugin-command.js +1 -2
- package/lib/config-file.js +3 -3
- package/lib/config.js +5 -4
- package/lib/constants.js +79 -0
- package/lib/extension/driver-config.js +230 -0
- package/lib/extension/extension-config.js +459 -0
- package/lib/extension/index.js +103 -0
- package/lib/extension/manifest.js +590 -0
- package/lib/extension/package-changed.js +64 -0
- package/lib/extension/plugin-config.js +111 -0
- package/lib/grid-register.js +4 -4
- package/lib/main.js +51 -88
- package/lib/schema/arg-spec.js +2 -2
- package/lib/schema/cli-args.js +1 -0
- package/lib/schema/keywords.js +1 -1
- package/lib/schema/schema.js +60 -28
- package/lib/utils.js +2 -32
- package/package.json +29 -21
- package/{postinstall.js → scripts/postinstall.js} +1 -1
- package/types/types.d.ts +70 -31
- package/bin/ios-webkit-debug-proxy-launcher.js +0 -71
- package/build/check-npm-pack-files.js +0 -23
- package/build/commands-yml/parse.js +0 -319
- package/build/commands-yml/validator.js +0 -130
- package/build/index.js +0 -19
- package/build/lib/cli/npm.js +0 -220
- package/build/lib/driver-config.js +0 -100
- package/build/lib/drivers.js +0 -100
- package/build/lib/ext-config-io.js +0 -165
- package/build/lib/extension-config.js +0 -320
- package/build/lib/plugin-config.js +0 -69
- package/build/lib/plugins.js +0 -18
- package/build/postinstall.js +0 -90
- package/build/test/cli/cli-e2e-specs.js +0 -221
- package/build/test/cli/cli-helpers.js +0 -86
- package/build/test/cli/cli-specs.js +0 -71
- package/build/test/cli/fixtures/test-driver/package.json +0 -27
- package/build/test/cli/schema-args-specs.js +0 -48
- package/build/test/cli/schema-e2e-specs.js +0 -47
- package/build/test/config-e2e-specs.js +0 -112
- package/build/test/config-file-e2e-specs.js +0 -191
- package/build/test/config-file-specs.js +0 -281
- package/build/test/config-specs.js +0 -258
- package/build/test/driver-e2e-specs.js +0 -435
- package/build/test/driver-specs.js +0 -386
- package/build/test/ext-config-io-specs.js +0 -181
- package/build/test/extension-config-specs.js +0 -365
- package/build/test/fixtures/allow-feat.txt +0 -5
- package/build/test/fixtures/caps.json +0 -3
- package/build/test/fixtures/config/allow-insecure.txt +0 -3
- package/build/test/fixtures/config/appium.config.bad-nodeconfig.json +0 -5
- package/build/test/fixtures/config/appium.config.bad.json +0 -32
- package/build/test/fixtures/config/appium.config.ext-good.json +0 -9
- package/build/test/fixtures/config/appium.config.ext-unknown-props.json +0 -10
- package/build/test/fixtures/config/appium.config.good.js +0 -40
- package/build/test/fixtures/config/appium.config.good.json +0 -33
- package/build/test/fixtures/config/appium.config.good.yaml +0 -30
- package/build/test/fixtures/config/appium.config.invalid.json +0 -31
- package/build/test/fixtures/config/appium.config.security-array.json +0 -5
- package/build/test/fixtures/config/appium.config.security-delimited.json +0 -5
- package/build/test/fixtures/config/appium.config.security-path.json +0 -5
- package/build/test/fixtures/config/driver-fake.config.json +0 -8
- package/build/test/fixtures/config/nodeconfig.json +0 -3
- package/build/test/fixtures/config/plugin-fake.config.json +0 -0
- package/build/test/fixtures/default-args.js +0 -35
- package/build/test/fixtures/deny-feat.txt +0 -5
- package/build/test/fixtures/driver.schema.js +0 -20
- package/build/test/fixtures/extensions.yaml +0 -27
- package/build/test/fixtures/flattened-schema.js +0 -532
- package/build/test/fixtures/plugin.schema.js +0 -20
- package/build/test/fixtures/schema-with-extensions.js +0 -28
- package/build/test/grid-register-specs.js +0 -74
- package/build/test/helpers.js +0 -75
- package/build/test/logger-specs.js +0 -76
- package/build/test/npm-specs.js +0 -20
- package/build/test/parser-specs.js +0 -319
- package/build/test/plugin-e2e-specs.js +0 -316
- package/build/test/schema/arg-spec-specs.js +0 -70
- package/build/test/schema/cli-args-specs.js +0 -408
- package/build/test/schema/schema-specs.js +0 -407
- package/build/test/utils-specs.js +0 -288
- package/lib/cli/npm.js +0 -251
- package/lib/driver-config.js +0 -101
- package/lib/drivers.js +0 -84
- package/lib/ext-config-io.js +0 -287
- package/lib/extension-config.js +0 -366
- package/lib/plugin-config.js +0 -63
- package/lib/plugins.js +0 -13
|
@@ -0,0 +1,246 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports.Manifest = void 0;
|
|
9
|
+
|
|
10
|
+
require("source-map-support/register");
|
|
11
|
+
|
|
12
|
+
var _support = require("@appium/support");
|
|
13
|
+
|
|
14
|
+
var _lodash = _interopRequireDefault(require("lodash"));
|
|
15
|
+
|
|
16
|
+
var _path = _interopRequireDefault(require("path"));
|
|
17
|
+
|
|
18
|
+
var _yaml = _interopRequireDefault(require("yaml"));
|
|
19
|
+
|
|
20
|
+
var _constants = require("../constants");
|
|
21
|
+
|
|
22
|
+
var _logger = _interopRequireDefault(require("../logger"));
|
|
23
|
+
|
|
24
|
+
var _extensionConfig = require("./extension-config");
|
|
25
|
+
|
|
26
|
+
var _packageChanged = require("./package-changed");
|
|
27
|
+
|
|
28
|
+
const DEFAULT_SEARCH_DEPTH = 4;
|
|
29
|
+
const DEFAULT_FIND_EXTENSIONS_OPTS = Object.freeze({
|
|
30
|
+
depthLimit: DEFAULT_SEARCH_DEPTH,
|
|
31
|
+
filter: filepath => !_path.default.basename(filepath).startsWith('.')
|
|
32
|
+
});
|
|
33
|
+
const CONFIG_SCHEMA_REV = 2;
|
|
34
|
+
const CONFIG_DATA_DRIVER_KEY = `${_constants.DRIVER_TYPE}s`;
|
|
35
|
+
const CONFIG_DATA_PLUGIN_KEY = `${_constants.PLUGIN_TYPE}s`;
|
|
36
|
+
const INITIAL_MANIFEST_DATA = Object.freeze({
|
|
37
|
+
[CONFIG_DATA_DRIVER_KEY]: Object.freeze({}),
|
|
38
|
+
[CONFIG_DATA_PLUGIN_KEY]: Object.freeze({}),
|
|
39
|
+
schemaRev: CONFIG_SCHEMA_REV
|
|
40
|
+
});
|
|
41
|
+
|
|
42
|
+
function isExtension(value) {
|
|
43
|
+
return _lodash.default.isPlainObject(value) && _lodash.default.isPlainObject(value.appium) && _lodash.default.isString(value.name) && _lodash.default.isString(value.version);
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
function isDriver(value) {
|
|
47
|
+
return isExtension(value) && _lodash.default.isString(_lodash.default.get(value, 'appium.driverName')) && _lodash.default.isString(_lodash.default.get(value, 'appium.automationName')) && _lodash.default.isArray(_lodash.default.get(value, 'appium.platformNames'));
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
function isPlugin(value) {
|
|
51
|
+
return isExtension(value) && _lodash.default.isString(_lodash.default.get(value, 'appium.pluginName'));
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
class Manifest {
|
|
55
|
+
_data;
|
|
56
|
+
_appiumHome;
|
|
57
|
+
_manifestPath;
|
|
58
|
+
_writing;
|
|
59
|
+
_reading;
|
|
60
|
+
|
|
61
|
+
constructor(appiumHome) {
|
|
62
|
+
this._appiumHome = appiumHome;
|
|
63
|
+
this._data = _lodash.default.cloneDeep(INITIAL_MANIFEST_DATA);
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
static getInstance = _lodash.default.memoize(function _getInstance(appiumHome) {
|
|
67
|
+
return new Manifest(appiumHome);
|
|
68
|
+
});
|
|
69
|
+
|
|
70
|
+
async syncWithInstalledExtensions({
|
|
71
|
+
depthLimit = DEFAULT_SEARCH_DEPTH
|
|
72
|
+
} = {}) {
|
|
73
|
+
const walkOpts = _lodash.default.defaults({
|
|
74
|
+
depthLimit
|
|
75
|
+
}, DEFAULT_FIND_EXTENSIONS_OPTS);
|
|
76
|
+
|
|
77
|
+
let didChange = false;
|
|
78
|
+
|
|
79
|
+
for await (const {
|
|
80
|
+
stats,
|
|
81
|
+
path: filepath
|
|
82
|
+
} of _support.fs.walk(this._appiumHome, walkOpts)) {
|
|
83
|
+
if (filepath !== this._appiumHome && stats.isDirectory()) {
|
|
84
|
+
try {
|
|
85
|
+
const pkg = await _support.env.readPackageInDir(filepath);
|
|
86
|
+
|
|
87
|
+
if (pkg && isExtension(pkg)) {
|
|
88
|
+
const added = this.addExtensionFromPackage(pkg, _path.default.join(filepath, 'package.json'));
|
|
89
|
+
didChange = didChange || added;
|
|
90
|
+
}
|
|
91
|
+
} catch {}
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
return didChange;
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
hasDriver(name) {
|
|
99
|
+
return Boolean(this._data.drivers[name]);
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
hasPlugin(name) {
|
|
103
|
+
return Boolean(this._data.plugins[name]);
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
addExtensionFromPackage(pkgJson, pkgPath) {
|
|
107
|
+
const internal = {
|
|
108
|
+
pkgName: pkgJson.name,
|
|
109
|
+
version: pkgJson.version,
|
|
110
|
+
installType: _extensionConfig.INSTALL_TYPE_NPM,
|
|
111
|
+
installSpec: `${pkgJson.name}@${pkgJson.version}`
|
|
112
|
+
};
|
|
113
|
+
|
|
114
|
+
if (isDriver(pkgJson)) {
|
|
115
|
+
if (!this.hasDriver(pkgJson.appium.driverName)) {
|
|
116
|
+
this.addExtension(_constants.DRIVER_TYPE, pkgJson.appium.driverName, { ..._lodash.default.omit(pkgJson.appium, 'driverName'),
|
|
117
|
+
...internal
|
|
118
|
+
});
|
|
119
|
+
return true;
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
return false;
|
|
123
|
+
} else if (isPlugin(pkgJson)) {
|
|
124
|
+
if (!this.hasPlugin(pkgJson.appium.pluginName)) {
|
|
125
|
+
this.addExtension(_constants.PLUGIN_TYPE, pkgJson.appium.pluginName, { ..._lodash.default.omit(pkgJson.appium, 'pluginName'),
|
|
126
|
+
...internal
|
|
127
|
+
});
|
|
128
|
+
return true;
|
|
129
|
+
}
|
|
130
|
+
|
|
131
|
+
return false;
|
|
132
|
+
} else {
|
|
133
|
+
throw new TypeError(`The extension in ${_path.default.dirname(pkgPath)} is neither a valid driver nor a valid plugin.`);
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
addExtension(extType, extName, extData) {
|
|
138
|
+
this._data[`${extType}s`][extName] = extData;
|
|
139
|
+
}
|
|
140
|
+
|
|
141
|
+
get appiumHome() {
|
|
142
|
+
return this._appiumHome;
|
|
143
|
+
}
|
|
144
|
+
|
|
145
|
+
get manifestPath() {
|
|
146
|
+
return this._manifestPath;
|
|
147
|
+
}
|
|
148
|
+
|
|
149
|
+
getExtensionData(extType) {
|
|
150
|
+
return this._data[`${extType}s`];
|
|
151
|
+
}
|
|
152
|
+
|
|
153
|
+
async read() {
|
|
154
|
+
if (this._reading) {
|
|
155
|
+
await this._reading;
|
|
156
|
+
return this._data;
|
|
157
|
+
}
|
|
158
|
+
|
|
159
|
+
this._reading = (async () => {
|
|
160
|
+
let data;
|
|
161
|
+
let isNewFile = false;
|
|
162
|
+
await this._setManifestPath();
|
|
163
|
+
|
|
164
|
+
try {
|
|
165
|
+
_logger.default.debug(`Reading ${this._manifestPath}...`);
|
|
166
|
+
|
|
167
|
+
const yaml = await _support.fs.readFile(this._manifestPath, 'utf8');
|
|
168
|
+
data = _yaml.default.parse(yaml);
|
|
169
|
+
} catch (err) {
|
|
170
|
+
if (err.code === 'ENOENT') {
|
|
171
|
+
data = _lodash.default.cloneDeep(INITIAL_MANIFEST_DATA);
|
|
172
|
+
isNewFile = true;
|
|
173
|
+
} else {
|
|
174
|
+
if (this._manifestPath) {
|
|
175
|
+
throw new Error(`Appium had trouble loading the extension installation ` + `cache file (${this._manifestPath}). It may be invalid YAML. Specific error: ${err.message}`);
|
|
176
|
+
} else {
|
|
177
|
+
throw new Error(`Appium encountered an unknown problem. Specific error: ${err.message}`);
|
|
178
|
+
}
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
|
|
182
|
+
this._data = data;
|
|
183
|
+
let installedExtensionsChanged = false;
|
|
184
|
+
|
|
185
|
+
if ((await _support.env.hasAppiumDependency(this.appiumHome)) && (await (0, _packageChanged.packageDidChange)(this.appiumHome))) {
|
|
186
|
+
installedExtensionsChanged = await this.syncWithInstalledExtensions();
|
|
187
|
+
}
|
|
188
|
+
|
|
189
|
+
if (isNewFile || installedExtensionsChanged) {
|
|
190
|
+
await this.write();
|
|
191
|
+
}
|
|
192
|
+
})();
|
|
193
|
+
|
|
194
|
+
try {
|
|
195
|
+
await this._reading;
|
|
196
|
+
return this._data;
|
|
197
|
+
} finally {
|
|
198
|
+
this._reading = undefined;
|
|
199
|
+
}
|
|
200
|
+
}
|
|
201
|
+
|
|
202
|
+
async _setManifestPath() {
|
|
203
|
+
if (!this._manifestPath) {
|
|
204
|
+
this._manifestPath = await _support.env.resolveManifestPath(this._appiumHome);
|
|
205
|
+
|
|
206
|
+
if (_path.default.relative(this._appiumHome, this._manifestPath).startsWith('.')) {
|
|
207
|
+
throw new Error(`Mismatch between location of APPIUM_HOME and manifest file. APPIUM_HOME: ${this.appiumHome}, manifest file: ${this._manifestPath}`);
|
|
208
|
+
}
|
|
209
|
+
}
|
|
210
|
+
|
|
211
|
+
return this._manifestPath;
|
|
212
|
+
}
|
|
213
|
+
|
|
214
|
+
async write() {
|
|
215
|
+
if (this._writing) {
|
|
216
|
+
return this._writing;
|
|
217
|
+
}
|
|
218
|
+
|
|
219
|
+
this._writing = (async () => {
|
|
220
|
+
await this._setManifestPath();
|
|
221
|
+
|
|
222
|
+
try {
|
|
223
|
+
await _support.fs.mkdirp(_path.default.dirname(this._manifestPath));
|
|
224
|
+
} catch (err) {
|
|
225
|
+
throw new Error(`Appium could not create the directory for the manifest file: ${_path.default.dirname(this._manifestPath)}. Original error: ${err.message}`);
|
|
226
|
+
}
|
|
227
|
+
|
|
228
|
+
try {
|
|
229
|
+
await _support.fs.writeFile(this._manifestPath, _yaml.default.stringify(this._data), 'utf8');
|
|
230
|
+
return true;
|
|
231
|
+
} catch (err) {
|
|
232
|
+
throw new Error(`Appium could not write to manifest at ${this._manifestPath} using APPIUM_HOME ${this._appiumHome}. ` + `Please ensure it is writable. Original error: ${err.message}`);
|
|
233
|
+
}
|
|
234
|
+
})();
|
|
235
|
+
|
|
236
|
+
try {
|
|
237
|
+
return await this._writing;
|
|
238
|
+
} finally {
|
|
239
|
+
this._writing = undefined;
|
|
240
|
+
}
|
|
241
|
+
}
|
|
242
|
+
|
|
243
|
+
}
|
|
244
|
+
|
|
245
|
+
exports.Manifest = Manifest;
|
|
246
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../lib/extension/manifest.js"],"names":["DEFAULT_SEARCH_DEPTH","DEFAULT_FIND_EXTENSIONS_OPTS","Object","freeze","depthLimit","filter","filepath","path","basename","startsWith","CONFIG_SCHEMA_REV","CONFIG_DATA_DRIVER_KEY","DRIVER_TYPE","CONFIG_DATA_PLUGIN_KEY","PLUGIN_TYPE","INITIAL_MANIFEST_DATA","schemaRev","isExtension","value","_","isPlainObject","appium","isString","name","version","isDriver","get","isArray","isPlugin","Manifest","_data","_appiumHome","_manifestPath","_writing","_reading","constructor","appiumHome","cloneDeep","getInstance","memoize","_getInstance","syncWithInstalledExtensions","walkOpts","defaults","didChange","stats","fs","walk","isDirectory","pkg","env","readPackageInDir","added","addExtensionFromPackage","join","hasDriver","Boolean","drivers","hasPlugin","plugins","pkgJson","pkgPath","internal","pkgName","installType","INSTALL_TYPE_NPM","installSpec","driverName","addExtension","omit","pluginName","TypeError","dirname","extType","extName","extData","manifestPath","getExtensionData","read","data","isNewFile","_setManifestPath","log","debug","yaml","readFile","YAML","parse","err","code","Error","message","installedExtensionsChanged","hasAppiumDependency","write","undefined","resolveManifestPath","relative","mkdirp","writeFile","stringify"],"mappings":"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","sourcesContent":["// @ts-check\n\n/**\n * Module containing {@link Manifest} which handles reading & writing of extension config files.\n */\n\nimport { env, fs } from '@appium/support';\nimport _ from 'lodash';\nimport path from 'path';\nimport YAML from 'yaml';\nimport { DRIVER_TYPE, PLUGIN_TYPE } from '../constants';\nimport log from '../logger';\nimport { INSTALL_TYPE_NPM } from './extension-config';\nimport { packageDidChange } from './package-changed';\n\n/**\n * Default depth to search in directory tree for whatever it is we're looking for.\n *\n * It's 4 because smaller numbers didn't work.\n */\nconst DEFAULT_SEARCH_DEPTH = 4;\n\n/**\n * Default options for {@link findExtensions}.\n * @type {Readonly<import('klaw').Options>}\n */\nconst DEFAULT_FIND_EXTENSIONS_OPTS = Object.freeze({\n  depthLimit: DEFAULT_SEARCH_DEPTH,\n  /* istanbul ignore next */\n  filter: (filepath) => !path.basename(filepath).startsWith('.'),\n});\n\n/**\n * Current configuration schema revision!\n */\nconst CONFIG_SCHEMA_REV = 2;\n\n/**\n * The name of the prop (`drivers`) used in `extensions.yaml` for drivers.\n * @type {`${typeof DRIVER_TYPE}s`}\n */\nconst CONFIG_DATA_DRIVER_KEY = `${DRIVER_TYPE}s`;\n\n/**\n * The name of the prop (`plugins`) used in `extensions.yaml` for plugins.\n * @type {`${typeof PLUGIN_TYPE}s`}\n */\nconst CONFIG_DATA_PLUGIN_KEY = `${PLUGIN_TYPE}s`;\n\n/**\n * @type {Readonly<ManifestData>}\n */\nconst INITIAL_MANIFEST_DATA = Object.freeze({\n  [CONFIG_DATA_DRIVER_KEY]: Object.freeze({}),\n  [CONFIG_DATA_PLUGIN_KEY]: Object.freeze({}),\n  schemaRev: CONFIG_SCHEMA_REV,\n});\n\n/**\n * Given a `package.json` return `true` if it represents an Appium Extension (either a driver or plugin).\n *\n * The `package.json` must have an `appium` property which is an object.\n * @param {any} value\n * @returns {value is ExtensionPackageJson<ExtensionType>}\n */\nfunction isExtension (value) {\n  return (\n    _.isPlainObject(value) &&\n    _.isPlainObject(value.appium) &&\n    _.isString(value.name) &&\n    _.isString(value.version)\n  );\n}\n/**\n * Given a `package.json`, return `true` if it represents an Appium Driver.\n *\n * To be considered a driver, a `package.json` must have a fields\n * `appium.driverName`, `appium.automationName` and `appium.platformNames`.\n * @param {any} value - Value to test\n * @returns {value is ExtensionPackageJson<DriverType>}\n */\nfunction isDriver (value) {\n  return (\n    isExtension(value) &&\n    _.isString(_.get(value, 'appium.driverName')) &&\n    _.isString(_.get(value, 'appium.automationName')) &&\n    _.isArray(_.get(value, 'appium.platformNames'))\n  );\n}\n\n/**\n * Given a `package.json`, return `true` if it represents an Appium Plugin.\n *\n * To be considered a plugin, a `package.json` must have an `appium.pluginName` field.\n * @param {any} value - Value to test\n * @returns {value is ExtensionPackageJson<PluginType>}\n */\nfunction isPlugin (value) {\n  return isExtension(value) && _.isString(_.get(value, 'appium.pluginName'));\n}\n\n/**\n * Handles reading & writing of extension config files.\n *\n * Only one instance of this class exists per value of `APPIUM_HOME`.\n */\nexport class Manifest {\n  /**\n   * The entire contents of a parsed YAML extension config file.\n   *\n   * Contains proxies for automatic persistence on disk\n   * @type {ManifestData}\n   * @private\n   */\n  _data;\n\n  /**\n   * Path to `APPIUM_HOME`.\n   * @private\n   * @type {Readonly<string>}\n   */\n  _appiumHome;\n\n  /**\n   * Path to `extensions.yaml`\n   * @type {string}\n   * Not set until {@link Manifest.read} is called.\n   */\n  _manifestPath;\n\n  /**\n   * Helps avoid writing multiple times.\n   *\n   * If this is `undefined`, calling {@link Manifest.write} will cause it to be\n   * set to a `Promise`. When the call to `write()` is complete, the `Promise`\n   * will resolve and then this value will be set to `undefined`.  Concurrent calls\n   * made while this value is a `Promise` will return the `Promise` itself.\n   * @private\n   * @type {Promise<boolean>|undefined}\n   */\n  _writing;\n\n  /**\n   * Helps avoid reading multiple times.\n   *\n   * If this is `undefined`, calling {@link Manifest.read} will cause it to be\n   * set to a `Promise`. When the call to `read()` is complete, the `Promise`\n   * will resolve and then this value will be set to `undefined`.  Concurrent calls\n   * made while this value is a `Promise` will return the `Promise` itself.\n   * @private\n   * @type {Promise<void>|undefined}\n   */\n  _reading;\n\n  /**\n   * Sets internal data to a fresh clone of {@link INITIAL_MANIFEST_DATA}\n   *\n   * Use {@link Manifest.getInstance} instead.\n   * @param {string} appiumHome\n   * @private\n   */\n  constructor (appiumHome) {\n    this._appiumHome = appiumHome;\n    this._data = _.cloneDeep(INITIAL_MANIFEST_DATA);\n  }\n\n  /**\n   * Returns a new or existing {@link Manifest} instance, based on the value of `appiumHome`.\n   *\n   * Maintains one instance per value of `appiumHome`.\n   * @param {string} appiumHome - Path to `APPIUM_HOME`\n   * @returns {Manifest}\n   */\n  static getInstance = _.memoize(function _getInstance (\n    appiumHome,\n  ) {\n    return new Manifest(appiumHome);\n  });\n\n  /**\n   * Searches `APPIUM_HOME` for installed extensions and adds them to the manifest.\n   * @param {SyncWithInstalledExtensionsOpts} opts\n   * @returns {Promise<boolean>} `true` if any extensions were added, `false` otherwise.\n   */\n  async syncWithInstalledExtensions ({depthLimit = DEFAULT_SEARCH_DEPTH} = {}) {\n    const walkOpts = _.defaults({depthLimit}, DEFAULT_FIND_EXTENSIONS_OPTS);\n    // this could be parallelized, but we can't use fs.walk as an async iterator\n    let didChange = false;\n    for await (const {stats, path: filepath} of fs.walk(\n      this._appiumHome,\n      walkOpts,\n    )) {\n      if (filepath !== this._appiumHome && stats.isDirectory()) {\n        try {\n          const pkg = await env.readPackageInDir(filepath);\n          if (pkg && isExtension(pkg)) {\n            // it's possible that this extension already exists in the manifest,\n            // so only update `didChange` if it's new.\n            const added = this.addExtensionFromPackage(\n              pkg,\n              path.join(filepath, 'package.json'),\n            );\n            didChange = didChange || added;\n          }\n        } catch {}\n      }\n    }\n    return didChange;\n  }\n\n  /**\n   * Returns `true` if driver with name `name` is registered.\n   * @param {string} name - Driver name\n   * @returns {boolean}\n   */\n  hasDriver (name) {\n    return Boolean(this._data.drivers[name]);\n  }\n\n  /**\n   * Returns `true` if plugin with name `name` is registered.\n   * @param {string} name - Plugin name\n   * @returns {boolean}\n   */\n  hasPlugin (name) {\n    return Boolean(this._data.plugins[name]);\n  }\n\n  /**\n   * Given a path to a `package.json`, add it as either a driver or plugin to the manifest.\n   *\n   * Will _not_ overwrite existing entries.\n   * @template {ExtensionType} ExtType\n   * @param {ExtensionPackageJson<ExtType>} pkgJson\n   * @param {string} pkgPath\n   * @returns {boolean} - `true` upon success, `false` if the extension is already registered.\n   */\n  addExtensionFromPackage (pkgJson, pkgPath) {\n    /**\n     * @type {InternalData}\n     */\n    const internal = {\n      pkgName: pkgJson.name,\n      version: pkgJson.version,\n      installType: INSTALL_TYPE_NPM,\n      installSpec: `${pkgJson.name}@${pkgJson.version}`,\n    };\n\n    if (isDriver(pkgJson)) {\n      if (!this.hasDriver(pkgJson.appium.driverName)) {\n        this.addExtension(DRIVER_TYPE, pkgJson.appium.driverName, {\n          ..._.omit(pkgJson.appium, 'driverName'),\n          ...internal\n        });\n        return true;\n      }\n      return false;\n    } else if (isPlugin(pkgJson)) {\n      if (!this.hasPlugin(pkgJson.appium.pluginName)) {\n        this.addExtension(PLUGIN_TYPE, pkgJson.appium.pluginName, {\n          ..._.omit(pkgJson.appium, 'pluginName'),\n          ...internal,\n        });\n        return true;\n      }\n      return false;\n    } else {\n      throw new TypeError(\n        `The extension in ${path.dirname(\n          pkgPath,\n        )} is neither a valid driver nor a valid plugin.`,\n      );\n    }\n  }\n\n  /**\n   * Adds an extension to the manifest as was installed by the `appium` CLI.  The\n   * `extData`, `extType`, and `extName` have already been determined.\n   *\n   * See {@link Manifest.addExtensionFromPackage} for adding an extension from an on-disk package.\n   * @template {ExtensionType} ExtType\n   * @param {ExtType} extType - `driver` or `plugin`\n   * @param {string} extName - Name of extension\n   * @param {ExtData<ExtType>} extData - Extension metadata\n   * @returns {void}\n   */\n  addExtension (extType, extName, extData) {\n    this._data[`${extType}s`][extName] = extData;\n  }\n\n  /**\n   * Returns the APPIUM_HOME path\n   */\n  get appiumHome () {\n    return this._appiumHome;\n  }\n\n  /**\n   * Returns the path to the manifest file\n   */\n  get manifestPath () {\n    return this._manifestPath;\n  }\n\n  /**\n   * Returns extension data for a particular type.\n   *\n   * @template {ExtensionType} ExtType\n   * @param {ExtType} extType\n   * @returns {ExtRecord<ExtType>}\n   */\n  getExtensionData (extType) {\n    return this._data[/** @type {string} */ (`${extType}s`)];\n  }\n\n  /**\n   * Reads manifest from disk and _overwrites_ the internal data.\n   *\n   * If the manifest does not exist on disk, an {@link INITIAL_MANIFEST_DATA \"empty\"} manifest file will be created.\n   *\n   * If `APPIUM_HOME` contains a `package.json` with an `appium` dependency, then a hash of the `package.json` will be taken. If this hash differs from the last hash, the contents of `APPIUM_HOME/node_modules` will be scanned for extensions that may have been installed outside of the `appium` CLI.  Any found extensions will be added to the manifest file, and if so, the manifest file will be written to disk.\n   *\n   * Only one read operation should happen at a time.  This is controlled via the {@link Manifest._reading} property.\n   * @returns {Promise<ManifestData>} The data\n   */\n  async read () {\n    if (this._reading) {\n      await this._reading;\n      return this._data;\n    }\n\n    this._reading = (async () => {\n      /** @type {ManifestData} */\n      let data;\n      let isNewFile = false;\n      await this._setManifestPath();\n      try {\n        log.debug(`Reading ${this._manifestPath}...`);\n        const yaml = await fs.readFile(this._manifestPath, 'utf8');\n        data = YAML.parse(yaml);\n      } catch (err) {\n        if (err.code === 'ENOENT') {\n          data = _.cloneDeep(INITIAL_MANIFEST_DATA);\n          isNewFile = true;\n        } else {\n          if (this._manifestPath) {\n            throw new Error(\n              `Appium had trouble loading the extension installation ` +\n                `cache file (${this._manifestPath}). It may be invalid YAML. Specific error: ${err.message}`,\n            );\n          } else {\n            throw new Error(\n              `Appium encountered an unknown problem. Specific error: ${err.message}`,\n            );\n          }\n        }\n      }\n\n      this._data = data;\n      let installedExtensionsChanged = false;\n      if (\n        await env.hasAppiumDependency(this.appiumHome) &&\n        (await packageDidChange(this.appiumHome))\n      ) {\n        installedExtensionsChanged = await this.syncWithInstalledExtensions();\n      }\n\n      if (isNewFile || installedExtensionsChanged) {\n        await this.write();\n      }\n    })();\n    try {\n      await this._reading;\n      return this._data;\n    } finally {\n      this._reading = undefined;\n    }\n  }\n\n  /**\n   * Ensures {@link Manifest._manifestPath} is set.\n   *\n   * Creates the directory if necessary.\n   * @private\n   * @returns {Promise<string>}\n   */\n  async _setManifestPath () {\n    if (!this._manifestPath) {\n      this._manifestPath = await env.resolveManifestPath(this._appiumHome);\n\n      /* istanbul ignore if */\n      if (path.relative(this._appiumHome, this._manifestPath).startsWith('.')) {\n        throw new Error(\n          `Mismatch between location of APPIUM_HOME and manifest file. APPIUM_HOME: ${this.appiumHome}, manifest file: ${this._manifestPath}`,\n        );\n      }\n    }\n\n    return this._manifestPath;\n  }\n\n  /**\n   * Writes the data if it need s writing.\n   *\n   * If the `schemaRev` prop needs updating, the file will be written.\n   *\n   * @todo If this becomes too much of a bottleneck, throttle it.\n   * @returns {Promise<boolean>} Whether the data was written\n   */\n  async write () {\n    if (this._writing) {\n      return this._writing;\n    }\n    this._writing = (async () => {\n      await this._setManifestPath();\n      try {\n        await fs.mkdirp(path.dirname(this._manifestPath));\n      } catch (err) {\n        throw new Error(\n          `Appium could not create the directory for the manifest file: ${path.dirname(\n            this._manifestPath,\n          )}. Original error: ${err.message}`,\n        );\n      }\n      try {\n        await fs.writeFile(\n          this._manifestPath,\n          YAML.stringify(this._data),\n          'utf8',\n        );\n        return true;\n      } catch (err) {\n        throw new Error(\n          `Appium could not write to manifest at ${this._manifestPath} using APPIUM_HOME ${this._appiumHome}. ` +\n            `Please ensure it is writable. Original error: ${err.message}`,\n        );\n      }\n    })();\n    try {\n      return await this._writing;\n    } finally {\n      this._writing = undefined;\n    }\n  }\n}\n\n/**\n * Either `driver` or `plugin` rn\n * @typedef {typeof DRIVER_TYPE | typeof PLUGIN_TYPE} ExtensionType\n */\n\n/**\n * Represents an entire YAML manifest (`extensions.yaml`)\n * @typedef ManifestData\n * @property {ExtRecord<DriverType>} drivers - Record of drivers, keyed by name\n * @property {ExtRecord<PluginType>} plugins - Record of plugins, keyed by name\n * @property {number} [schemaRev] - The schema revision of the manifest\n */\n\n/**\n * Combination of external + internal extension data with `driverName`/`pluginName` removed (it becomes a key in an {@link ExtRecord} object).\n * @template {ExtensionType} ExtType\n * @typedef {(Omit<ExternalData<ExtType>, ExtType extends DriverType ? 'driverName' : 'pluginName'>) & InternalData & CommonData} ExtensionManifest\n */\n\n/**\n * Manifest extension data which is _not_ provided in `package.json`.  It may be derived\n * (e.g., `installSpec`) or copied from elsewhere in a `package.json` (e.g.,\n * `version`).\n * @typedef InternalData\n * @property {string} pkgName - Name of package (e.g., `appium-xcuitest-driver`)\n * @property {string} version - Version of package\n * @property {import('./extension-config').InstallType} installType - Install type\n * @property {string} installSpec - Whatever the user typed as the extension to install. May be derived from `package.json`\n */\n\n/**\n * Convert external (`package.json`) extension data into manifest data\n * @typedef {ExtensionManifest<DriverType>} ManifestDriverData\n */\n\n/**\n * Convert external (`package.json`) extension data into manifest data\n * @typedef {ExtensionManifest<PluginType>} ManifestPluginData\n */\n\n/**\n * Data points shared by all Appium extensions\n * @typedef CommonData\n * @property {string} mainClass - Name of main class in the extension\n * @property {Record<string,string>} [scripts] - Collection of scripts which an extension may run\n * @property {string | (import('ajv').SchemaObject & {[key: number]: never})} [schema] - Argument schema object\n */\n\n/**\n * Driver-specific manifest data.\n * @typedef DriverData\n * @property {string} automationName - Automation engine to use\n * @property {string[]} platformNames - Platforms to run on\n * @property {string} driverName - Name of driver (_not_ the same as the package name, probably)\n */\n\n/**\n * Plugin-specific manifest data.\n * @typedef PluginData\n * @property {string} pluginName - Name of plugin (_not_ the same as the package name, probably)\n */\n\n/**\n * Generic type to refer to either {@link DriverData} or {@link PluginData}\n * @template {ExtensionType} ExtType\n * @typedef {CommonData & (ExtType extends DriverType ? DriverData : PluginData)} ExternalData\n */\n\n/**\n * Main class/constructor of third-party plugin\n *\n * Referenced by {@link CommonData.mainClass}\n * @typedef { {pluginName: string} & import('type-fest').Class<unknown> & ExtClassStaticMembers} PluginClass\n */\n\n/**\n * Main class/constructor of third-party driver\n *\n * Referenced by {@link CommonData.mainClass}\n * @typedef { {driverName: string} & import('type-fest').Class<unknown> & ExtClassStaticMembers } DriverClass\n */\n\n/**\n * @typedef ExtClassStaticMembers\n * @property {UpdateServerFn} [updateServer]\n * @property {import('@appium/base-driver').MethodMap} [newMethodMap]\n */\n\n/**\n * @callback UpdateServerFn\n * @param {import('express').Express} app - Express app\n * @param {import('http').Server} httpServer - HTTP server\n * @returns {import('type-fest').Promisable<void>}\n */\n/**\n * Generic type for an object keyed by extension name, with values of type {@link ExtData}\n * @template {ExtensionType} ExtType\n * @typedef {Record<string,ExtData<ExtType>>} ExtRecord\n */\n\n/**\n * Generic type to refer to the data in an {@link ExtRecord}; this is the data for each extension in `extensions.yaml`.\n * @template {ExtensionType} ExtType\n * @typedef {ExtensionManifest<ExtType>} ExtData\n */\n\n/**\n * Like {@link ExtData} except it _for sure_ has a `schema` property.\n * @template {ExtensionType} ExtType\n * @typedef {(ExtensionManifest<ExtType>) & {schema: import('ajv').SchemaObject|string} } ExtDataWithSchema\n */\n\n/**\n * Generic type to refer to the main class constructor of an extension\n * @template {ExtensionType} ExtType\n * @typedef {ExtType extends DriverType ? DriverClass : PluginClass} ExtClass\n */\n\n/**\n * Generic type for the key of an {@link ExtRecord} which corresponds to an extension name.\n * @template {ExtensionType} ExtType\n * @typedef {keyof ExtRecord<ExtType>} ExtName\n */\n\n/**\n * Type of the string referring to a driver (typically as a key or type string)\n * @typedef {typeof import('../constants').DRIVER_TYPE} DriverType\n */\n\n/**\n * Type of the string referring to a plugin (typically as a key or type string)\n * @typedef {typeof import('../constants').PLUGIN_TYPE} PluginType\n */\n\n/**\n * A `package.json` containing extension data.\n * @template {ExtensionType} ExtType\n * @typedef {import('type-fest').SetRequired<import('type-fest').PackageJson, 'name' | 'version'> & {appium: ExternalData<ExtType>} } ExtensionPackageJson\n */\n\n/**\n * @typedef SyncWithInstalledExtensionsOpts\n * @property {number} [depthLimit] - Maximum depth to recurse into subdirectories\n */\n"]}
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports.packageDidChange = packageDidChange;
|
|
9
|
+
|
|
10
|
+
require("source-map-support/register");
|
|
11
|
+
|
|
12
|
+
var _support = require("@appium/support");
|
|
13
|
+
|
|
14
|
+
var _packageChanged = require("package-changed");
|
|
15
|
+
|
|
16
|
+
var _path = _interopRequireDefault(require("path"));
|
|
17
|
+
|
|
18
|
+
var _constants = require("../constants");
|
|
19
|
+
|
|
20
|
+
var _logger = _interopRequireDefault(require("../logger"));
|
|
21
|
+
|
|
22
|
+
async function packageDidChange(appiumHome) {
|
|
23
|
+
const hashFilename = _path.default.join(appiumHome, _constants.PKG_HASHFILE_RELATIVE_PATH);
|
|
24
|
+
|
|
25
|
+
let isChanged;
|
|
26
|
+
let writeHash;
|
|
27
|
+
let hash;
|
|
28
|
+
let oldHash;
|
|
29
|
+
|
|
30
|
+
const hashFilenameDir = _path.default.dirname(hashFilename);
|
|
31
|
+
|
|
32
|
+
_logger.default.debug(`Creating hash file directory: ${hashFilenameDir}`);
|
|
33
|
+
|
|
34
|
+
try {
|
|
35
|
+
await _support.fs.mkdirp(hashFilenameDir);
|
|
36
|
+
} catch (err) {
|
|
37
|
+
throw new Error(`Appium could not create the directory for hash file: ${hashFilenameDir}. Original error: ${err.message}`);
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
try {
|
|
41
|
+
({
|
|
42
|
+
isChanged,
|
|
43
|
+
writeHash,
|
|
44
|
+
oldHash,
|
|
45
|
+
hash
|
|
46
|
+
} = await (0, _packageChanged.isPackageChanged)({
|
|
47
|
+
cwd: appiumHome,
|
|
48
|
+
hashFilename: _constants.PKG_HASHFILE_RELATIVE_PATH
|
|
49
|
+
}));
|
|
50
|
+
} catch {
|
|
51
|
+
return true;
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
if (isChanged) {
|
|
55
|
+
try {
|
|
56
|
+
var _oldHash;
|
|
57
|
+
|
|
58
|
+
writeHash();
|
|
59
|
+
|
|
60
|
+
_logger.default.debug(`Updated hash of ${appiumHome}/package.json from: ${(_oldHash = oldHash) !== null && _oldHash !== void 0 ? _oldHash : '(none)'} to: ${hash}`);
|
|
61
|
+
} catch (err) {
|
|
62
|
+
throw new Error(`Appium could not write hash file: ${hashFilenameDir}. Original error: ${err.message}`);
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
return isChanged;
|
|
67
|
+
}
|
|
68
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL2xpYi9leHRlbnNpb24vcGFja2FnZS1jaGFuZ2VkLmpzIl0sIm5hbWVzIjpbInBhY2thZ2VEaWRDaGFuZ2UiLCJhcHBpdW1Ib21lIiwiaGFzaEZpbGVuYW1lIiwicGF0aCIsImpvaW4iLCJQS0dfSEFTSEZJTEVfUkVMQVRJVkVfUEFUSCIsImlzQ2hhbmdlZCIsIndyaXRlSGFzaCIsImhhc2giLCJvbGRIYXNoIiwiaGFzaEZpbGVuYW1lRGlyIiwiZGlybmFtZSIsImxvZyIsImRlYnVnIiwiZnMiLCJta2RpcnAiLCJlcnIiLCJFcnJvciIsIm1lc3NhZ2UiLCJjd2QiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7O0FBRUE7O0FBQ0E7O0FBQ0E7O0FBQ0E7O0FBQ0E7O0FBV08sZUFBZUEsZ0JBQWYsQ0FBaUNDLFVBQWpDLEVBQTZDO0FBQ2xELFFBQU1DLFlBQVksR0FBR0MsY0FBS0MsSUFBTCxDQUFVSCxVQUFWLEVBQXNCSSxxQ0FBdEIsQ0FBckI7O0FBS0EsTUFBSUMsU0FBSjtBQUVBLE1BQUlDLFNBQUo7QUFFQSxNQUFJQyxJQUFKO0FBRUEsTUFBSUMsT0FBSjs7QUFHQSxRQUFNQyxlQUFlLEdBQUdQLGNBQUtRLE9BQUwsQ0FBYVQsWUFBYixDQUF4Qjs7QUFDQVUsa0JBQUlDLEtBQUosQ0FBVyxpQ0FBZ0NILGVBQWdCLEVBQTNEOztBQUNBLE1BQUk7QUFDRixVQUFNSSxZQUFHQyxNQUFILENBQVVMLGVBQVYsQ0FBTjtBQUNELEdBRkQsQ0FFRSxPQUFPTSxHQUFQLEVBQVk7QUFDWixVQUFNLElBQUlDLEtBQUosQ0FDSCx3REFBdURQLGVBQWdCLHFCQUFvQk0sR0FBRyxDQUFDRSxPQUFRLEVBRHBHLENBQU47QUFHRDs7QUFFRCxNQUFJO0FBQ0YsS0FBQztBQUFDWixNQUFBQSxTQUFEO0FBQVlDLE1BQUFBLFNBQVo7QUFBdUJFLE1BQUFBLE9BQXZCO0FBQWdDRCxNQUFBQTtBQUFoQyxRQUF3QyxNQUFNLHNDQUFpQjtBQUM5RFcsTUFBQUEsR0FBRyxFQUFFbEIsVUFEeUQ7QUFFOURDLE1BQUFBLFlBQVksRUFBRUc7QUFGZ0QsS0FBakIsQ0FBL0M7QUFJRCxHQUxELENBS0UsTUFBTTtBQUNOLFdBQU8sSUFBUDtBQUNEOztBQUVELE1BQUlDLFNBQUosRUFBZTtBQUNiLFFBQUk7QUFBQTs7QUFDRkMsTUFBQUEsU0FBUzs7QUFDVEssc0JBQUlDLEtBQUosQ0FBVyxtQkFBa0JaLFVBQVcsdUJBQTlCLFlBQW9EUSxPQUFwRCwrQ0FBK0QsUUFBUyxRQUFPRCxJQUFLLEVBQTlGO0FBQ0QsS0FIRCxDQUdFLE9BQU9RLEdBQVAsRUFBWTtBQUNaLFlBQU0sSUFBSUMsS0FBSixDQUNILHFDQUFvQ1AsZUFBZ0IscUJBQW9CTSxHQUFHLENBQUNFLE9BQVEsRUFEakYsQ0FBTjtBQUdEO0FBQ0Y7O0FBRUQsU0FBT1osU0FBUDtBQUNEIiwic291cmNlc0NvbnRlbnQiOlsiLy8gQHRzLWNoZWNrXG5cbmltcG9ydCB7IGZzIH0gZnJvbSAnQGFwcGl1bS9zdXBwb3J0JztcbmltcG9ydCB7IGlzUGFja2FnZUNoYW5nZWQgfSBmcm9tICdwYWNrYWdlLWNoYW5nZWQnO1xuaW1wb3J0IHBhdGggZnJvbSAncGF0aCc7XG5pbXBvcnQgeyBQS0dfSEFTSEZJTEVfUkVMQVRJVkVfUEFUSCB9IGZyb20gJy4uL2NvbnN0YW50cyc7XG5pbXBvcnQgbG9nIGZyb20gJy4uL2xvZ2dlcic7XG5cbi8qKlxuICogRGV0ZXJtaW5lcyBpZiBleHRlbnNpb25zIGhhdmUgY2hhbmdlZCwgYW5kIHVwZGF0ZXMgYSBoYXNoIHRoZSBgcGFja2FnZS5qc29uYCBpbiBgYXBwaXVtSG9tZWAgaWYgc28uXG4gKlxuICogSWYgdGhleSBoYXZlLCB3ZSBuZWVkIHRvIHN5bmMgdGhlbSB3aXRoIHRoZSBgZXh0ZW5zaW9ucy55YW1sYCBtYW5pZmVzdC5cbiAqXG4gKiBfV2FybmluZzogdGhpcyBtYWtlcyBhIGJsb2NraW5nIGNhbGwgdG8gYHdyaXRlRmlsZVN5bmNgLl9cbiAqIEBwYXJhbSB7c3RyaW5nfSBhcHBpdW1Ib21lXG4gKiBAcmV0dXJucyB7UHJvbWlzZTxib29sZWFuPn0gYHRydWVgIGlmIGBwYWNrYWdlLmpzb25gIGBhcHBpdW1Ib21lYCBjaGFuZ2VkXG4gKi9cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBwYWNrYWdlRGlkQ2hhbmdlIChhcHBpdW1Ib21lKSB7XG4gIGNvbnN0IGhhc2hGaWxlbmFtZSA9IHBhdGguam9pbihhcHBpdW1Ib21lLCBQS0dfSEFTSEZJTEVfUkVMQVRJVkVfUEFUSCk7XG5cbiAgLy8gWFhYOiB0aGUgdHlwZXMgaW4gYHBhY2thZ2UtY2hhbmdlZGAgc2VlbSB0byBiZSB3cm9uZy5cblxuICAvKiogQHR5cGUge2Jvb2xlYW59ICovXG4gIGxldCBpc0NoYW5nZWQ7XG4gIC8qKiBAdHlwZSB7KCkgPT4gdm9pZH0gKi9cbiAgbGV0IHdyaXRlSGFzaDtcbiAgLyoqIEB0eXBlIHtzdHJpbmd9ICovXG4gIGxldCBoYXNoO1xuICAvKiogQHR5cGUge3N0cmluZ3x1bmRlZmluZWR9ICovXG4gIGxldCBvbGRIYXNoO1xuXG4gIC8vIGZpcnN0IG1rZGlycCB0aGUgdGFyZ2V0IGRpci5cbiAgY29uc3QgaGFzaEZpbGVuYW1lRGlyID0gcGF0aC5kaXJuYW1lKGhhc2hGaWxlbmFtZSk7XG4gIGxvZy5kZWJ1ZyhgQ3JlYXRpbmcgaGFzaCBmaWxlIGRpcmVjdG9yeTogJHtoYXNoRmlsZW5hbWVEaXJ9YCk7XG4gIHRyeSB7XG4gICAgYXdhaXQgZnMubWtkaXJwKGhhc2hGaWxlbmFtZURpcik7XG4gIH0gY2F0Y2ggKGVycikge1xuICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgIGBBcHBpdW0gY291bGQgbm90IGNyZWF0ZSB0aGUgZGlyZWN0b3J5IGZvciBoYXNoIGZpbGU6ICR7aGFzaEZpbGVuYW1lRGlyfS4gT3JpZ2luYWwgZXJyb3I6ICR7ZXJyLm1lc3NhZ2V9YCxcbiAgICApO1xuICB9XG5cbiAgdHJ5IHtcbiAgICAoe2lzQ2hhbmdlZCwgd3JpdGVIYXNoLCBvbGRIYXNoLCBoYXNofSA9IGF3YWl0IGlzUGFja2FnZUNoYW5nZWQoe1xuICAgICAgY3dkOiBhcHBpdW1Ib21lLFxuICAgICAgaGFzaEZpbGVuYW1lOiBQS0dfSEFTSEZJTEVfUkVMQVRJVkVfUEFUSCxcbiAgICB9KSk7XG4gIH0gY2F0Y2gge1xuICAgIHJldHVybiB0cnVlO1xuICB9XG5cbiAgaWYgKGlzQ2hhbmdlZCkge1xuICAgIHRyeSB7XG4gICAgICB3cml0ZUhhc2goKTtcbiAgICAgIGxvZy5kZWJ1ZyhgVXBkYXRlZCBoYXNoIG9mICR7YXBwaXVtSG9tZX0vcGFja2FnZS5qc29uIGZyb206ICR7b2xkSGFzaCA/PyAnKG5vbmUpJ30gdG86ICR7aGFzaH1gKTtcbiAgICB9IGNhdGNoIChlcnIpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgICAgYEFwcGl1bSBjb3VsZCBub3Qgd3JpdGUgaGFzaCBmaWxlOiAke2hhc2hGaWxlbmFtZURpcn0uIE9yaWdpbmFsIGVycm9yOiAke2Vyci5tZXNzYWdlfWAsXG4gICAgICApO1xuICAgIH1cbiAgfVxuXG4gIHJldHVybiBpc0NoYW5nZWQ7XG59XG4iXX0=
|
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports.PluginConfig = void 0;
|
|
9
|
+
|
|
10
|
+
require("source-map-support/register");
|
|
11
|
+
|
|
12
|
+
var _lodash = _interopRequireDefault(require("lodash"));
|
|
13
|
+
|
|
14
|
+
var _extensionConfig = require("./extension-config");
|
|
15
|
+
|
|
16
|
+
var _logger = _interopRequireDefault(require("../logger"));
|
|
17
|
+
|
|
18
|
+
var _constants = require("../constants");
|
|
19
|
+
|
|
20
|
+
class PluginConfig extends _extensionConfig.ExtensionConfig {
|
|
21
|
+
static _instances = new WeakMap();
|
|
22
|
+
|
|
23
|
+
constructor(manifest, {
|
|
24
|
+
extData,
|
|
25
|
+
logFn
|
|
26
|
+
} = {}) {
|
|
27
|
+
super(_constants.PLUGIN_TYPE, manifest, logFn);
|
|
28
|
+
|
|
29
|
+
if (extData) {
|
|
30
|
+
this.validate(extData);
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
static create(manifest, {
|
|
35
|
+
extData,
|
|
36
|
+
logFn
|
|
37
|
+
} = {}) {
|
|
38
|
+
const instance = new PluginConfig(manifest, {
|
|
39
|
+
logFn,
|
|
40
|
+
extData
|
|
41
|
+
});
|
|
42
|
+
|
|
43
|
+
if (PluginConfig.getInstance(manifest)) {
|
|
44
|
+
throw new Error(`Manifest with APPIUM_HOME ${manifest.appiumHome} already has a PluginConfig; use PluginConfig.getInstance() to retrieve it.`);
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
PluginConfig._instances.set(manifest, instance);
|
|
48
|
+
|
|
49
|
+
return instance;
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
static getInstance(manifest) {
|
|
53
|
+
return PluginConfig._instances.get(manifest);
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
extensionDesc(pluginName, {
|
|
57
|
+
version
|
|
58
|
+
}) {
|
|
59
|
+
return `${pluginName}@${version}`;
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
print(activeNames) {
|
|
63
|
+
const pluginNames = Object.keys(this.installedExtensions);
|
|
64
|
+
|
|
65
|
+
if (_lodash.default.isEmpty(pluginNames)) {
|
|
66
|
+
_logger.default.info(`No plugins have been installed. Use the "appium plugin" ` + 'command to install the one(s) you want to use.');
|
|
67
|
+
|
|
68
|
+
return;
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
_logger.default.info(`Available plugins:`);
|
|
72
|
+
|
|
73
|
+
for (const [pluginName, pluginData] of _lodash.default.toPairs(this.installedExtensions)) {
|
|
74
|
+
const activeTxt = _lodash.default.includes(activeNames, pluginName) ? ' (ACTIVE)' : '';
|
|
75
|
+
|
|
76
|
+
_logger.default.info(` - ${this.extensionDesc(pluginName, pluginData)}${activeTxt}`);
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
if (_lodash.default.isEmpty(activeNames)) {
|
|
80
|
+
_logger.default.info('No plugins activated. Use the --use-plugins flag with names of plugins to activate');
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
exports.PluginConfig = PluginConfig;
|
|
87
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL2xpYi9leHRlbnNpb24vcGx1Z2luLWNvbmZpZy5qcyJdLCJuYW1lcyI6WyJQbHVnaW5Db25maWciLCJFeHRlbnNpb25Db25maWciLCJfaW5zdGFuY2VzIiwiV2Vha01hcCIsImNvbnN0cnVjdG9yIiwibWFuaWZlc3QiLCJleHREYXRhIiwibG9nRm4iLCJQTFVHSU5fVFlQRSIsInZhbGlkYXRlIiwiY3JlYXRlIiwiaW5zdGFuY2UiLCJnZXRJbnN0YW5jZSIsIkVycm9yIiwiYXBwaXVtSG9tZSIsInNldCIsImdldCIsImV4dGVuc2lvbkRlc2MiLCJwbHVnaW5OYW1lIiwidmVyc2lvbiIsInByaW50IiwiYWN0aXZlTmFtZXMiLCJwbHVnaW5OYW1lcyIsIk9iamVjdCIsImtleXMiLCJpbnN0YWxsZWRFeHRlbnNpb25zIiwiXyIsImlzRW1wdHkiLCJsb2ciLCJpbmZvIiwicGx1Z2luRGF0YSIsInRvUGFpcnMiLCJhY3RpdmVUeHQiLCJpbmNsdWRlcyJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7QUFFQTs7QUFDQTs7QUFDQTs7QUFDQTs7QUFLTyxNQUFNQSxZQUFOLFNBQTJCQyxnQ0FBM0IsQ0FBMkM7QUFZOUIsU0FBVkMsVUFBVSxHQUFHLElBQUlDLE9BQUosRUFBSDs7QUFVakJDLEVBQUFBLFdBQVcsQ0FBRUMsUUFBRixFQUFZO0FBQUNDLElBQUFBLE9BQUQ7QUFBVUMsSUFBQUE7QUFBVixNQUFtQixFQUEvQixFQUFtQztBQUM1QyxVQUFNQyxzQkFBTixFQUFtQkgsUUFBbkIsRUFBNkJFLEtBQTdCOztBQUVBLFFBQUlELE9BQUosRUFBYTtBQUNYLFdBQUtHLFFBQUwsQ0FBY0gsT0FBZDtBQUNEO0FBQ0Y7O0FBVVksU0FBTkksTUFBTSxDQUFFTCxRQUFGLEVBQVk7QUFBQ0MsSUFBQUEsT0FBRDtBQUFVQyxJQUFBQTtBQUFWLE1BQW1CLEVBQS9CLEVBQW1DO0FBQzlDLFVBQU1JLFFBQVEsR0FBRyxJQUFJWCxZQUFKLENBQWlCSyxRQUFqQixFQUEyQjtBQUFDRSxNQUFBQSxLQUFEO0FBQVFELE1BQUFBO0FBQVIsS0FBM0IsQ0FBakI7O0FBQ0EsUUFBSU4sWUFBWSxDQUFDWSxXQUFiLENBQXlCUCxRQUF6QixDQUFKLEVBQXdDO0FBQ3RDLFlBQU0sSUFBSVEsS0FBSixDQUFXLDZCQUE0QlIsUUFBUSxDQUFDUyxVQUFXLDZFQUEzRCxDQUFOO0FBQ0Q7O0FBQ0RkLElBQUFBLFlBQVksQ0FBQ0UsVUFBYixDQUF3QmEsR0FBeEIsQ0FBNEJWLFFBQTVCLEVBQXNDTSxRQUF0Qzs7QUFDQSxXQUFPQSxRQUFQO0FBQ0Q7O0FBT2lCLFNBQVhDLFdBQVcsQ0FBRVAsUUFBRixFQUFZO0FBQzVCLFdBQU9MLFlBQVksQ0FBQ0UsVUFBYixDQUF3QmMsR0FBeEIsQ0FBNEJYLFFBQTVCLENBQVA7QUFDRDs7QUFNRFksRUFBQUEsYUFBYSxDQUFFQyxVQUFGLEVBQWM7QUFBQ0MsSUFBQUE7QUFBRCxHQUFkLEVBQXlCO0FBQ3BDLFdBQVEsR0FBRUQsVUFBVyxJQUFHQyxPQUFRLEVBQWhDO0FBQ0Q7O0FBT0RDLEVBQUFBLEtBQUssQ0FBRUMsV0FBRixFQUFlO0FBQ2xCLFVBQU1DLFdBQVcsR0FBR0MsTUFBTSxDQUFDQyxJQUFQLENBQVksS0FBS0MsbUJBQWpCLENBQXBCOztBQUVBLFFBQUlDLGdCQUFFQyxPQUFGLENBQVVMLFdBQVYsQ0FBSixFQUE0QjtBQUMxQk0sc0JBQUlDLElBQUosQ0FBVSwwREFBRCxHQUNELGdEQURSOztBQUVBO0FBQ0Q7O0FBRURELG9CQUFJQyxJQUFKLENBQVUsb0JBQVY7O0FBQ0EsU0FBSyxNQUFNLENBQUNYLFVBQUQsRUFBYVksVUFBYixDQUFYLElBQXVDSixnQkFBRUssT0FBRixDQUFVLEtBQUtOLG1CQUFmLENBQXZDLEVBQTRFO0FBQzFFLFlBQU1PLFNBQVMsR0FBR04sZ0JBQUVPLFFBQUYsQ0FBV1osV0FBWCxFQUF3QkgsVUFBeEIsSUFBc0MsV0FBdEMsR0FBb0QsRUFBdEU7O0FBQ0FVLHNCQUFJQyxJQUFKLENBQVUsT0FBTSxLQUFLWixhQUFMLENBQW1CQyxVQUFuQixFQUErQlksVUFBL0IsQ0FBMkMsR0FBRUUsU0FBVSxFQUF2RTtBQUNEOztBQUVELFFBQUlOLGdCQUFFQyxPQUFGLENBQVVOLFdBQVYsQ0FBSixFQUE0QjtBQUMxQk8sc0JBQUlDLElBQUosQ0FBUyxvRkFBVDtBQUNEO0FBQ0Y7O0FBdkY4QyIsInNvdXJjZXNDb250ZW50IjpbIi8vIEB0cy1jaGVja1xuXG5pbXBvcnQgXyBmcm9tICdsb2Rhc2gnO1xuaW1wb3J0IHtFeHRlbnNpb25Db25maWd9IGZyb20gJy4vZXh0ZW5zaW9uLWNvbmZpZyc7XG5pbXBvcnQgbG9nIGZyb20gJy4uL2xvZ2dlcic7XG5pbXBvcnQge1BMVUdJTl9UWVBFfSBmcm9tICcuLi9jb25zdGFudHMnO1xuXG4vKipcbiAqIEBleHRlbmRzIHtFeHRlbnNpb25Db25maWc8UGx1Z2luVHlwZT59XG4gKi9cbmV4cG9ydCBjbGFzcyBQbHVnaW5Db25maWcgZXh0ZW5kcyBFeHRlbnNpb25Db25maWcge1xuXG4gIC8qKlxuICAgKiBBIG1hcHBpbmcgb2Yge0BsaW5rIE1hbmlmZXN0fSBpbnN0YW5jZXMgdG8ge0BsaW5rIFBsdWdpbkNvbmZpZ30gaW5zdGFuY2VzLlxuICAgKlxuICAgKiBgTWFuaWZlc3RgIGFuZCB7QGxpbmsgRXh0ZW5zaW9uQ29uZmlnfSBoYXZlIGEgb25lLXRvLW1hbnkgcmVsYXRpb25zaGlwOyBlYWNoIGBNYW5pZmVzdGAgc2hvdWxkIGJlIGFzc29jaWF0ZWQgd2l0aCBhIGBEcml2ZXJDb25maWdgIGFuZCBhIGBQbHVnaW5Db25maWdgOyBubyBtb3JlLCBubyBsZXNzLlxuICAgKlxuICAgKiBUaGlzIHZhcmlhYmxlIHRyYWNrcyB0aGUgYE1hbmlmZXN0YC10by1gUGx1Z2luQ29uZmlnYCBwb3J0aW9uLlxuICAgKlxuICAgKiBAdHlwZSB7V2Vha01hcDxNYW5pZmVzdCxQbHVnaW5Db25maWc+fVxuICAgKiBAcHJpdmF0ZVxuICAgKi9cbiAgIHN0YXRpYyBfaW5zdGFuY2VzID0gbmV3IFdlYWtNYXAoKTtcblxuICAgLyoqXG4gICAqIENhbGwge0BsaW5rIFBsdWdpbkNvbmZpZy5jcmVhdGV9IGluc3RlYWQuXG4gICAqXG4gICAqIEp1c3QgY2FsbHMgdGhlIHN1cGVyY2xhc3MnIGNvbnN0cnVjdG9yIHdpdGggdGhlIGNvcnJlY3QgZXh0ZW5zaW9uIHR5cGVcbiAgICogQHByaXZhdGVcbiAgICogQHBhcmFtIHtpbXBvcnQoJy4vbWFuaWZlc3QnKS5NYW5pZmVzdH0gbWFuaWZlc3QgLSBJTyBvYmplY3RcbiAgICogQHBhcmFtIHtQbHVnaW5Db25maWdPcHRpb25zfSBbb3B0c11cbiAgICovXG4gICBjb25zdHJ1Y3RvciAobWFuaWZlc3QsIHtleHREYXRhLCBsb2dGbn0gPSB7fSkge1xuICAgICBzdXBlcihQTFVHSU5fVFlQRSwgbWFuaWZlc3QsIGxvZ0ZuKTtcblxuICAgICBpZiAoZXh0RGF0YSkge1xuICAgICAgIHRoaXMudmFsaWRhdGUoZXh0RGF0YSk7XG4gICAgIH1cbiAgIH1cblxuICAgLyoqXG4gICAgKiBDcmVhdGVzIGEgbmV3IHtAbGluayBQbHVnaW5Db25maWd9IGluc3RhbmNlIGZvciBhIHtAbGluayBNYW5pZmVzdH0gaW5zdGFuY2UuXG4gICAgKlxuICAgICogQHBhcmFtIHtNYW5pZmVzdH0gbWFuaWZlc3RcbiAgICAqIEBwYXJhbSB7UGx1Z2luQ29uZmlnT3B0aW9uc30gW29wdHNdXG4gICAgKiBAdGhyb3dzIElmIGBtYW5pZmVzdGAgYWxyZWFkeSBhc3NvY2lhdGVkIHdpdGggYSBgUGx1Z2luQ29uZmlnYFxuICAgICogQHJldHVybnMge1BsdWdpbkNvbmZpZ31cbiAgICAqL1xuICAgc3RhdGljIGNyZWF0ZSAobWFuaWZlc3QsIHtleHREYXRhLCBsb2dGbn0gPSB7fSkge1xuICAgICBjb25zdCBpbnN0YW5jZSA9IG5ldyBQbHVnaW5Db25maWcobWFuaWZlc3QsIHtsb2dGbiwgZXh0RGF0YX0pO1xuICAgICBpZiAoUGx1Z2luQ29uZmlnLmdldEluc3RhbmNlKG1hbmlmZXN0KSkge1xuICAgICAgIHRocm93IG5ldyBFcnJvcihgTWFuaWZlc3Qgd2l0aCBBUFBJVU1fSE9NRSAke21hbmlmZXN0LmFwcGl1bUhvbWV9IGFscmVhZHkgaGFzIGEgUGx1Z2luQ29uZmlnOyB1c2UgUGx1Z2luQ29uZmlnLmdldEluc3RhbmNlKCkgdG8gcmV0cmlldmUgaXQuYCk7XG4gICAgIH1cbiAgICAgUGx1Z2luQ29uZmlnLl9pbnN0YW5jZXMuc2V0KG1hbmlmZXN0LCBpbnN0YW5jZSk7XG4gICAgIHJldHVybiBpbnN0YW5jZTtcbiAgIH1cblxuICAgLyoqXG4gICAgICogUmV0dXJucyBhIFBsdWdpbkNvbmZpZyBhc3NvY2lhdGVkIHdpdGggYSBNYW5pZmVzdFxuICAgICAqIEBwYXJhbSB7TWFuaWZlc3R9IG1hbmlmZXN0XG4gICAgICogQHJldHVybnMge1BsdWdpbkNvbmZpZ3x1bmRlZmluZWR9XG4gICAgICovXG4gICBzdGF0aWMgZ2V0SW5zdGFuY2UgKG1hbmlmZXN0KSB7XG4gICAgIHJldHVybiBQbHVnaW5Db25maWcuX2luc3RhbmNlcy5nZXQobWFuaWZlc3QpO1xuICAgfVxuICAgLyoqXG4gICAqIEBwYXJhbSB7c3RyaW5nfSBwbHVnaW5OYW1lXG4gICAqIEBwYXJhbSB7UGx1Z2luRGF0YX0gcGx1Z2luRGF0YVxuICAgKiBAcmV0dXJucyB7c3RyaW5nfVxuICAgKi9cbiAgIGV4dGVuc2lvbkRlc2MgKHBsdWdpbk5hbWUsIHt2ZXJzaW9ufSkge1xuICAgICByZXR1cm4gYCR7cGx1Z2luTmFtZX1AJHt2ZXJzaW9ufWA7XG4gICB9XG5cbiAgIC8qKlxuICAgKlxuICAgKiBAcGFyYW0geyhrZXlvZiBpbXBvcnQoJy4vbWFuaWZlc3QnKS5FeHRSZWNvcmQ8UGx1Z2luVHlwZT4pW119IGFjdGl2ZU5hbWVzXG4gICAqIEByZXR1cm5zIHt2b2lkfVxuICAgKi9cbiAgIHByaW50IChhY3RpdmVOYW1lcykge1xuICAgICBjb25zdCBwbHVnaW5OYW1lcyA9IE9iamVjdC5rZXlzKHRoaXMuaW5zdGFsbGVkRXh0ZW5zaW9ucyk7XG5cbiAgICAgaWYgKF8uaXNFbXB0eShwbHVnaW5OYW1lcykpIHtcbiAgICAgICBsb2cuaW5mbyhgTm8gcGx1Z2lucyBoYXZlIGJlZW4gaW5zdGFsbGVkLiBVc2UgdGhlIFwiYXBwaXVtIHBsdWdpblwiIGAgK1xuICAgICAgICAgICAgICAgJ2NvbW1hbmQgdG8gaW5zdGFsbCB0aGUgb25lKHMpIHlvdSB3YW50IHRvIHVzZS4nKTtcbiAgICAgICByZXR1cm47XG4gICAgIH1cblxuICAgICBsb2cuaW5mbyhgQXZhaWxhYmxlIHBsdWdpbnM6YCk7XG4gICAgIGZvciAoY29uc3QgW3BsdWdpbk5hbWUsIHBsdWdpbkRhdGFdIG9mIF8udG9QYWlycyh0aGlzLmluc3RhbGxlZEV4dGVuc2lvbnMpKSB7XG4gICAgICAgY29uc3QgYWN0aXZlVHh0ID0gXy5pbmNsdWRlcyhhY3RpdmVOYW1lcywgcGx1Z2luTmFtZSkgPyAnIChBQ1RJVkUpJyA6ICcnO1xuICAgICAgIGxvZy5pbmZvKGAgIC0gJHt0aGlzLmV4dGVuc2lvbkRlc2MocGx1Z2luTmFtZSwgcGx1Z2luRGF0YSl9JHthY3RpdmVUeHR9YCk7XG4gICAgIH1cblxuICAgICBpZiAoXy5pc0VtcHR5KGFjdGl2ZU5hbWVzKSkge1xuICAgICAgIGxvZy5pbmZvKCdObyBwbHVnaW5zIGFjdGl2YXRlZC4gVXNlIHRoZSAtLXVzZS1wbHVnaW5zIGZsYWcgd2l0aCBuYW1lcyBvZiBwbHVnaW5zIHRvIGFjdGl2YXRlJyk7XG4gICAgIH1cbiAgIH1cbn1cblxuLyoqXG4gKiBAdHlwZWRlZiBQbHVnaW5Db25maWdPcHRpb25zXG4gKiBAcHJvcGVydHkge2ltcG9ydCgnLi9leHRlbnNpb24tY29uZmlnJykuRXh0ZW5zaW9uTG9nRm59IFtsb2dGbl0gLSBPcHRpb25hbCBsb2dnaW5nIGZ1bmN0aW9uXG4gKiBAcHJvcGVydHkge2ltcG9ydCgnLi9tYW5pZmVzdCcpLkV4dFJlY29yZDxQbHVnaW5UeXBlPn0gW2V4dERhdGFdIC0gRXh0ZW5zaW9uIGRhdGFcbiAqL1xuXG4vKipcbiAqIEB0eXBlZGVmIHtpbXBvcnQoJy4vbWFuaWZlc3QnKS5QbHVnaW5UeXBlfSBQbHVnaW5UeXBlXG4gKiBAdHlwZWRlZiB7aW1wb3J0KCcuL21hbmlmZXN0JykuRXh0RGF0YTxQbHVnaW5UeXBlPn0gUGx1Z2luRGF0YVxuICogQHR5cGVkZWYge2ltcG9ydCgnLi9tYW5pZmVzdCcpLk1hbmlmZXN0fSBNYW5pZmVzdFxuICovXG4iXX0=
|
|
@@ -149,7 +149,5 @@ async function isAlreadyRegistered(configHolder) {
|
|
|
149
149
|
}
|
|
150
150
|
|
|
151
151
|
var _default = registerNode;
|
|
152
|
-
exports.default = _default;
|
|
153
|
-
|
|
154
|
-
|
|
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":"../.."}
|
|
152
|
+
exports.default = _default;
|
|
153
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;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. If a `string`, all subsequent arguments are required!\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"]}
|
package/build/lib/logger.js
CHANGED
|
@@ -12,7 +12,5 @@ var _support = require("@appium/support");
|
|
|
12
12
|
let log = _support.logger.getLogger('Appium');
|
|
13
13
|
|
|
14
14
|
var _default = log;
|
|
15
|
-
exports.default = _default;
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImxpYi9sb2dnZXIuanMiXSwibmFtZXMiOlsibG9nIiwibG9nZ2VyIiwiZ2V0TG9nZ2VyIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7QUFBQTs7QUFHQSxJQUFJQSxHQUFHLEdBQUdDLGdCQUFPQyxTQUFQLENBQWlCLFFBQWpCLENBQVY7O2VBRWVGLEciLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBsb2dnZXIgfSBmcm9tICdAYXBwaXVtL3N1cHBvcnQnO1xuXG5cbmxldCBsb2cgPSBsb2dnZXIuZ2V0TG9nZ2VyKCdBcHBpdW0nKTtcblxuZXhwb3J0IGRlZmF1bHQgbG9nO1xuIl0sImZpbGUiOiJsaWIvbG9nZ2VyLmpzIiwic291cmNlUm9vdCI6Ii4uLy4uIn0=
|
|
15
|
+
exports.default = _default;
|
|
16
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL2xpYi9sb2dnZXIuanMiXSwibmFtZXMiOlsibG9nIiwibG9nZ2VyIiwiZ2V0TG9nZ2VyIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7QUFBQTs7QUFHQSxJQUFJQSxHQUFHLEdBQUdDLGdCQUFPQyxTQUFQLENBQWlCLFFBQWpCLENBQVY7O2VBRWVGLEciLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBsb2dnZXIgfSBmcm9tICdAYXBwaXVtL3N1cHBvcnQnO1xuXG5cbmxldCBsb2cgPSBsb2dnZXIuZ2V0TG9nZ2VyKCdBcHBpdW0nKTtcblxuZXhwb3J0IGRlZmF1bHQgbG9nO1xuIl19
|