appium 2.0.0-beta.24 → 2.0.0-beta.27

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.
Files changed (124) hide show
  1. package/build/lib/appium-config.schema.json +278 -0
  2. package/build/lib/appium.js +45 -66
  3. package/build/lib/cli/args.js +19 -39
  4. package/build/lib/cli/driver-command.js +5 -9
  5. package/build/lib/cli/extension-command.js +73 -64
  6. package/build/lib/cli/extension.js +10 -23
  7. package/build/lib/cli/parser.js +9 -19
  8. package/build/lib/cli/plugin-command.js +5 -9
  9. package/build/lib/cli/utils.js +2 -4
  10. package/build/lib/config-file.js +5 -10
  11. package/build/lib/config.js +50 -20
  12. package/build/lib/constants.js +60 -0
  13. package/build/lib/extension/driver-config.js +190 -0
  14. package/build/lib/extension/extension-config.js +297 -0
  15. package/build/lib/extension/index.js +77 -0
  16. package/build/lib/extension/manifest.js +246 -0
  17. package/build/lib/extension/package-changed.js +68 -0
  18. package/build/lib/extension/plugin-config.js +87 -0
  19. package/build/lib/grid-register.js +2 -4
  20. package/build/lib/logger.js +2 -4
  21. package/build/lib/logsink.js +2 -4
  22. package/build/lib/main.js +42 -71
  23. package/build/lib/schema/appium-config-schema.js +2 -4
  24. package/build/lib/schema/arg-spec.js +11 -14
  25. package/build/lib/schema/cli-args.js +2 -4
  26. package/build/lib/schema/cli-transformers.js +2 -4
  27. package/build/lib/schema/index.js +2 -4
  28. package/build/lib/schema/keywords.js +2 -4
  29. package/build/lib/schema/schema.js +61 -37
  30. package/build/lib/utils.js +1 -32
  31. package/lib/appium.js +50 -68
  32. package/lib/cli/args.js +19 -23
  33. package/lib/cli/driver-command.js +10 -2
  34. package/lib/cli/extension-command.js +216 -135
  35. package/lib/cli/extension.js +7 -15
  36. package/lib/cli/parser.js +6 -14
  37. package/lib/cli/plugin-command.js +1 -2
  38. package/lib/config-file.js +12 -15
  39. package/lib/config.js +55 -24
  40. package/lib/constants.js +79 -0
  41. package/lib/extension/driver-config.js +230 -0
  42. package/lib/extension/extension-config.js +459 -0
  43. package/lib/extension/index.js +103 -0
  44. package/lib/extension/manifest.js +590 -0
  45. package/lib/extension/package-changed.js +64 -0
  46. package/lib/extension/plugin-config.js +111 -0
  47. package/lib/grid-register.js +4 -4
  48. package/lib/main.js +57 -93
  49. package/lib/schema/arg-spec.js +3 -3
  50. package/lib/schema/cli-args.js +1 -0
  51. package/lib/schema/keywords.js +1 -1
  52. package/lib/schema/schema.js +67 -29
  53. package/lib/utils.js +2 -32
  54. package/package.json +29 -21
  55. package/{postinstall.js → scripts/postinstall.js} +1 -1
  56. package/types/types.d.ts +70 -31
  57. package/bin/ios-webkit-debug-proxy-launcher.js +0 -71
  58. package/build/check-npm-pack-files.js +0 -23
  59. package/build/commands-yml/parse.js +0 -319
  60. package/build/commands-yml/validator.js +0 -130
  61. package/build/index.js +0 -19
  62. package/build/lib/cli/npm.js +0 -220
  63. package/build/lib/driver-config.js +0 -100
  64. package/build/lib/drivers.js +0 -100
  65. package/build/lib/ext-config-io.js +0 -165
  66. package/build/lib/extension-config.js +0 -320
  67. package/build/lib/plugin-config.js +0 -69
  68. package/build/lib/plugins.js +0 -18
  69. package/build/postinstall.js +0 -90
  70. package/build/test/cli/cli-e2e-specs.js +0 -221
  71. package/build/test/cli/cli-helpers.js +0 -86
  72. package/build/test/cli/cli-specs.js +0 -71
  73. package/build/test/cli/fixtures/test-driver/package.json +0 -27
  74. package/build/test/cli/schema-args-specs.js +0 -48
  75. package/build/test/cli/schema-e2e-specs.js +0 -47
  76. package/build/test/config-e2e-specs.js +0 -112
  77. package/build/test/config-file-e2e-specs.js +0 -209
  78. package/build/test/config-file-specs.js +0 -281
  79. package/build/test/config-specs.js +0 -246
  80. package/build/test/driver-e2e-specs.js +0 -435
  81. package/build/test/driver-specs.js +0 -386
  82. package/build/test/ext-config-io-specs.js +0 -181
  83. package/build/test/extension-config-specs.js +0 -365
  84. package/build/test/fixtures/allow-feat.txt +0 -5
  85. package/build/test/fixtures/caps.json +0 -3
  86. package/build/test/fixtures/config/allow-insecure.txt +0 -3
  87. package/build/test/fixtures/config/appium.config.bad-nodeconfig.json +0 -5
  88. package/build/test/fixtures/config/appium.config.bad.json +0 -32
  89. package/build/test/fixtures/config/appium.config.ext-good.json +0 -9
  90. package/build/test/fixtures/config/appium.config.ext-unknown-props.json +0 -10
  91. package/build/test/fixtures/config/appium.config.good.js +0 -40
  92. package/build/test/fixtures/config/appium.config.good.json +0 -33
  93. package/build/test/fixtures/config/appium.config.good.yaml +0 -30
  94. package/build/test/fixtures/config/appium.config.invalid.json +0 -31
  95. package/build/test/fixtures/config/appium.config.security-array.json +0 -5
  96. package/build/test/fixtures/config/appium.config.security-delimited.json +0 -5
  97. package/build/test/fixtures/config/appium.config.security-path.json +0 -5
  98. package/build/test/fixtures/config/driver-fake.config.json +0 -8
  99. package/build/test/fixtures/config/nodeconfig.json +0 -3
  100. package/build/test/fixtures/config/plugin-fake.config.json +0 -0
  101. package/build/test/fixtures/default-args.js +0 -35
  102. package/build/test/fixtures/deny-feat.txt +0 -5
  103. package/build/test/fixtures/driver.schema.js +0 -20
  104. package/build/test/fixtures/extensions.yaml +0 -27
  105. package/build/test/fixtures/flattened-schema.js +0 -532
  106. package/build/test/fixtures/plugin.schema.js +0 -20
  107. package/build/test/fixtures/schema-with-extensions.js +0 -28
  108. package/build/test/grid-register-specs.js +0 -74
  109. package/build/test/helpers.js +0 -75
  110. package/build/test/logger-specs.js +0 -76
  111. package/build/test/npm-specs.js +0 -20
  112. package/build/test/parser-specs.js +0 -319
  113. package/build/test/plugin-e2e-specs.js +0 -316
  114. package/build/test/schema/arg-spec-specs.js +0 -70
  115. package/build/test/schema/cli-args-specs.js +0 -408
  116. package/build/test/schema/schema-specs.js +0 -407
  117. package/build/test/utils-specs.js +0 -288
  118. package/lib/cli/npm.js +0 -251
  119. package/lib/driver-config.js +0 -101
  120. package/lib/drivers.js +0 -84
  121. package/lib/ext-config-io.js +0 -287
  122. package/lib/extension-config.js +0 -366
  123. package/lib/plugin-config.js +0 -63
  124. package/lib/plugins.js +0 -13
@@ -1,165 +0,0 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
- Object.defineProperty(exports, "__esModule", {
6
- value: true
7
- });
8
- exports.getExtConfigIOInstance = exports.PLUGIN_TYPE = exports.DRIVER_TYPE = void 0;
9
-
10
- var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
11
-
12
- require("source-map-support/register");
13
-
14
- var _support = require("@appium/support");
15
-
16
- var _lodash = _interopRequireDefault(require("lodash"));
17
-
18
- var _path = _interopRequireDefault(require("path"));
19
-
20
- var _yaml = _interopRequireDefault(require("yaml"));
21
-
22
- const CONFIG_FILE_NAME = 'extensions.yaml';
23
- const CONFIG_SCHEMA_REV = 2;
24
- const DRIVER_TYPE = 'driver';
25
- exports.DRIVER_TYPE = DRIVER_TYPE;
26
- const PLUGIN_TYPE = 'plugin';
27
- exports.PLUGIN_TYPE = PLUGIN_TYPE;
28
- const VALID_EXT_TYPES = new Set([DRIVER_TYPE, PLUGIN_TYPE]);
29
- const CONFIG_DATA_DRIVER_KEY = `${DRIVER_TYPE}s`;
30
- const CONFIG_DATA_PLUGIN_KEY = `${PLUGIN_TYPE}s`;
31
-
32
- class ExtConfigIO {
33
- constructor(appiumHome) {
34
- (0, _defineProperty2.default)(this, "_dirty", void 0);
35
- (0, _defineProperty2.default)(this, "_data", void 0);
36
- (0, _defineProperty2.default)(this, "_extDataByType", new Map());
37
- (0, _defineProperty2.default)(this, "_filepath", void 0);
38
- (0, _defineProperty2.default)(this, "_appiumHome", void 0);
39
- (0, _defineProperty2.default)(this, "_writing", null);
40
- (0, _defineProperty2.default)(this, "_reading", null);
41
- this._filepath = _path.default.resolve(appiumHome, CONFIG_FILE_NAME);
42
- this._appiumHome = appiumHome;
43
- }
44
-
45
- _createProxy(extensionType, data) {
46
- return new Proxy(data[`${extensionType}s`], {
47
- set: (target, prop, value) => {
48
- if (value !== target[prop]) {
49
- this._dirty = true;
50
- }
51
-
52
- target[prop] = value;
53
- return Reflect.set(target, prop, value);
54
- },
55
- deleteProperty: (target, prop) => {
56
- if (prop in target) {
57
- this._dirty = true;
58
- }
59
-
60
- return Reflect.deleteProperty(target, prop);
61
- }
62
- });
63
- }
64
-
65
- get filepath() {
66
- return this._filepath;
67
- }
68
-
69
- async read(extensionType) {
70
- if (this._reading) {
71
- await this._reading;
72
- return this._extDataByType.get(extensionType);
73
- }
74
-
75
- this._reading = (async () => {
76
- if (!VALID_EXT_TYPES.has(extensionType)) {
77
- throw new TypeError(`Invalid extension type: ${extensionType}. Valid values are: ${[...VALID_EXT_TYPES].join(', ')}`);
78
- }
79
-
80
- if (this._extDataByType.has(extensionType)) {
81
- return;
82
- }
83
-
84
- let data;
85
- let isNewFile = false;
86
-
87
- try {
88
- await (0, _support.mkdirp)(this._appiumHome);
89
- const yaml = await _support.fs.readFile(this.filepath, 'utf8');
90
- data = _yaml.default.parse(yaml);
91
- } catch (err) {
92
- if (err.code === 'ENOENT') {
93
- data = {
94
- [CONFIG_DATA_DRIVER_KEY]: {},
95
- [CONFIG_DATA_PLUGIN_KEY]: {},
96
- schemaRev: CONFIG_SCHEMA_REV
97
- };
98
- isNewFile = true;
99
- } else {
100
- throw new Error(`Appium had trouble loading the extension installation ` + `cache file (${this.filepath}). Ensure it exists and is ` + `readable. Specific error: ${err.message}`);
101
- }
102
- }
103
-
104
- this._data = data;
105
-
106
- this._extDataByType.set(DRIVER_TYPE, this._createProxy(DRIVER_TYPE, data));
107
-
108
- this._extDataByType.set(PLUGIN_TYPE, this._createProxy(PLUGIN_TYPE, data));
109
-
110
- if (isNewFile) {
111
- await this.write(true);
112
- }
113
- })();
114
-
115
- try {
116
- await this._reading;
117
- return this._extDataByType.get(extensionType);
118
- } finally {
119
- this._reading = null;
120
- }
121
- }
122
-
123
- async write(force = false) {
124
- if (this._writing) {
125
- return this._writing;
126
- }
127
-
128
- this._writing = (async () => {
129
- try {
130
- if (!this._dirty && !force) {
131
- return false;
132
- }
133
-
134
- if (!this._data) {
135
- throw new ReferenceError('No data to write. Call `read()` first');
136
- }
137
-
138
- const dataToWrite = { ...this._data,
139
- [CONFIG_DATA_DRIVER_KEY]: this._extDataByType.get(DRIVER_TYPE),
140
- [CONFIG_DATA_PLUGIN_KEY]: this._extDataByType.get(PLUGIN_TYPE)
141
- };
142
-
143
- try {
144
- await _support.fs.writeFile(this.filepath, _yaml.default.stringify(dataToWrite), 'utf8');
145
- this._dirty = false;
146
- return true;
147
- } catch {
148
- throw new Error(`Appium could not parse or write from the Appium Home directory ` + `(${this._appiumHome}). Please ensure it is writable.`);
149
- }
150
- } finally {
151
- this._writing = null;
152
- }
153
- })();
154
-
155
- return await this._writing;
156
- }
157
-
158
- }
159
-
160
- const getExtConfigIOInstance = _lodash.default.memoize(appiumHome => new ExtConfigIO(appiumHome));
161
-
162
- exports.getExtConfigIOInstance = getExtConfigIOInstance;require('source-map-support').install();
163
-
164
-
165
- //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/ext-config-io.js"],"names":["CONFIG_FILE_NAME","CONFIG_SCHEMA_REV","DRIVER_TYPE","PLUGIN_TYPE","VALID_EXT_TYPES","Set","CONFIG_DATA_DRIVER_KEY","CONFIG_DATA_PLUGIN_KEY","ExtConfigIO","constructor","appiumHome","Map","_filepath","path","resolve","_appiumHome","_createProxy","extensionType","data","Proxy","set","target","prop","value","_dirty","Reflect","deleteProperty","filepath","read","_reading","_extDataByType","get","has","TypeError","join","isNewFile","yaml","fs","readFile","YAML","parse","err","code","schemaRev","Error","message","_data","write","force","_writing","ReferenceError","dataToWrite","writeFile","stringify","getExtConfigIOInstance","_","memoize"],"mappings":"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","sourcesContent":["// @ts-check\n\n/**\n * Module containing {@link ExtConfigIO} which handles reading & writing of extension config files.\n */\n\nimport { fs, mkdirp } from '@appium/support';\nimport _ from 'lodash';\nimport path from 'path';\nimport YAML from 'yaml';\n\nconst CONFIG_FILE_NAME = 'extensions.yaml';\n\n/**\n * Current configuration schema revision!\n */\nconst CONFIG_SCHEMA_REV = 2;\n\nexport const DRIVER_TYPE = 'driver';\nexport const PLUGIN_TYPE = 'plugin';\n\n/**\n * Set of valid extension types.\n * @type {Readonly<Set<ExtensionType>>}\n */\nconst VALID_EXT_TYPES = new Set([DRIVER_TYPE, PLUGIN_TYPE]);\n\nconst CONFIG_DATA_DRIVER_KEY = `${DRIVER_TYPE}s`;\nconst CONFIG_DATA_PLUGIN_KEY = `${PLUGIN_TYPE}s`;\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 */\nclass ExtConfigIO {\n  /**\n   * \"Dirty\" flag. If true, the data has changed since the last write.\n   * @type {boolean}\n   * @private\n   */\n  _dirty;\n\n  /**\n   * The entire contents of a parsed YAML extension config file.\n   * @type {object?}\n   * @private\n   */\n  _data;\n\n  /**\n   * A mapping of extension type to configuration data. Configuration data is\n   * keyed on extension name.\n   *\n   * Consumers get the values of this `Map` (corresponding to the\n   * `extensionType` of the consumer, which will be a subclass of\n   * `ExtensionConfig`) and do not have access to the entire data object.\n   * @private\n   * @type {Map<ExtensionType,object>}\n   */\n  _extDataByType = new Map();\n\n  /**\n   * Path to config file.\n   * @private\n   * @type {Readonly<string>}\n   */\n  _filepath;\n\n  /**\n   * Path to `APPIUM_HOME`\n   * @private\n   * @type {Readonly<string>}\n   */\n  _appiumHome;\n\n  /**\n   * Helps avoid writing multiple times.\n   *\n   * If this is `null`, calling {@link ExtConfigIO.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 `null`.  Concurrent calls\n   * made while this value is a `Promise` will return the `Promise` itself.\n   * @private\n   * @type {Promise<boolean>?}\n   */\n  _writing = null;\n\n  /**\n   * Helps avoid reading multiple times.\n   *\n   * If this is `null`, calling {@link ExtConfigIO.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 `null`.  Concurrent calls\n   * made while this value is a `Promise` will return the `Promise` itself.\n   * @private\n   * @type {Promise<void>?}\n   */\n  _reading = null;\n\n  /**\n   * @param {string} appiumHome\n   */\n  constructor (appiumHome) {\n    this._filepath = path.resolve(appiumHome, CONFIG_FILE_NAME);\n    this._appiumHome = appiumHome;\n  }\n\n  /**\n   * Creaes a `Proxy` which watches for changes to the extension-type-specific\n   * config data.\n   *\n   * When changes are detected, it sets a `_dirty` flag.  The next call to\n   * {@link ExtConfigIO.write} will check if this flag is `true` before\n   * proceeding.\n   * @param {ExtensionType} extensionType\n   * @param {Record<string,object>} data - Extension config data, keyed by name\n   * @private\n   * @returns {Record<string,object>}\n   */\n  _createProxy (extensionType, data) {\n    return new Proxy(data[`${extensionType}s`], {\n      set: (target, prop, value) => {\n        if (value !== target[prop]) {\n          this._dirty = true;\n        }\n        target[prop] = value;\n        return Reflect.set(target, prop, value);\n      },\n      deleteProperty: (target, prop) => {\n        if (prop in target) {\n          this._dirty = true;\n        }\n        return Reflect.deleteProperty(target, prop);\n      },\n    });\n  }\n\n  /**\n   * Returns the path to the config file.\n   */\n  get filepath () {\n    return this._filepath;\n  }\n\n  /**\n   * Gets data for an extension type.  Reads the config file if necessary.\n   *\n   * Force-reading is _not_ supported, as it's likely to be a source of\n   * bugs--it's easy to mutate the data and then overwrite memory with the file\n   * contents\n   *\n   * Ideally this will only ever read the file _once_.\n   * @param {ExtensionType} extensionType - Which bit of the config data we\n   * want\n   * @returns {Promise<object>} The data\n   */\n  async read (extensionType) {\n    if (this._reading) {\n      await this._reading;\n      return this._extDataByType.get(extensionType);\n    }\n\n    this._reading = (async () => {\n      if (!VALID_EXT_TYPES.has(extensionType)) {\n        throw new TypeError(\n          `Invalid extension type: ${extensionType}. Valid values are: ${[\n            ...VALID_EXT_TYPES,\n          ].join(', ')}`,\n        );\n      }\n      if (this._extDataByType.has(extensionType)) {\n        return;\n      }\n\n      let data;\n      let isNewFile = false;\n      try {\n        await mkdirp(this._appiumHome);\n        const yaml = await fs.readFile(this.filepath, 'utf8');\n        data = YAML.parse(yaml);\n      } catch (err) {\n        if (err.code === 'ENOENT') {\n          data = {\n            [CONFIG_DATA_DRIVER_KEY]: {},\n            [CONFIG_DATA_PLUGIN_KEY]: {},\n            schemaRev: CONFIG_SCHEMA_REV,\n          };\n          isNewFile = true;\n        } else {\n          throw new Error(\n            `Appium had trouble loading the extension installation ` +\n              `cache file (${this.filepath}). Ensure it exists and is ` +\n              `readable. Specific error: ${err.message}`,\n          );\n        }\n      }\n\n      this._data = data;\n      this._extDataByType.set(\n        DRIVER_TYPE,\n        this._createProxy(DRIVER_TYPE, data),\n      );\n      this._extDataByType.set(\n        PLUGIN_TYPE,\n        this._createProxy(PLUGIN_TYPE, data),\n      );\n\n      if (isNewFile) {\n        await this.write(true);\n      }\n    })();\n    try {\n      await this._reading;\n      return this._extDataByType.get(extensionType);\n    } finally {\n      this._reading = null;\n    }\n  }\n\n  /**\n   * Writes the data if it needs writing.\n   *\n   * If the `schemaRev` prop needs updating, the file will be written.\n   * @param {boolean} [force=false] - Whether to force a write even if the data is clean\n   * @returns {Promise<boolean>} Whether the data was written\n   */\n  async write (force = false) {\n    if (this._writing) {\n      return this._writing;\n    }\n    this._writing = (async () => {\n      try {\n        if (!this._dirty && !force) {\n          return false;\n        }\n\n        if (!this._data) {\n          throw new ReferenceError('No data to write. Call `read()` first');\n        }\n\n        const dataToWrite = {\n          ...this._data,\n          [CONFIG_DATA_DRIVER_KEY]: this._extDataByType.get(DRIVER_TYPE),\n          [CONFIG_DATA_PLUGIN_KEY]: this._extDataByType.get(PLUGIN_TYPE),\n        };\n\n        try {\n          await fs.writeFile(\n            this.filepath,\n            YAML.stringify(dataToWrite),\n            'utf8',\n          );\n          this._dirty = false;\n          return true;\n        } catch {\n          throw new Error(\n            `Appium could not parse or write from the Appium Home directory ` +\n              `(${this._appiumHome}). Please ensure it is writable.`,\n          );\n        }\n      } finally {\n        this._writing = null;\n      }\n    })();\n    return await this._writing;\n  }\n}\n\n/**\n * Factory function for {@link ExtConfigIO}.\n *\n * Maintains one instance per value of `APPIUM_HOME`.\n * @param {string} appiumHome - `APPIUM_HOME`\n * @returns {ExtConfigIO}\n */\nexport const getExtConfigIOInstance = _.memoize(\n  (appiumHome) => new ExtConfigIO(appiumHome),\n);\n\n/**\n * @typedef {ExtConfigIO} ExtensionConfigIO\n */\n\n/**\n * @typedef {typeof DRIVER_TYPE | typeof PLUGIN_TYPE} ExtensionType\n */\n"],"file":"lib/ext-config-io.js","sourceRoot":"../.."}
@@ -1,320 +0,0 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
- Object.defineProperty(exports, "__esModule", {
6
- value: true
7
- });
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;
23
-
24
- require("source-map-support/register");
25
-
26
- var _lodash = _interopRequireDefault(require("lodash"));
27
-
28
- var _os = _interopRequireDefault(require("os"));
29
-
30
- var _path = _interopRequireDefault(require("path"));
31
-
32
- var _resolveFrom = _interopRequireDefault(require("resolve-from"));
33
-
34
- var _extConfigIo = require("./ext-config-io");
35
-
36
- var _logger = _interopRequireDefault(require("./logger"));
37
-
38
- var _schema = require("./schema/schema");
39
-
40
- const DEFAULT_APPIUM_HOME = _path.default.resolve(_os.default.homedir(), '.appium');
41
-
42
- exports.DEFAULT_APPIUM_HOME = DEFAULT_APPIUM_HOME;
43
- const APPIUM_HOME = process.env.APPIUM_HOME || DEFAULT_APPIUM_HOME;
44
- exports.APPIUM_HOME = APPIUM_HOME;
45
- const INSTALL_TYPE_NPM = 'npm';
46
- exports.INSTALL_TYPE_NPM = INSTALL_TYPE_NPM;
47
- const INSTALL_TYPE_LOCAL = 'local';
48
- exports.INSTALL_TYPE_LOCAL = INSTALL_TYPE_LOCAL;
49
- const INSTALL_TYPE_GITHUB = 'github';
50
- exports.INSTALL_TYPE_GITHUB = INSTALL_TYPE_GITHUB;
51
- const INSTALL_TYPE_GIT = 'git';
52
- exports.INSTALL_TYPE_GIT = INSTALL_TYPE_GIT;
53
- const INSTALL_TYPES = [INSTALL_TYPE_GIT, INSTALL_TYPE_GITHUB, INSTALL_TYPE_LOCAL, INSTALL_TYPE_NPM];
54
- exports.INSTALL_TYPES = INSTALL_TYPES;
55
-
56
- class ExtensionConfig {
57
- constructor(appiumHome, extensionType, logFn) {
58
- const logger = _lodash.default.isFunction(logFn) ? logFn : _logger.default.error.bind(_logger.default);
59
- this.appiumHome = appiumHome;
60
- this.installedExtensions = {};
61
- this.io = (0, _extConfigIo.getExtConfigIOInstance)(appiumHome);
62
- this.extensionType = extensionType;
63
- this.configKey = `${extensionType}s`;
64
- this.log = logger;
65
- }
66
-
67
- validate(exts) {
68
- const foundProblems = {};
69
-
70
- for (const [extName, extData] of _lodash.default.toPairs(exts)) {
71
- foundProblems[extName] = [...this.getGenericConfigProblems(extData, extName), ...this.getConfigProblems(extData, extName), ...this.getSchemaProblems(extData, extName)];
72
- }
73
-
74
- const problemSummaries = [];
75
-
76
- for (const [extName, problems] of _lodash.default.toPairs(foundProblems)) {
77
- if (_lodash.default.isEmpty(problems)) {
78
- continue;
79
- }
80
-
81
- delete exts[extName];
82
- problemSummaries.push(`${this.extensionType} ${extName} had errors and will not ` + `be available. Errors:`);
83
-
84
- for (const problem of problems) {
85
- problemSummaries.push(` - ${problem.err} (Actual value: ` + `${JSON.stringify(problem.val)})`);
86
- }
87
- }
88
-
89
- if (!_lodash.default.isEmpty(problemSummaries)) {
90
- this.log(`Appium encountered one or more errors while validating ` + `the ${this.configKey} extension file (${this.io.filepath}):`);
91
-
92
- for (const summary of problemSummaries) {
93
- this.log(summary);
94
- }
95
- }
96
-
97
- return exts;
98
- }
99
-
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) {
144
- const {
145
- version,
146
- pkgName,
147
- installSpec,
148
- installType,
149
- installPath,
150
- mainClass
151
- } = extData;
152
- const problems = [];
153
-
154
- if (!_lodash.default.isString(version)) {
155
- problems.push({
156
- err: 'Missing or incorrect version',
157
- val: version
158
- });
159
- }
160
-
161
- if (!_lodash.default.isString(pkgName)) {
162
- problems.push({
163
- err: 'Missing or incorrect NPM package name',
164
- val: pkgName
165
- });
166
- }
167
-
168
- if (!_lodash.default.isString(installSpec)) {
169
- problems.push({
170
- err: 'Missing or incorrect installation spec',
171
- val: installSpec
172
- });
173
- }
174
-
175
- if (!_lodash.default.includes(INSTALL_TYPES, installType)) {
176
- problems.push({
177
- err: 'Missing or incorrect install type',
178
- val: installType
179
- });
180
- }
181
-
182
- if (!_lodash.default.isString(installPath)) {
183
- problems.push({
184
- err: 'Missing or incorrect installation path',
185
- val: installPath
186
- });
187
- }
188
-
189
- if (!_lodash.default.isString(mainClass)) {
190
- problems.push({
191
- err: 'Missing or incorrect driver class name',
192
- val: mainClass
193
- });
194
- }
195
-
196
- return problems;
197
- }
198
-
199
- getConfigProblems(extData, extName) {
200
- return [];
201
- }
202
-
203
- async read() {
204
- const extensions = await this.io.read(this.extensionType);
205
- this.installedExtensions = this.validate(extensions);
206
- return this.installedExtensions;
207
- }
208
-
209
- async write() {
210
- return await this.io.write();
211
- }
212
-
213
- async addExtension(extName, extData) {
214
- this.installedExtensions[extName] = extData;
215
- await this.write();
216
- }
217
-
218
- async updateExtension(extName, extData) {
219
- this.installedExtensions[extName] = { ...this.installedExtensions[extName],
220
- ...extData
221
- };
222
- await this.write();
223
- }
224
-
225
- async removeExtension(extName) {
226
- delete this.installedExtensions[extName];
227
- await this.write();
228
- }
229
-
230
- print() {
231
- const extNames = Object.keys(this.installedExtensions);
232
-
233
- if (_lodash.default.isEmpty(extNames)) {
234
- _logger.default.info(`No ${this.configKey} have been installed. Use the "appium ${this.extensionType}" ` + 'command to install the one(s) you want to use.');
235
-
236
- return;
237
- }
238
-
239
- _logger.default.info(`Available ${this.configKey}:`);
240
-
241
- for (const [extName, extData] of _lodash.default.toPairs(this.installedExtensions)) {
242
- _logger.default.info(` - ${this.extensionDesc(extName, extData)}`);
243
- }
244
- }
245
-
246
- extensionDesc(extName, extData) {
247
- throw new Error('This must be implemented in a subclass');
248
- }
249
-
250
- getExtensionRequirePath(extName) {
251
- const {
252
- pkgName,
253
- installPath
254
- } = this.installedExtensions[extName];
255
- return _path.default.resolve(this.appiumHome, installPath, 'node_modules', pkgName);
256
- }
257
-
258
- getInstallPath(extName) {
259
- const {
260
- installPath
261
- } = this.installedExtensions[extName];
262
- return _path.default.resolve(this.appiumHome, installPath);
263
- }
264
-
265
- require(extName) {
266
- const {
267
- mainClass
268
- } = this.installedExtensions[extName];
269
- const reqPath = this.getExtensionRequirePath(extName);
270
-
271
- const reqResolved = require.resolve(reqPath);
272
-
273
- if (process.env.APPIUM_RELOAD_EXTENSIONS && require.cache[reqResolved]) {
274
- _logger.default.debug(`Removing ${reqResolved} from require cache`);
275
-
276
- delete require.cache[reqResolved];
277
- }
278
-
279
- return require(reqPath)[mainClass];
280
- }
281
-
282
- isInstalled(extName) {
283
- return _lodash.default.includes(Object.keys(this.installedExtensions), extName);
284
- }
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
-
315
- }
316
-
317
- exports.default = ExtensionConfig;require('source-map-support').install();
318
-
319
-
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 {import('type-fest').Class<unknown>}\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":"../.."}
@@ -1,69 +0,0 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
- Object.defineProperty(exports, "__esModule", {
6
- value: true
7
- });
8
- exports.default = void 0;
9
-
10
- var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
11
-
12
- require("source-map-support/register");
13
-
14
- var _lodash = _interopRequireDefault(require("lodash"));
15
-
16
- var _extensionConfig = _interopRequireDefault(require("./extension-config"));
17
-
18
- var _extConfigIo = require("./ext-config-io");
19
-
20
- var _logger = _interopRequireDefault(require("./logger"));
21
-
22
- class PluginConfig extends _extensionConfig.default {
23
- constructor(appiumHome, logFn) {
24
- super(appiumHome, _extConfigIo.PLUGIN_TYPE, logFn);
25
- }
26
-
27
- static getInstance(appiumHome, logFn) {
28
- var _PluginConfig$_instan;
29
-
30
- const instance = (_PluginConfig$_instan = PluginConfig._instances[appiumHome]) !== null && _PluginConfig$_instan !== void 0 ? _PluginConfig$_instan : new PluginConfig(appiumHome, logFn);
31
- PluginConfig._instances[appiumHome] = instance;
32
- return instance;
33
- }
34
-
35
- extensionDesc(pluginName, {
36
- version
37
- }) {
38
- return `${pluginName}@${version}`;
39
- }
40
-
41
- print(activeNames) {
42
- const pluginNames = Object.keys(this.installedExtensions);
43
-
44
- if (_lodash.default.isEmpty(pluginNames)) {
45
- _logger.default.info(`No plugins have been installed. Use the "appium plugin" ` + 'command to install the one(s) you want to use.');
46
-
47
- return;
48
- }
49
-
50
- _logger.default.info(`Available plugins:`);
51
-
52
- for (const [pluginName, pluginData] of _lodash.default.toPairs(this.installedExtensions)) {
53
- const activeTxt = _lodash.default.includes(activeNames, pluginName) ? ' (ACTIVE)' : '';
54
-
55
- _logger.default.info(` - ${this.extensionDesc(pluginName, pluginData)}${activeTxt}`);
56
- }
57
-
58
- if (_lodash.default.isEmpty(activeNames)) {
59
- _logger.default.info('No plugins activated. Use the --use-plugins flag with names of plugins to activate');
60
- }
61
- }
62
-
63
- }
64
-
65
- exports.default = PluginConfig;
66
- (0, _defineProperty2.default)(PluginConfig, "_instances", {});require('source-map-support').install();
67
-
68
-
69
- //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImxpYi9wbHVnaW4tY29uZmlnLmpzIl0sIm5hbWVzIjpbIlBsdWdpbkNvbmZpZyIsIkV4dGVuc2lvbkNvbmZpZyIsImNvbnN0cnVjdG9yIiwiYXBwaXVtSG9tZSIsImxvZ0ZuIiwiUExVR0lOX1RZUEUiLCJnZXRJbnN0YW5jZSIsImluc3RhbmNlIiwiX2luc3RhbmNlcyIsImV4dGVuc2lvbkRlc2MiLCJwbHVnaW5OYW1lIiwidmVyc2lvbiIsInByaW50IiwiYWN0aXZlTmFtZXMiLCJwbHVnaW5OYW1lcyIsIk9iamVjdCIsImtleXMiLCJpbnN0YWxsZWRFeHRlbnNpb25zIiwiXyIsImlzRW1wdHkiLCJsb2ciLCJpbmZvIiwicGx1Z2luRGF0YSIsInRvUGFpcnMiLCJhY3RpdmVUeHQiLCJpbmNsdWRlcyJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7OztBQUFBOztBQUNBOztBQUNBOztBQUNBOztBQUVlLE1BQU1BLFlBQU4sU0FBMkJDLHdCQUEzQixDQUEyQztBQWtCeERDLEVBQUFBLFdBQVcsQ0FBRUMsVUFBRixFQUFjQyxLQUFkLEVBQXFCO0FBQzlCLFVBQU1ELFVBQU4sRUFBa0JFLHdCQUFsQixFQUErQkQsS0FBL0I7QUFDRDs7QUFRaUIsU0FBWEUsV0FBVyxDQUFFSCxVQUFGLEVBQWNDLEtBQWQsRUFBcUI7QUFBQTs7QUFDckMsVUFBTUcsUUFBUSw0QkFBR1AsWUFBWSxDQUFDUSxVQUFiLENBQXdCTCxVQUF4QixDQUFILHlFQUEwQyxJQUFJSCxZQUFKLENBQWlCRyxVQUFqQixFQUE2QkMsS0FBN0IsQ0FBeEQ7QUFDQUosSUFBQUEsWUFBWSxDQUFDUSxVQUFiLENBQXdCTCxVQUF4QixJQUFzQ0ksUUFBdEM7QUFDQSxXQUFPQSxRQUFQO0FBQ0Q7O0FBRURFLEVBQUFBLGFBQWEsQ0FBRUMsVUFBRixFQUFjO0FBQUNDLElBQUFBO0FBQUQsR0FBZCxFQUF5QjtBQUNwQyxXQUFRLEdBQUVELFVBQVcsSUFBR0MsT0FBUSxFQUFoQztBQUNEOztBQUVEQyxFQUFBQSxLQUFLLENBQUVDLFdBQUYsRUFBZTtBQUNsQixVQUFNQyxXQUFXLEdBQUdDLE1BQU0sQ0FBQ0MsSUFBUCxDQUFZLEtBQUtDLG1CQUFqQixDQUFwQjs7QUFFQSxRQUFJQyxnQkFBRUMsT0FBRixDQUFVTCxXQUFWLENBQUosRUFBNEI7QUFDMUJNLHNCQUFJQyxJQUFKLENBQVUsMERBQUQsR0FDQSxnREFEVDs7QUFFQTtBQUNEOztBQUVERCxvQkFBSUMsSUFBSixDQUFVLG9CQUFWOztBQUNBLFNBQUssTUFBTSxDQUFDWCxVQUFELEVBQWFZLFVBQWIsQ0FBWCxJQUF1Q0osZ0JBQUVLLE9BQUYsQ0FBVSxLQUFLTixtQkFBZixDQUF2QyxFQUE0RTtBQUMxRSxZQUFNTyxTQUFTLEdBQUdOLGdCQUFFTyxRQUFGLENBQVdaLFdBQVgsRUFBd0JILFVBQXhCLElBQXNDLFdBQXRDLEdBQW9ELEVBQXRFOztBQUNBVSxzQkFBSUMsSUFBSixDQUFVLE9BQU0sS0FBS1osYUFBTCxDQUFtQkMsVUFBbkIsRUFBK0JZLFVBQS9CLENBQTJDLEdBQUVFLFNBQVUsRUFBdkU7QUFDRDs7QUFFRCxRQUFJTixnQkFBRUMsT0FBRixDQUFVTixXQUFWLENBQUosRUFBNEI7QUFDMUJPLHNCQUFJQyxJQUFKLENBQVMsb0ZBQVQ7QUFDRDtBQUNGOztBQXhEdUQ7Ozs4QkFBckNyQixZLGdCQVFDLEUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgXyBmcm9tICdsb2Rhc2gnO1xuaW1wb3J0IEV4dGVuc2lvbkNvbmZpZyBmcm9tICcuL2V4dGVuc2lvbi1jb25maWcnO1xuaW1wb3J0IHsgUExVR0lOX1RZUEUgfSBmcm9tICcuL2V4dC1jb25maWctaW8nO1xuaW1wb3J0IGxvZyBmcm9tICcuL2xvZ2dlcic7XG5cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIFBsdWdpbkNvbmZpZyBleHRlbmRzIEV4dGVuc2lvbkNvbmZpZyB7XG5cbiAgLyoqXG4gICAqIEEgbWFwcGluZyBvZiBgQVBQSVVNX0hPTUVgIHZhbHVlcyB0byB7QGxpbmsgUGx1Z2luQ29uZmlnfSBpbnN0YW5jZXMuXG4gICAqIEVhY2ggYEFQUElVTV9IT01FYCBzaG91bGQgb25seSBoYXZlIG9uZSBhc3NvY2lhdGVkIGBQbHVnaW5Db25maWdgIGluc3RhbmNlLlxuICAgKiBAdHlwZSB7UmVjb3JkPHN0cmluZyxQbHVnaW5Db25maWc+fVxuICAgKiBAcHJpdmF0ZVxuICAgKi9cbiAgc3RhdGljIF9pbnN0YW5jZXMgPSB7fTtcblxuICAvKipcbiAgICogQ2FsbCB7QGxpbmsgUGx1Z2luQ29uZmlnLmdldEluc3RhbmNlfSBpbnN0ZWFkLlxuICAgKlxuICAgKiBKdXN0IGNhbGxzIHRoZSBzdXBlcmNsYXNzJyBjb25zdHJ1Y3RvciB3aXRoIHRoZSBjb3JyZWN0IGV4dGVuc2lvbiB0eXBlXG4gICAqIEBwcml2YXRlXG4gICAqIEBwYXJhbSB7c3RyaW5nfSBhcHBpdW1Ib21lIC0gYEFQUElVTV9IT01FYCBwYXRoXG4gICAqIEBwYXJhbSB7KC4uLmFyZ3M6IGFueVtdKSA9PiB2b2lkKX0gW2xvZ0ZuXSAtIE9wdGlvbmFsIGxvZ2dpbmcgZnVuY3Rpb25cbiAgICovXG4gIGNvbnN0cnVjdG9yIChhcHBpdW1Ib21lLCBsb2dGbikge1xuICAgIHN1cGVyKGFwcGl1bUhvbWUsIFBMVUdJTl9UWVBFLCBsb2dGbik7XG4gIH1cblxuICAvKipcbiAgICogQ3JlYXRlcyBvciBnZXRzIGFuIGluc3RhbmNlIG9mIHtAbGluayBQbHVnaW5Db25maWd9IGJhc2VkIHZhbHVlIG9mIGBhcHBpdW1Ib21lYFxuICAgKiBAcGFyYW0ge3N0cmluZ30gYXBwaXVtSG9tZSAtIGBBUFBJVU1fSE9NRWAgcGF0aFxuICAgKiBAcGFyYW0geyguLi5hcmdzOiBhbnlbXSkgPT4gdm9pZH0gW2xvZ0ZuXSAtIE9wdGlvbmFsIGxvZ2dpbmcgZnVuY3Rpb25cbiAgICogQHJldHVybnMge1BsdWdpbkNvbmZpZ31cbiAgICovXG4gIHN0YXRpYyBnZXRJbnN0YW5jZSAoYXBwaXVtSG9tZSwgbG9nRm4pIHtcbiAgICBjb25zdCBpbnN0YW5jZSA9IFBsdWdpbkNvbmZpZy5faW5zdGFuY2VzW2FwcGl1bUhvbWVdID8/IG5ldyBQbHVnaW5Db25maWcoYXBwaXVtSG9tZSwgbG9nRm4pO1xuICAgIFBsdWdpbkNvbmZpZy5faW5zdGFuY2VzW2FwcGl1bUhvbWVdID0gaW5zdGFuY2U7XG4gICAgcmV0dXJuIGluc3RhbmNlO1xuICB9XG5cbiAgZXh0ZW5zaW9uRGVzYyAocGx1Z2luTmFtZSwge3ZlcnNpb259KSB7XG4gICAgcmV0dXJuIGAke3BsdWdpbk5hbWV9QCR7dmVyc2lvbn1gO1xuICB9XG5cbiAgcHJpbnQgKGFjdGl2ZU5hbWVzKSB7XG4gICAgY29uc3QgcGx1Z2luTmFtZXMgPSBPYmplY3Qua2V5cyh0aGlzLmluc3RhbGxlZEV4dGVuc2lvbnMpO1xuXG4gICAgaWYgKF8uaXNFbXB0eShwbHVnaW5OYW1lcykpIHtcbiAgICAgIGxvZy5pbmZvKGBObyBwbHVnaW5zIGhhdmUgYmVlbiBpbnN0YWxsZWQuIFVzZSB0aGUgXCJhcHBpdW0gcGx1Z2luXCIgYCArXG4gICAgICAgICAgICAgICAnY29tbWFuZCB0byBpbnN0YWxsIHRoZSBvbmUocykgeW91IHdhbnQgdG8gdXNlLicpO1xuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIGxvZy5pbmZvKGBBdmFpbGFibGUgcGx1Z2luczpgKTtcbiAgICBmb3IgKGNvbnN0IFtwbHVnaW5OYW1lLCBwbHVnaW5EYXRhXSBvZiBfLnRvUGFpcnModGhpcy5pbnN0YWxsZWRFeHRlbnNpb25zKSkge1xuICAgICAgY29uc3QgYWN0aXZlVHh0ID0gXy5pbmNsdWRlcyhhY3RpdmVOYW1lcywgcGx1Z2luTmFtZSkgPyAnIChBQ1RJVkUpJyA6ICcnO1xuICAgICAgbG9nLmluZm8oYCAgLSAke3RoaXMuZXh0ZW5zaW9uRGVzYyhwbHVnaW5OYW1lLCBwbHVnaW5EYXRhKX0ke2FjdGl2ZVR4dH1gKTtcbiAgICB9XG5cbiAgICBpZiAoXy5pc0VtcHR5KGFjdGl2ZU5hbWVzKSkge1xuICAgICAgbG9nLmluZm8oJ05vIHBsdWdpbnMgYWN0aXZhdGVkLiBVc2UgdGhlIC0tdXNlLXBsdWdpbnMgZmxhZyB3aXRoIG5hbWVzIG9mIHBsdWdpbnMgdG8gYWN0aXZhdGUnKTtcbiAgICB9XG4gIH1cbn1cbiJdLCJmaWxlIjoibGliL3BsdWdpbi1jb25maWcuanMiLCJzb3VyY2VSb290IjoiLi4vLi4ifQ==
@@ -1,18 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.KNOWN_PLUGINS = void 0;
7
-
8
- require("source-map-support/register");
9
-
10
- const KNOWN_PLUGINS = {
11
- images: '@appium/images-plugin',
12
- 'execute-driver': '@appium/execute-driver-plugin',
13
- 'relaxed-caps': '@appium/relaxed-caps-plugin'
14
- };
15
- exports.KNOWN_PLUGINS = KNOWN_PLUGINS;require('source-map-support').install();
16
-
17
-
18
- //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImxpYi9wbHVnaW5zLmpzIl0sIm5hbWVzIjpbIktOT1dOX1BMVUdJTlMiLCJpbWFnZXMiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7OztBQUlBLE1BQU1BLGFBQWEsR0FBRztBQUNwQkMsRUFBQUEsTUFBTSxFQUFFLHVCQURZO0FBRXBCLG9CQUFrQiwrQkFGRTtBQUdwQixrQkFBZ0I7QUFISSxDQUF0QiIsInNvdXJjZXNDb250ZW50IjpbIi8vIFRoaXMgaXMgYSBtYXAgb2YgcGx1Z2luIG5hbWVzIHRvIG5wbSBwYWNrYWdlcyByZXByZXNlbnRpbmcgdGhvc2UgcGx1Z2lucy5cbi8vIFRoZSBwbHVnaW5zIGluIHRoaXMgbGlzdCB3aWxsIGJlIGF2YWlsYWJsZSB0byB0aGUgQ0xJIHNvIHVzZXJzIGNhbiBqdXN0XG4vLyB0eXBlICdhcHBpdW0gcGx1Z2luIGluc3RhbGwgJ25hbWUnJywgcmF0aGVyIHRoYW4gaGF2aW5nIHRvIHNwZWNpZnkgdGhlIGZ1bGxcbi8vIG5wbSBwYWNrYWdlLiBJLmUuLCB0aGVzZSBhcmUgdGhlIG9mZmljaWFsbHkgcmVjb2duaXplZCBwbHVnaW5zLlxuY29uc3QgS05PV05fUExVR0lOUyA9IHtcbiAgaW1hZ2VzOiAnQGFwcGl1bS9pbWFnZXMtcGx1Z2luJyxcbiAgJ2V4ZWN1dGUtZHJpdmVyJzogJ0BhcHBpdW0vZXhlY3V0ZS1kcml2ZXItcGx1Z2luJyxcbiAgJ3JlbGF4ZWQtY2Fwcyc6ICdAYXBwaXVtL3JlbGF4ZWQtY2Fwcy1wbHVnaW4nLFxufTtcblxuZXhwb3J0IHtcbiAgS05PV05fUExVR0lOUyxcbn07XG4iXSwiZmlsZSI6ImxpYi9wbHVnaW5zLmpzIiwic291cmNlUm9vdCI6Ii4uLy4uIn0=