appium 2.0.0-beta.39 → 2.0.0-beta.41
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.d.ts.map +1 -1
- package/build/lib/appium.js +14 -15
- package/build/lib/cli/args.d.ts +2 -5
- package/build/lib/cli/args.d.ts.map +1 -1
- package/build/lib/cli/args.js +1 -1
- package/build/lib/config-file.js +4 -4
- package/build/lib/config.d.ts +9 -2
- package/build/lib/config.d.ts.map +1 -1
- package/build/lib/config.js +12 -29
- package/build/lib/extension/extension-config.d.ts.map +1 -1
- package/build/lib/extension/extension-config.js +3 -3
- package/build/lib/extension/index.js +6 -5
- package/build/lib/extension/package-changed.js +2 -4
- package/build/lib/main.d.ts.map +1 -1
- package/build/lib/main.js +22 -17
- package/build/lib/schema/arg-spec.d.ts +5 -5
- package/build/lib/schema/arg-spec.d.ts.map +1 -1
- package/build/lib/schema/arg-spec.js +2 -2
- package/build/lib/schema/cli-args.js +5 -7
- package/build/lib/schema/schema.d.ts +3 -3
- package/build/lib/schema/schema.d.ts.map +1 -1
- package/build/lib/schema/schema.js +2 -4
- package/build/tsconfig.tsbuildinfo +1 -1
- package/build/types/cli.d.ts +4 -5
- package/build/types/cli.d.ts.map +1 -1
- package/lib/appium.js +8 -5
- package/lib/cli/args.js +1 -3
- package/lib/config.js +18 -24
- package/lib/extension/extension-config.js +4 -6
- package/lib/main.js +17 -2
- package/lib/schema/arg-spec.js +1 -1
- package/lib/schema/schema.js +1 -1
- package/package.json +24 -15
- package/scripts/autoinstall-extensions.js +11 -3
- package/test.d.ts +7 -0
- package/test.js +13 -0
- package/types/cli.ts +8 -19
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"appium.d.ts","sourceRoot":"","sources":["../../lib/appium.js"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"appium.d.ts","sourceRoot":"","sources":["../../lib/appium.js"],"names":[],"mappings":"AAkyBA;;;GAGG;AACH;IAME,cAOC;IAZD;;OAEG;IACH,MAFU,SAAS,MAAM,CAAC,CAEgB;CAU3C;6BAKY,OAAO,eAAe,EAAE,cAAc;qBACtC,OAAO,eAAe,EAAE,MAAM;0BAC9B,OAAO,eAAe,EAAE,WAAW;8BACnC,OAAO,eAAe,EAAE,eAAe;yBACvC,OAAO,eAAe,EAAE,UAAU;yBAClC,OAAO,eAAe,EAAE,UAAU;0BAClC,OAAO,eAAe,EAAE,WAAW;2BACnC,OAAO,eAAe,EAAE,YAAY;4BACpC,OAAO,eAAe,EAAE,aAAa;2BACrC,OAAO,2BAA2B,EAAE,YAAY;qBAChD,OAAO,eAAe,EAAE,MAAM;0BAC9B,OAAO,eAAe,EAAE,WAAW;yBACnC,OAAO,eAAe,EAAE,UAAU;yBAClC,OAAO,eAAe,EAAE,UAAU;6BAClC,OAAO,eAAe,EAAE,cAAc,CAAC,qBAAqB,GAAG,EAAE,CAAC,EAAC,qBAAqB,IAAI,CAAC,CAAC;;;;;;;;;;AAnyB3G;;GAEG;AACH;IAqDE;;OAEG;IACH,kBAFW,UAAU,EAwBpB;IA7ED;;;;;OAKG;IACH,UAFU,OAAO,MAAM,EAAC,cAAc,CAAC,CAEzB;IAEd;;;;;OAKG;IACH,gBAFU,OAAO,MAAM,EAAC,cAAc,EAAE,CAAC,CAErB;IASpB;;;OAGG;IACH,eAFU,IAAI,WAAW,EAAC,MAAM,CAAC,CAEnB;IAEd;;;OAGG;IACH,gBAFU,OAAO,MAAM,EAAC,aAAa,WAAW,CAAC,EAAE,CAAC,CAEhC;IAEpB;;;OAGG;IACH,oBAFU,aAAa,WAAW,CAAC,EAAE,CAEb;IAExB,2BAA2B;IAC3B,cADW,YAAY,CACV;IAEb,2BAA2B;IAC3B,QADW,YAAY,CAChB;IAEP,qEAAqD;IAErD,yBAAyB;IACzB,MADW,UAAU,CAChB;IA+CL,uCAGC;IAED,yEAEC;IAGD;;OAIC;IAGD;;;;;SAKC;IAED,+FAiBC;IAED;;;;OAIG;IACH,6BAHW,MAAM,GACJ,OAAO,MAAM,EAAC,OAAO,CAAC,CAIlC;IAED;;;;;;;;OAQG;IACH,6BAHW,MAAM,GACJ,OAAO,MAAM,EAAC,OAAO,CAAC,GAAC,SAAS,CAgB5C;IAED;;;;;;OAMG;IACH,0BALW,eAAe,WACf,eAAe,mBACf,eAAe;;;;;;;;OAuKzB;IAED;;;;OAIG;IACH,wCAHW,MAAM,kBACN,MAAM,QAsChB;IAED;;;;OAIG;IAEH,qCAJW,WAAW,GACT,QAAQ,UAAU,EAAE,CAAC,CAkBjC;IAED;;OAEG;IACH,yBAFW,MAAM;;;;;;;;OA0ChB;IAED,4CAqBC;IAED;;;;;OAKG;IACH,8BAHY,MAAM,gBAejB;IAED;;;;;;;;;OASG;IACH,wBAJW,MAAM,cACL,MAAM,gBASjB;IAED;;;OAGG;IACH,yBAFa,MAAM,EAAE,CAWpB;IAED;;;;;OAKG;IACH,oBAJW,MAAM,WACF,GAAG,kBA+HjB;IAED;;;;;;;YAwBC;IAED;;;aAoBC;IAED;;;;;;;OAwBC;IAED,qCAGC;IAED,sDAGC;IAED,kCAGC;CACF"}
|
package/build/lib/appium.js
CHANGED
|
@@ -58,9 +58,14 @@ class AppiumDriver extends _baseDriver.DriverCore {
|
|
|
58
58
|
super(opts);
|
|
59
59
|
this.args = { ...opts
|
|
60
60
|
};
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
61
|
+
|
|
62
|
+
(async () => {
|
|
63
|
+
try {
|
|
64
|
+
await (0, _config.updateBuildInfo)();
|
|
65
|
+
} catch (e) {
|
|
66
|
+
this.log.debug(`Cannot fetch Appium build info: ${e.message}`);
|
|
67
|
+
}
|
|
68
|
+
})();
|
|
64
69
|
}
|
|
65
70
|
|
|
66
71
|
get log() {
|
|
@@ -106,9 +111,9 @@ class AppiumDriver extends _baseDriver.DriverCore {
|
|
|
106
111
|
}
|
|
107
112
|
|
|
108
113
|
getCliArgsForPlugin(extName) {
|
|
109
|
-
var _this$args$plugin
|
|
114
|
+
var _this$args$plugin;
|
|
110
115
|
|
|
111
|
-
return (
|
|
116
|
+
return ((_this$args$plugin = this.args.plugin) === null || _this$args$plugin === void 0 ? void 0 : _this$args$plugin[extName]) ?? {};
|
|
112
117
|
}
|
|
113
118
|
|
|
114
119
|
getCliArgsForDriver(extName) {
|
|
@@ -127,8 +132,6 @@ class AppiumDriver extends _baseDriver.DriverCore {
|
|
|
127
132
|
}
|
|
128
133
|
|
|
129
134
|
async createSession(jsonwpCaps, reqCaps, w3cCapabilities, driverData) {
|
|
130
|
-
var _alwaysMatch, _w3cCapabilities;
|
|
131
|
-
|
|
132
135
|
const defaultCapabilities = _lodash.default.cloneDeep(this.args.defaultCapabilities);
|
|
133
136
|
|
|
134
137
|
const defaultSettings = (0, _utils.pullSettings)(defaultCapabilities);
|
|
@@ -138,12 +141,10 @@ class AppiumDriver extends _baseDriver.DriverCore {
|
|
|
138
141
|
};
|
|
139
142
|
w3cCapabilities = _lodash.default.cloneDeep(w3cCapabilities);
|
|
140
143
|
const w3cSettings = { ...jwpSettings,
|
|
141
|
-
...(0, _utils.pullSettings)((
|
|
144
|
+
...(0, _utils.pullSettings)((w3cCapabilities ?? {}).alwaysMatch ?? {})
|
|
142
145
|
};
|
|
143
146
|
|
|
144
|
-
for (const firstMatchEntry of (
|
|
145
|
-
var _firstMatch, _w3cCapabilities2;
|
|
146
|
-
|
|
147
|
+
for (const firstMatchEntry of (w3cCapabilities ?? {}).firstMatch ?? []) {
|
|
147
148
|
Object.assign(w3cSettings, (0, _utils.pullSettings)(firstMatchEntry));
|
|
148
149
|
}
|
|
149
150
|
|
|
@@ -208,9 +209,7 @@ class AppiumDriver extends _baseDriver.DriverCore {
|
|
|
208
209
|
driverInstance.serverPath = this.args.basePath;
|
|
209
210
|
|
|
210
211
|
try {
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
runningDriversData = (_await$this$curSessio = await this.curSessionDataForDriver(InnerDriver)) !== null && _await$this$curSessio !== void 0 ? _await$this$curSessio : [];
|
|
212
|
+
runningDriversData = (await this.curSessionDataForDriver(InnerDriver)) ?? [];
|
|
214
213
|
} catch (e) {
|
|
215
214
|
throw new _baseDriver.errors.SessionNotCreatedError(e.message);
|
|
216
215
|
}
|
|
@@ -582,4 +581,4 @@ class NoDriverProxyCommandError extends Error {
|
|
|
582
581
|
}
|
|
583
582
|
|
|
584
583
|
exports.NoDriverProxyCommandError = NoDriverProxyCommandError;
|
|
585
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["desiredCapabilityConstraints","Object","freeze","automationName","presence","isString","platformName","sessionsListGuard","AsyncLock","pendingDriversGuard","AppiumDriver","DriverCore","sessions","pendingDrivers","newCommandTimeoutMs","pluginClasses","sessionPlugins","sessionlessPlugins","driverConfig","server","desiredCapConstraints","args","constructor","opts","tmpDir","process","env","APPIUM_TMP_DIR","updateBuildInfo","catch","err","log","debug","_log","instanceName","name","node","getObjectId","substring","logger","getLogger","isCommandsQueueEnabled","sessionExists","sessionId","dstSession","driverForSession","getStatus","build","_","clone","getBuildInfo","getSessions","toPairs","map","id","driver","capabilities","caps","printNewSessionAnnouncement","driverName","driverVersion","driverBaseVersion","info","APPIUM_VER","baseVersion","getCliArgsForPlugin","extName","plugin","getCliArgsForDriver","allCliArgsForExt","isEmpty","defaults","getDefaultsForExtension","DRIVER_TYPE","cliArgs","omitBy","value","key","isEqual","createSession","jsonwpCaps","reqCaps","w3cCapabilities","driverData","defaultCapabilities","cloneDeep","defaultSettings","pullSettings","jwpSettings","w3cSettings","alwaysMatch","firstMatchEntry","firstMatch","assign","protocol","innerSessionId","dCaps","parsedCaps","parseCapsForInnerDriver","desiredCaps","processedJsonwpCapabilities","processedW3CCapabilities","error","InnerDriver","version","findMatchingDriver","sessionOverride","deleteAllSessions","runningDriversData","otherPendingDriversData","driverInstance","relaxedSecurityEnabled","denyInsecure","a","allowInsecure","serverHost","address","serverPort","port","serverPath","basePath","curSessionDataForDriver","e","errors","SessionNotCreatedError","message","acquire","compact","drv","push","pull","attachUnexpectedShutdownHandler","startNewCommandTimeout","isW3CProtocol","JSON","stringify","updateSettings","isMjsonwpProtocol","onShutdown","cause","Error","warn","isFunction","onUnexpectedShutdown","data","values","filter","s","datum","deleteSession","otherSessionsData","curConstructorName","sessionsCount","size","force","reason","util","pluralize","cleanupPromises","startUnexpectedShutdown","keys","cleanupPromise","pluginsForSession","createPluginInstances","pluginsToHandleCmd","cmd","p","handle","pluginInstances","PluginClass","entries","executeCommand","isGetStatus","GET_STATUS_COMMAND","isUmbrellaCmd","isAppiumDriverCommand","isSessionCmd","isSessionCommand","reqForProxy","last","pop","plugins","cmdHandledBy","default","defaultBehavior","length","proxyCommand","NoDriverProxyCommandError","originalUrl","method","body","BaseDriver","prototype","call","wrappedCmd","wrapCommandWithPlugins","next","res","executeWrappedCommand","logPluginHandlerReport","CREATE_SESSION_COMMAND","first","_next","didHandle","k","didntHandle","cmdRes","cmdErr","isPlainObject","has","proxyActive","getProxyAvoidList","canProxy","DELETE_SESSION_COMMAND","code"],"sources":["../../lib/appium.js"],"sourcesContent":["/* eslint-disable no-unused-vars */\nimport _ from 'lodash';\nimport {getBuildInfo, updateBuildInfo, APPIUM_VER} from './config';\nimport {\n  BaseDriver,\n  DriverCore,\n  errors,\n  isSessionCommand,\n  CREATE_SESSION_COMMAND,\n  DELETE_SESSION_COMMAND,\n  GET_STATUS_COMMAND,\n} from '@appium/base-driver';\nimport AsyncLock from 'async-lock';\nimport {parseCapsForInnerDriver, pullSettings} from './utils';\nimport {util, node, logger} from '@appium/support';\nimport {getDefaultsForExtension} from './schema';\nimport {DRIVER_TYPE, PLUGIN_TYPE} from './constants';\n\n/**\n * Invariant set of base constraints\n * @type {Readonly<Constraints>}\n */\nconst desiredCapabilityConstraints = Object.freeze({\n  automationName: {\n    presence: true,\n    isString: true,\n  },\n  platformName: {\n    presence: true,\n    isString: true,\n  },\n});\n\nconst sessionsListGuard = new AsyncLock();\nconst pendingDriversGuard = new AsyncLock();\n\n/**\n * @implements {SessionHandler}\n */\nclass AppiumDriver extends DriverCore {\n  /**\n   * Access to sessions list must be guarded with a Semaphore, because\n   * it might be changed by other async calls at any time\n   * It is not recommended to access this property directly from the outside\n   * @type {Record<string,ExternalDriver>}\n   */\n  sessions = {};\n\n  /**\n   * Access to pending drivers list must be guarded with a Semaphore, because\n   * it might be changed by other async calls at any time\n   * It is not recommended to access this property directly from the outside\n   * @type {Record<string,ExternalDriver[]>}\n   */\n  pendingDrivers = {};\n\n  /**\n   * Note that {@linkcode AppiumDriver} has no `newCommandTimeout` method.\n   * `AppiumDriver` does not set and observe its own timeouts; individual\n   * sessions (managed drivers) do instead.\n   */\n  newCommandTimeoutMs = 0;\n\n  /**\n   * List of active plugins\n   * @type {Map<PluginClass,string>}\n   */\n  pluginClasses;\n\n  /**\n   * map of sessions to actual plugin instances per session\n   * @type {Record<string,InstanceType<PluginClass>[]>}\n   */\n  sessionPlugins = {};\n\n  /**\n   * some commands are sessionless, so we need a set of plugins for them\n   * @type {InstanceType<PluginClass>[]}\n   */\n  sessionlessPlugins = [];\n\n  /** @type {DriverConfig} */\n  driverConfig;\n\n  /** @type {AppiumServer} */\n  server;\n\n  desiredCapConstraints = desiredCapabilityConstraints;\n\n  /** @type {DriverOpts} */\n  args;\n\n  /**\n   * @param {DriverOpts} opts\n   */\n  constructor(opts) {\n    // It is necessary to set `--tmp` here since it should be set to\n    // process.env.APPIUM_TMP_DIR once at an initial point in the Appium lifecycle.\n    // The process argument will be referenced by BaseDriver.\n    // Please call @appium/support.tempDir module to apply this benefit.\n    if (opts.tmpDir) {\n      process.env.APPIUM_TMP_DIR = opts.tmpDir;\n    }\n\n    super(opts);\n\n    this.args = {...opts};\n\n    // allow this to happen in the background, so no `await`\n    // catch this to avoid an unhandled rejection\n    // eslint-disable-next-line promise/prefer-await-to-then,promise/prefer-await-to-callbacks\n    updateBuildInfo().catch((err) => {\n      this.log.debug(err);\n    });\n  }\n\n  /**\n   * Retrieves logger instance for the current umbrella driver instance\n   */\n  get log() {\n    if (!this._log) {\n      const instanceName = `${this.constructor.name}@${node.getObjectId(this).substring(0, 4)}`;\n      this._log = logger.getLogger(instanceName);\n    }\n    return this._log;\n  }\n\n  /**\n   * Cancel commands queueing for the umbrella Appium driver\n   */\n  get isCommandsQueueEnabled() {\n    return false;\n  }\n\n  sessionExists(sessionId) {\n    const dstSession = this.sessions[sessionId];\n    return dstSession && dstSession.sessionId !== null;\n  }\n\n  driverForSession(sessionId) {\n    return this.sessions[sessionId];\n  }\n\n  // eslint-disable-next-line require-await\n  async getStatus() {\n    return {\n      build: _.clone(getBuildInfo()),\n    };\n  }\n\n  // eslint-disable-next-line require-await\n  async getSessions() {\n    return _.toPairs(this.sessions).map(([id, driver]) => ({\n      id,\n      capabilities: driver.caps,\n    }));\n  }\n\n  printNewSessionAnnouncement(driverName, driverVersion, driverBaseVersion) {\n    this.log.info(\n      driverVersion\n        ? `Appium v${APPIUM_VER} creating new ${driverName} (v${driverVersion}) session`\n        : `Appium v${APPIUM_VER} creating new ${driverName} session`\n    );\n    this.log.info(`Checking BaseDriver versions for Appium and ${driverName}`);\n    this.log.info(\n      AppiumDriver.baseVersion\n        ? `Appium's BaseDriver version is ${AppiumDriver.baseVersion}`\n        : `Could not determine Appium's BaseDriver version`\n    );\n    this.log.info(\n      driverBaseVersion\n        ? `${driverName}'s BaseDriver version is ${driverBaseVersion}`\n        : `Could not determine ${driverName}'s BaseDriver version`\n    );\n  }\n\n  /**\n   * Retrieves all CLI arguments for a specific plugin.\n   * @param {string} extName - Plugin name\n   * @returns {Record<string,unknown>} Arguments object. If none, an empty object.\n   */\n  getCliArgsForPlugin(extName) {\n    return /** @type {Record<string,unknown>} */ (this.args.plugin?.[extName] ?? {});\n  }\n\n  /**\n   * Retrieves CLI args for a specific driver.\n   *\n   * _Any arg which is equal to its default value will not be present in the returned object._\n   *\n   * _Note that this behavior currently (May 18 2022) differs from how plugins are handled_ (see {@linkcode AppiumDriver.getCliArgsForPlugin}).\n   * @param {string} extName - Driver name\n   * @returns {Record<string,unknown>|undefined} Arguments object. If none, `undefined`\n   */\n  getCliArgsForDriver(extName) {\n    const allCliArgsForExt = /** @type {Record<string,unknown>|undefined} */ (\n      this.args.driver?.[extName]\n    );\n\n    if (!_.isEmpty(allCliArgsForExt)) {\n      const defaults = getDefaultsForExtension(DRIVER_TYPE, extName);\n      const cliArgs = _.isEmpty(defaults)\n        ? allCliArgsForExt\n        : _.omitBy(allCliArgsForExt, (value, key) => _.isEqual(defaults[key], value));\n      if (!_.isEmpty(cliArgs)) {\n        return cliArgs;\n      }\n    }\n  }\n\n  /**\n   * Create a new session\n   * @param {W3CCapabilities} jsonwpCaps JSONWP formatted desired capabilities\n   * @param {W3CCapabilities} reqCaps Required capabilities (JSONWP standard)\n   * @param {W3CCapabilities} w3cCapabilities W3C capabilities\n   * @param {DriverData[]} [driverData]\n   */\n  async createSession(jsonwpCaps, reqCaps, w3cCapabilities, driverData) {\n    const defaultCapabilities = _.cloneDeep(this.args.defaultCapabilities);\n    const defaultSettings = pullSettings(defaultCapabilities);\n    jsonwpCaps = _.cloneDeep(jsonwpCaps);\n    const jwpSettings = {...defaultSettings, ...pullSettings(jsonwpCaps)};\n    w3cCapabilities = _.cloneDeep(w3cCapabilities);\n    // It is possible that the client only provides caps using JSONWP standard,\n    // although firstMatch/alwaysMatch properties are still present.\n    // In such case we assume the client understands W3C protocol and merge the given\n    // JSONWP caps to W3C caps\n    const w3cSettings = {\n      ...jwpSettings,\n      ...pullSettings((w3cCapabilities ?? {}).alwaysMatch ?? {}),\n    };\n    for (const firstMatchEntry of (w3cCapabilities ?? {}).firstMatch ?? []) {\n      Object.assign(w3cSettings, pullSettings(firstMatchEntry));\n    }\n\n    let protocol;\n    let innerSessionId, dCaps;\n    try {\n      // Parse the caps into a format that the InnerDriver will accept\n      const parsedCaps = parseCapsForInnerDriver(\n        jsonwpCaps,\n        w3cCapabilities,\n        this.desiredCapConstraints,\n        defaultCapabilities\n      );\n\n      const {desiredCaps, processedJsonwpCapabilities, processedW3CCapabilities} =\n        /** @type {import('./utils').ParsedDriverCaps} */ (parsedCaps);\n      protocol = parsedCaps.protocol;\n      const error = /** @type {import('./utils').InvalidCaps} */ (parsedCaps).error;\n      // If the parsing of the caps produced an error, throw it in here\n      if (error) {\n        throw error;\n      }\n\n      const {\n        driver: InnerDriver,\n        version: driverVersion,\n        driverName,\n      } = this.driverConfig.findMatchingDriver(desiredCaps);\n      this.printNewSessionAnnouncement(InnerDriver.name, driverVersion, InnerDriver.baseVersion);\n\n      if (this.args.sessionOverride) {\n        await this.deleteAllSessions();\n      }\n\n      /**\n       * @type {DriverData[]}\n       */\n      let runningDriversData = [];\n      /**\n       * @type {DriverData[]}\n       */\n      let otherPendingDriversData = [];\n\n      const driverInstance = new InnerDriver(this.args, true);\n\n      // We want to assign security values directly on the driver. The driver\n      // should not read security values from `this.opts` because those values\n      // could have been set by a malicious user via capabilities, whereas we\n      // want a guarantee the values were set by the appium server admin\n      if (this.args.relaxedSecurityEnabled) {\n        this.log.info(\n          `Applying relaxed security to '${InnerDriver.name}' as per ` +\n            `server command line argument. All insecure features will be ` +\n            `enabled unless explicitly disabled by --deny-insecure`\n        );\n        driverInstance.relaxedSecurityEnabled = true;\n      }\n\n      if (!_.isEmpty(this.args.denyInsecure)) {\n        this.log.info('Explicitly preventing use of insecure features:');\n        this.args.denyInsecure.map((a) => this.log.info(`    ${a}`));\n        driverInstance.denyInsecure = this.args.denyInsecure;\n      }\n\n      if (!_.isEmpty(this.args.allowInsecure)) {\n        this.log.info('Explicitly enabling use of insecure features:');\n        this.args.allowInsecure.map((a) => this.log.info(`    ${a}`));\n        driverInstance.allowInsecure = this.args.allowInsecure;\n      }\n\n      // Likewise, any driver-specific CLI args that were passed in should be assigned directly to\n      // the driver so that they cannot be mimicked by a malicious user sending in capabilities\n      const cliArgs = this.getCliArgsForDriver(driverName);\n      if (!_.isEmpty(cliArgs)) {\n        driverInstance.cliArgs = cliArgs;\n      }\n\n      // This assignment is required for correct web sockets functionality inside the driver\n      // Drivers/plugins might also want to know where they are hosted\n\n      // XXX: temporary hack to work around #16747\n      driverInstance.server = this.server;\n      driverInstance.serverHost = this.args.address;\n      driverInstance.serverPort = this.args.port;\n      driverInstance.serverPath = this.args.basePath;\n\n      try {\n        runningDriversData = (await this.curSessionDataForDriver(InnerDriver)) ?? [];\n      } catch (e) {\n        throw new errors.SessionNotCreatedError(e.message);\n      }\n      await pendingDriversGuard.acquire(AppiumDriver.name, () => {\n        this.pendingDrivers[InnerDriver.name] = this.pendingDrivers[InnerDriver.name] || [];\n        otherPendingDriversData = _.compact(\n          this.pendingDrivers[InnerDriver.name].map((drv) => drv.driverData)\n        );\n        this.pendingDrivers[InnerDriver.name].push(driverInstance);\n      });\n\n      try {\n        [innerSessionId, dCaps] = await driverInstance.createSession(\n          processedJsonwpCapabilities,\n          reqCaps,\n          processedW3CCapabilities,\n          [...runningDriversData, ...otherPendingDriversData]\n        );\n        protocol = driverInstance.protocol;\n        this.sessions[innerSessionId] = driverInstance;\n      } finally {\n        await pendingDriversGuard.acquire(AppiumDriver.name, () => {\n          _.pull(this.pendingDrivers[InnerDriver.name], driverInstance);\n        });\n      }\n\n      this.attachUnexpectedShutdownHandler(driverInstance, innerSessionId);\n\n      this.log.info(\n        `New ${InnerDriver.name} session created successfully, session ` +\n          `${innerSessionId} added to master session list`\n      );\n\n      // set the New Command Timeout for the inner driver\n      driverInstance.startNewCommandTimeout();\n\n      // apply initial values to Appium settings (if provided)\n      if (driverInstance.isW3CProtocol() && !_.isEmpty(w3cSettings)) {\n        this.log.info(\n          `Applying the initial values to Appium settings parsed from W3C caps: ` +\n            JSON.stringify(w3cSettings)\n        );\n        await driverInstance.updateSettings(w3cSettings);\n      } else if (driverInstance.isMjsonwpProtocol() && !_.isEmpty(jwpSettings)) {\n        this.log.info(\n          `Applying the initial values to Appium settings parsed from MJSONWP caps: ` +\n            JSON.stringify(jwpSettings)\n        );\n        await driverInstance.updateSettings(jwpSettings);\n      }\n    } catch (error) {\n      return {\n        protocol,\n        error,\n      };\n    }\n\n    return {\n      protocol,\n      value: [innerSessionId, dCaps, protocol],\n    };\n  }\n\n  /**\n   *\n   * @param {Driver} driver\n   * @param {string} innerSessionId\n   */\n  attachUnexpectedShutdownHandler(driver, innerSessionId) {\n    const onShutdown = (cause = new Error('Unknown error')) => {\n      this.log.warn(`Ending session, cause was '${cause.message}'`);\n\n      if (this.sessionPlugins[innerSessionId]) {\n        for (const plugin of this.sessionPlugins[innerSessionId]) {\n          if (_.isFunction(plugin.onUnexpectedShutdown)) {\n            this.log.debug(\n              `Plugin ${plugin.name} defines an unexpected shutdown handler; calling it now`\n            );\n            try {\n              plugin.onUnexpectedShutdown(driver, cause);\n            } catch (e) {\n              this.log.warn(\n                `Got an error when running plugin ${plugin.name} shutdown handler: ${e}`\n              );\n            }\n          } else {\n            this.log.debug(`Plugin ${plugin.name} does not define an unexpected shutdown handler`);\n          }\n        }\n      }\n\n      this.log.info(`Removing session '${innerSessionId}' from our master session list`);\n      delete this.sessions[innerSessionId];\n      delete this.sessionPlugins[innerSessionId];\n    };\n\n    if (_.isFunction(driver.onUnexpectedShutdown)) {\n      driver.onUnexpectedShutdown(onShutdown);\n    } else {\n      this.log.warn(\n        `Failed to attach the unexpected shutdown listener. ` +\n          `Is 'onUnexpectedShutdown' method available for '${driver.constructor.name}'?`\n      );\n    }\n  }\n\n  /**\n   *\n   * @param {DriverClass} InnerDriver\n   * @returns {Promise<DriverData[]>}}\n   */\n  // eslint-disable-next-line require-await\n  async curSessionDataForDriver(InnerDriver) {\n    const data = _.compact(\n      _.values(this.sessions)\n        .filter((s) => s.constructor.name === InnerDriver.name)\n        .map((s) => s.driverData)\n    );\n    for (const datum of data) {\n      if (!datum) {\n        throw new Error(\n          `Problem getting session data for driver type ` +\n            `${InnerDriver.name}; does it implement 'get driverData'?`\n        );\n      }\n    }\n    return data;\n  }\n\n  /**\n   * @param {string} sessionId\n   */\n  async deleteSession(sessionId) {\n    let protocol;\n    try {\n      let otherSessionsData;\n      const dstSession = await sessionsListGuard.acquire(AppiumDriver.name, () => {\n        if (!this.sessions[sessionId]) {\n          return;\n        }\n        const curConstructorName = this.sessions[sessionId].constructor.name;\n        otherSessionsData = _.toPairs(this.sessions)\n          .filter(\n            ([key, value]) => value.constructor.name === curConstructorName && key !== sessionId\n          )\n          .map(([, value]) => value.driverData);\n        const dstSession = this.sessions[sessionId];\n        protocol = dstSession.protocol;\n        this.log.info(`Removing session ${sessionId} from our master session list`);\n        // regardless of whether the deleteSession completes successfully or not\n        // make the session unavailable, because who knows what state it might\n        // be in otherwise\n        delete this.sessions[sessionId];\n        delete this.sessionPlugins[sessionId];\n        return dstSession;\n      });\n      // this may not be correct, but if `dstSession` was falsy, the call to `deleteSession()` would\n      // throw anyway.\n      if (!dstSession) {\n        throw new Error('Session not found');\n      }\n      return {\n        protocol,\n        value: await dstSession.deleteSession(sessionId, otherSessionsData),\n      };\n    } catch (e) {\n      this.log.error(`Had trouble ending session ${sessionId}: ${e.message}`);\n      return {\n        protocol,\n        error: e,\n      };\n    }\n  }\n\n  async deleteAllSessions(opts = {}) {\n    const sessionsCount = _.size(this.sessions);\n    if (0 === sessionsCount) {\n      this.log.debug('There are no active sessions for cleanup');\n      return;\n    }\n\n    const {force = false, reason} = opts;\n    this.log.debug(`Cleaning up ${util.pluralize('active session', sessionsCount, true)}`);\n    const cleanupPromises = force\n      ? _.values(this.sessions).map((drv) =>\n          drv.startUnexpectedShutdown(reason && new Error(reason))\n        )\n      : _.keys(this.sessions).map((id) => this.deleteSession(id));\n    for (const cleanupPromise of cleanupPromises) {\n      try {\n        await cleanupPromise;\n      } catch (e) {\n        this.log.debug(e);\n      }\n    }\n  }\n\n  /**\n   * Get the appropriate plugins for a session (or sessionless plugins)\n   *\n   * @param {?string} sessionId - the sessionId (or null) to use to find plugins\n   * @returns {Array} - array of plugin instances\n   */\n  pluginsForSession(sessionId = null) {\n    if (sessionId) {\n      if (!this.sessionPlugins[sessionId]) {\n        this.sessionPlugins[sessionId] = this.createPluginInstances();\n      }\n      return this.sessionPlugins[sessionId];\n    }\n\n    if (_.isEmpty(this.sessionlessPlugins)) {\n      this.sessionlessPlugins = this.createPluginInstances();\n    }\n    return this.sessionlessPlugins;\n  }\n\n  /**\n   * To get plugins for a command, we either get the plugin instances associated with the\n   * particular command's session, or in the case of sessionless plugins, pull from the set of\n   * plugin instances reserved for sessionless commands (and we lazily create plugin instances on\n   * first use)\n   *\n   * @param {string} cmd - the name of the command to find a plugin to handle\n   * @param {?string} sessionId - the particular session for which to find a plugin, or null if\n   * sessionless\n   */\n  pluginsToHandleCmd(cmd, sessionId = null) {\n    // to handle a given command, a plugin should either implement that command as a plugin\n    // instance method or it should implement a generic 'handle' method\n    return this.pluginsForSession(sessionId).filter(\n      (p) => _.isFunction(p[cmd]) || _.isFunction(p.handle)\n    );\n  }\n\n  /**\n   * Creates instances of all of the enabled Plugin classes\n   * @returns {Plugin[]}\n   */\n  createPluginInstances() {\n    /** @type {Plugin[]} */\n    const pluginInstances = [];\n    for (const [PluginClass, name] of this.pluginClasses.entries()) {\n      const cliArgs = this.getCliArgsForPlugin(name);\n      const plugin = new PluginClass(name, cliArgs);\n      pluginInstances.push(plugin);\n    }\n    return pluginInstances;\n  }\n\n  /**\n   *\n   * @param {string} cmd\n   * @param  {...any} args\n   * @returns {Promise<{value: any, error?: Error, protocol: string} | import('type-fest').AsyncReturnType<Driver['executeCommand']>>}\n   */\n  async executeCommand(cmd, ...args) {\n    // We have basically three cases for how to handle commands:\n    // 1. handle getStatus (we do this as a special out of band case so it doesn't get added to an\n    //    execution queue, and can be called while e.g. createSession is in progress)\n    // 2. handle commands that this umbrella driver should handle, rather than the actual session\n    //    driver (for example, deleteSession, or other non-session commands)\n    // 3. handle session driver commands.\n    // The tricky part is that because we support command plugins, we need to wrap any of these\n    // cases with plugin handling.\n\n    const isGetStatus = cmd === GET_STATUS_COMMAND;\n    const isUmbrellaCmd = isAppiumDriverCommand(cmd);\n    const isSessionCmd = isSessionCommand(cmd);\n\n    // if a plugin override proxying for this command and that is why we are here instead of just\n    // letting the protocol proxy the command entirely, determine that, get the request object for\n    // use later on, then clean up the args\n    const reqForProxy = _.last(args)?.reqForProxy;\n    if (reqForProxy) {\n      args.pop();\n    }\n\n    // first do some error checking. If we're requesting a session command execution, then make\n    // sure that session actually exists on the session driver, and set the session driver itself\n    let sessionId = null;\n    let dstSession = null;\n    let protocol = null;\n    /** @type {this | ExternalDriver} */\n    let driver = this;\n    if (isSessionCmd) {\n      sessionId = _.last(args);\n      dstSession = this.sessions[sessionId];\n      if (!dstSession) {\n        throw new Error(`The session with id '${sessionId}' does not exist`);\n      }\n      // now save the response protocol given that the session driver's protocol might differ\n      protocol = dstSession.protocol;\n      if (!isUmbrellaCmd) {\n        driver = dstSession;\n      }\n    }\n\n    // get any plugins which are registered as handling this command\n    const plugins = this.pluginsToHandleCmd(cmd, sessionId);\n\n    // now we define a 'cmdHandledBy' object which will keep track of which plugins have handled this\n    // command. we care about this because (a) multiple plugins can handle the same command, and\n    // (b) there's no guarantee that a plugin will actually call the next() method which runs the\n    // original command execution. This results in a situation where the command might be handled\n    // by some but not all plugins, or by plugin(s) but not by the default behavior. So start out\n    // this object declaring that the default handler has not been executed.\n    const cmdHandledBy = {default: false};\n\n    // now we define an async function which will be passed to plugins, and successively wrapped\n    // if there is more than one plugin that can handle the command. To start off with, the async\n    // function is defined as calling the default behavior, i.e., whichever of the 3 cases above is\n    // the appropriate one\n    const defaultBehavior = async () => {\n      // if we're running with plugins, make sure we log that the default behavior is actually\n      // happening so we can tell when the plugin call chain is unwrapping to the default behavior\n      // if that's what happens\n      plugins.length && this.log.info(`Executing default handling behavior for command '${cmd}'`);\n\n      // if we make it here, we know that the default behavior is handled\n      cmdHandledBy.default = true;\n\n      if (reqForProxy) {\n        // we would have proxied this command had a plugin not handled it, so the default behavior\n        // is to do the proxy and retrieve the result internally so it can be passed to the plugin\n        // in case it calls 'await next()'. This requires that the driver have defined\n        // 'proxyCommand' and not just 'proxyReqRes'.\n        if (!dstSession.proxyCommand) {\n          throw new NoDriverProxyCommandError();\n        }\n        return await dstSession.proxyCommand(\n          reqForProxy.originalUrl,\n          reqForProxy.method,\n          reqForProxy.body\n        );\n      }\n\n      if (isGetStatus) {\n        return await this.getStatus();\n      }\n\n      if (isUmbrellaCmd) {\n        // some commands, like deleteSession, we want to make sure to handle on *this* driver,\n        // not the platform driver\n        return await BaseDriver.prototype.executeCommand.call(this, cmd, ...args);\n      }\n\n      // here we know that we are executing a session command, and have a valid session driver\n      return await dstSession.executeCommand(cmd, ...args);\n    };\n\n    // now take our default behavior, wrap it with any number of plugin behaviors, and run it\n    const wrappedCmd = this.wrapCommandWithPlugins({\n      driver,\n      cmd,\n      args,\n      plugins,\n      cmdHandledBy,\n      next: defaultBehavior,\n    });\n    const res = await this.executeWrappedCommand({wrappedCmd, protocol});\n\n    // if we had plugins, make sure to log out the helpful report about which plugins ended up\n    // handling the command and which didn't\n    this.logPluginHandlerReport(plugins, {cmd, cmdHandledBy});\n\n    // And finally, if the command was createSession, we want to migrate any plugins which were\n    // previously sessionless to use the new sessionId, so that plugins can share state between\n    // their createSession method and other instance methods\n    if (cmd === CREATE_SESSION_COMMAND && this.sessionlessPlugins.length && !res.error) {\n      const sessionId = _.first(res.value);\n      this.log.info(\n        `Promoting ${this.sessionlessPlugins.length} sessionless plugins to be attached ` +\n          `to session ID ${sessionId}`\n      );\n      this.sessionPlugins[sessionId] = this.sessionlessPlugins;\n      this.sessionlessPlugins = [];\n    }\n\n    return res;\n  }\n\n  wrapCommandWithPlugins({driver, cmd, args, next, cmdHandledBy, plugins}) {\n    plugins.length &&\n      this.log.info(`Plugins which can handle cmd '${cmd}': ${plugins.map((p) => p.name)}`);\n\n    // now we can go through each plugin and wrap `next` around its own handler, passing the *old*\n    // next in so that it can call it if it wants to\n    for (const plugin of plugins) {\n      // need an IIFE here because we want the value of next that's passed to plugin.handle to be\n      // exactly the value of next here before reassignment; we don't want it to be lazily\n      // evaluated, otherwise we end up with infinite recursion of the last `next` to be defined.\n      cmdHandledBy[plugin.name] = false; // we see a new plugin, so add it to the 'cmdHandledBy' object\n      next = ((_next) => async () => {\n        this.log.info(`Plugin ${plugin.name} is now handling cmd '${cmd}'`);\n        cmdHandledBy[plugin.name] = true; // if we make it here, this plugin has attempted to handle cmd\n        // first attempt to handle the command via a command-specific handler on the plugin\n        if (plugin[cmd]) {\n          return await plugin[cmd](_next, driver, ...args);\n        }\n        // otherwise, call the generic 'handle' method\n        return await plugin.handle(_next, driver, cmd, ...args);\n      })(next);\n    }\n\n    return next;\n  }\n\n  logPluginHandlerReport(plugins, {cmd, cmdHandledBy}) {\n    if (!plugins.length) {\n      return;\n    }\n\n    // at the end of the day, we have an object representing which plugins ended up getting\n    // their code run as part of handling this command. Because plugins can choose *not* to\n    // pass control to other plugins or to the default driver behavior, this is information\n    // which is probably useful to the user (especially in situations where plugins might not\n    // interact well together, and it would be hard to debug otherwise without this kind of\n    // message).\n    const didHandle = Object.keys(cmdHandledBy).filter((k) => cmdHandledBy[k]);\n    const didntHandle = Object.keys(cmdHandledBy).filter((k) => !cmdHandledBy[k]);\n    if (didntHandle.length > 0) {\n      this.log.info(\n        `Command '${cmd}' was *not* handled by the following behaviours or plugins, even ` +\n          `though they were registered to handle it: ${JSON.stringify(didntHandle)}. The ` +\n          `command *was* handled by these: ${JSON.stringify(didHandle)}.`\n      );\n    }\n  }\n\n  async executeWrappedCommand({wrappedCmd, protocol}) {\n    let cmdRes,\n      cmdErr,\n      res = {};\n    try {\n      // At this point, `wrappedCmd` defines a whole sequence of plugin handlers, culminating in\n      // our default handler. Whatever it returns is what we're going to want to send back to the\n      // user.\n      cmdRes = await wrappedCmd();\n    } catch (e) {\n      cmdErr = e;\n    }\n\n    // Sadly, we don't know exactly what kind of object will be returned. It will either be a bare\n    // object, or a protocol-aware object with protocol and error/value keys. So we need to sniff\n    // it and make sure we don't double-wrap it if it's the latter kind.\n    if (_.isPlainObject(cmdRes) && _.has(cmdRes, 'protocol')) {\n      res = cmdRes;\n    } else {\n      res.value = cmdRes;\n      res.error = cmdErr;\n      res.protocol = protocol;\n    }\n    return res;\n  }\n\n  proxyActive(sessionId) {\n    const dstSession = this.sessions[sessionId];\n    return dstSession && _.isFunction(dstSession.proxyActive) && dstSession.proxyActive(sessionId);\n  }\n\n  getProxyAvoidList(sessionId) {\n    const dstSession = this.sessions[sessionId];\n    return dstSession ? dstSession.getProxyAvoidList() : [];\n  }\n\n  canProxy(sessionId) {\n    const dstSession = this.sessions[sessionId];\n    return dstSession && dstSession.canProxy(sessionId);\n  }\n}\n\n// help decide which commands should be proxied to sub-drivers and which\n// should be handled by this, our umbrella driver\nfunction isAppiumDriverCommand(cmd) {\n  return !isSessionCommand(cmd) || cmd === DELETE_SESSION_COMMAND;\n}\n\n/**\n * Thrown when Appium tried to proxy a command using a driver's `proxyCommand` method but the\n * method did not exist\n */\nexport class NoDriverProxyCommandError extends Error {\n  /**\n   * @type {Readonly<string>}\n   */\n  code = 'APPIUMERR_NO_DRIVER_PROXYCOMMAND';\n\n  constructor() {\n    super(\n      `The default behavior for this command was to proxy, but the driver ` +\n        `did not have the 'proxyCommand' method defined. To fully support ` +\n        `plugins, drivers should have 'proxyCommand' set to a jwpProxy object's ` +\n        `'command()' method, in addition to the normal 'proxyReqRes'`\n    );\n  }\n}\n\nexport {AppiumDriver};\n\n/**\n * @typedef {import('@appium/types').ExternalDriver} ExternalDriver\n * @typedef {import('@appium/types').Driver} Driver\n * @typedef {import('@appium/types').DriverClass} DriverClass\n * @typedef {import('@appium/types').W3CCapabilities} W3CCapabilities\n * @typedef {import('@appium/types').DriverData} DriverData\n * @typedef {import('@appium/types').ServerArgs} DriverOpts\n * @typedef {import('@appium/types').Constraints} Constraints\n * @typedef {import('@appium/types').AppiumServer} AppiumServer\n * @typedef {import('@appium/types').ExtensionType} ExtensionType\n * @typedef {import('./extension/driver-config').DriverConfig} DriverConfig\n * @typedef {import('@appium/types').Plugin} Plugin\n * @typedef {import('@appium/types').PluginClass} PluginClass\n * @typedef {import('@appium/types').PluginType} PluginType\n * @typedef {import('@appium/types').DriverType} DriverType\n * @typedef {import('@appium/types').SessionHandler<SessionHandlerResult<any[]>,SessionHandlerResult<void>>} SessionHandler\n */\n\n/**\n * Used by {@linkcode AppiumDriver.createSession} and {@linkcode AppiumDriver.deleteSession} to describe\n * result.\n * @template V\n * @typedef SessionHandlerResult\n * @property {V} [value]\n * @property {Error} [error]\n * @property {string} [protocol]\n */\n"],"mappings":"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"}
|
|
584
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["desiredCapabilityConstraints","Object","freeze","automationName","presence","isString","platformName","sessionsListGuard","AsyncLock","pendingDriversGuard","AppiumDriver","DriverCore","sessions","pendingDrivers","newCommandTimeoutMs","pluginClasses","sessionPlugins","sessionlessPlugins","driverConfig","server","desiredCapConstraints","args","constructor","opts","tmpDir","process","env","APPIUM_TMP_DIR","updateBuildInfo","e","log","debug","message","_log","instanceName","name","node","getObjectId","substring","logger","getLogger","isCommandsQueueEnabled","sessionExists","sessionId","dstSession","driverForSession","getStatus","build","_","clone","getBuildInfo","getSessions","toPairs","map","id","driver","capabilities","caps","printNewSessionAnnouncement","driverName","driverVersion","driverBaseVersion","info","APPIUM_VER","baseVersion","getCliArgsForPlugin","extName","plugin","getCliArgsForDriver","allCliArgsForExt","isEmpty","defaults","getDefaultsForExtension","DRIVER_TYPE","cliArgs","omitBy","value","key","isEqual","createSession","jsonwpCaps","reqCaps","w3cCapabilities","driverData","defaultCapabilities","cloneDeep","defaultSettings","pullSettings","jwpSettings","w3cSettings","alwaysMatch","firstMatchEntry","firstMatch","assign","protocol","innerSessionId","dCaps","parsedCaps","parseCapsForInnerDriver","desiredCaps","processedJsonwpCapabilities","processedW3CCapabilities","error","InnerDriver","version","findMatchingDriver","sessionOverride","deleteAllSessions","runningDriversData","otherPendingDriversData","driverInstance","relaxedSecurityEnabled","denyInsecure","a","allowInsecure","serverHost","address","serverPort","port","serverPath","basePath","curSessionDataForDriver","errors","SessionNotCreatedError","acquire","compact","drv","push","pull","attachUnexpectedShutdownHandler","startNewCommandTimeout","isW3CProtocol","JSON","stringify","updateSettings","isMjsonwpProtocol","onShutdown","cause","Error","warn","isFunction","onUnexpectedShutdown","data","values","filter","s","datum","deleteSession","otherSessionsData","curConstructorName","sessionsCount","size","force","reason","util","pluralize","cleanupPromises","startUnexpectedShutdown","keys","cleanupPromise","pluginsForSession","createPluginInstances","pluginsToHandleCmd","cmd","p","handle","pluginInstances","PluginClass","entries","executeCommand","isGetStatus","GET_STATUS_COMMAND","isUmbrellaCmd","isAppiumDriverCommand","isSessionCmd","isSessionCommand","reqForProxy","last","pop","plugins","cmdHandledBy","default","defaultBehavior","length","proxyCommand","NoDriverProxyCommandError","originalUrl","method","body","BaseDriver","prototype","call","wrappedCmd","wrapCommandWithPlugins","next","res","executeWrappedCommand","logPluginHandlerReport","CREATE_SESSION_COMMAND","first","_next","didHandle","k","didntHandle","cmdRes","cmdErr","isPlainObject","has","proxyActive","getProxyAvoidList","canProxy","DELETE_SESSION_COMMAND","code"],"sources":["../../lib/appium.js"],"sourcesContent":["/* eslint-disable no-unused-vars */\nimport _ from 'lodash';\nimport {getBuildInfo, updateBuildInfo, APPIUM_VER} from './config';\nimport {\n  BaseDriver,\n  DriverCore,\n  errors,\n  isSessionCommand,\n  CREATE_SESSION_COMMAND,\n  DELETE_SESSION_COMMAND,\n  GET_STATUS_COMMAND,\n} from '@appium/base-driver';\nimport AsyncLock from 'async-lock';\nimport {parseCapsForInnerDriver, pullSettings} from './utils';\nimport {util, node, logger} from '@appium/support';\nimport {getDefaultsForExtension} from './schema';\nimport {DRIVER_TYPE, PLUGIN_TYPE} from './constants';\n\n/**\n * Invariant set of base constraints\n * @type {Readonly<Constraints>}\n */\nconst desiredCapabilityConstraints = Object.freeze({\n  automationName: {\n    presence: true,\n    isString: true,\n  },\n  platformName: {\n    presence: true,\n    isString: true,\n  },\n});\n\nconst sessionsListGuard = new AsyncLock();\nconst pendingDriversGuard = new AsyncLock();\n\n/**\n * @implements {SessionHandler}\n */\nclass AppiumDriver extends DriverCore {\n  /**\n   * Access to sessions list must be guarded with a Semaphore, because\n   * it might be changed by other async calls at any time\n   * It is not recommended to access this property directly from the outside\n   * @type {Record<string,ExternalDriver>}\n   */\n  sessions = {};\n\n  /**\n   * Access to pending drivers list must be guarded with a Semaphore, because\n   * it might be changed by other async calls at any time\n   * It is not recommended to access this property directly from the outside\n   * @type {Record<string,ExternalDriver[]>}\n   */\n  pendingDrivers = {};\n\n  /**\n   * Note that {@linkcode AppiumDriver} has no `newCommandTimeout` method.\n   * `AppiumDriver` does not set and observe its own timeouts; individual\n   * sessions (managed drivers) do instead.\n   */\n  newCommandTimeoutMs = 0;\n\n  /**\n   * List of active plugins\n   * @type {Map<PluginClass,string>}\n   */\n  pluginClasses;\n\n  /**\n   * map of sessions to actual plugin instances per session\n   * @type {Record<string,InstanceType<PluginClass>[]>}\n   */\n  sessionPlugins = {};\n\n  /**\n   * some commands are sessionless, so we need a set of plugins for them\n   * @type {InstanceType<PluginClass>[]}\n   */\n  sessionlessPlugins = [];\n\n  /** @type {DriverConfig} */\n  driverConfig;\n\n  /** @type {AppiumServer} */\n  server;\n\n  desiredCapConstraints = desiredCapabilityConstraints;\n\n  /** @type {DriverOpts} */\n  args;\n\n  /**\n   * @param {DriverOpts} opts\n   */\n  constructor(opts) {\n    // It is necessary to set `--tmp` here since it should be set to\n    // process.env.APPIUM_TMP_DIR once at an initial point in the Appium lifecycle.\n    // The process argument will be referenced by BaseDriver.\n    // Please call @appium/support.tempDir module to apply this benefit.\n    if (opts.tmpDir) {\n      process.env.APPIUM_TMP_DIR = opts.tmpDir;\n    }\n\n    super(opts);\n\n    this.args = {...opts};\n\n    // allow this to happen in the background, so no `await`\n    (async () => {\n      try {\n        await updateBuildInfo();\n      } catch (e) {\n        // make sure we catch any possible errors to avoid unhandled rejections\n        this.log.debug(`Cannot fetch Appium build info: ${e.message}`);\n      }\n    })();\n  }\n\n  /**\n   * Retrieves logger instance for the current umbrella driver instance\n   */\n  get log() {\n    if (!this._log) {\n      const instanceName = `${this.constructor.name}@${node.getObjectId(this).substring(0, 4)}`;\n      this._log = logger.getLogger(instanceName);\n    }\n    return this._log;\n  }\n\n  /**\n   * Cancel commands queueing for the umbrella Appium driver\n   */\n  get isCommandsQueueEnabled() {\n    return false;\n  }\n\n  sessionExists(sessionId) {\n    const dstSession = this.sessions[sessionId];\n    return dstSession && dstSession.sessionId !== null;\n  }\n\n  driverForSession(sessionId) {\n    return this.sessions[sessionId];\n  }\n\n  // eslint-disable-next-line require-await\n  async getStatus() {\n    return {\n      build: _.clone(getBuildInfo()),\n    };\n  }\n\n  // eslint-disable-next-line require-await\n  async getSessions() {\n    return _.toPairs(this.sessions).map(([id, driver]) => ({\n      id,\n      capabilities: driver.caps,\n    }));\n  }\n\n  printNewSessionAnnouncement(driverName, driverVersion, driverBaseVersion) {\n    this.log.info(\n      driverVersion\n        ? `Appium v${APPIUM_VER} creating new ${driverName} (v${driverVersion}) session`\n        : `Appium v${APPIUM_VER} creating new ${driverName} session`\n    );\n    this.log.info(`Checking BaseDriver versions for Appium and ${driverName}`);\n    this.log.info(\n      AppiumDriver.baseVersion\n        ? `Appium's BaseDriver version is ${AppiumDriver.baseVersion}`\n        : `Could not determine Appium's BaseDriver version`\n    );\n    this.log.info(\n      driverBaseVersion\n        ? `${driverName}'s BaseDriver version is ${driverBaseVersion}`\n        : `Could not determine ${driverName}'s BaseDriver version`\n    );\n  }\n\n  /**\n   * Retrieves all CLI arguments for a specific plugin.\n   * @param {string} extName - Plugin name\n   * @returns {Record<string,unknown>} Arguments object. If none, an empty object.\n   */\n  getCliArgsForPlugin(extName) {\n    return /** @type {Record<string,unknown>} */ (this.args.plugin?.[extName] ?? {});\n  }\n\n  /**\n   * Retrieves CLI args for a specific driver.\n   *\n   * _Any arg which is equal to its default value will not be present in the returned object._\n   *\n   * _Note that this behavior currently (May 18 2022) differs from how plugins are handled_ (see {@linkcode AppiumDriver.getCliArgsForPlugin}).\n   * @param {string} extName - Driver name\n   * @returns {Record<string,unknown>|undefined} Arguments object. If none, `undefined`\n   */\n  getCliArgsForDriver(extName) {\n    const allCliArgsForExt = /** @type {Record<string,unknown>|undefined} */ (\n      this.args.driver?.[extName]\n    );\n\n    if (!_.isEmpty(allCliArgsForExt)) {\n      const defaults = getDefaultsForExtension(DRIVER_TYPE, extName);\n      const cliArgs = _.isEmpty(defaults)\n        ? allCliArgsForExt\n        : _.omitBy(allCliArgsForExt, (value, key) => _.isEqual(defaults[key], value));\n      if (!_.isEmpty(cliArgs)) {\n        return cliArgs;\n      }\n    }\n  }\n\n  /**\n   * Create a new session\n   * @param {W3CCapabilities} jsonwpCaps JSONWP formatted desired capabilities\n   * @param {W3CCapabilities} reqCaps Required capabilities (JSONWP standard)\n   * @param {W3CCapabilities} w3cCapabilities W3C capabilities\n   * @param {DriverData[]} [driverData]\n   */\n  async createSession(jsonwpCaps, reqCaps, w3cCapabilities, driverData) {\n    const defaultCapabilities = _.cloneDeep(this.args.defaultCapabilities);\n    const defaultSettings = pullSettings(defaultCapabilities);\n    jsonwpCaps = _.cloneDeep(jsonwpCaps);\n    const jwpSettings = {...defaultSettings, ...pullSettings(jsonwpCaps)};\n    w3cCapabilities = _.cloneDeep(w3cCapabilities);\n    // It is possible that the client only provides caps using JSONWP standard,\n    // although firstMatch/alwaysMatch properties are still present.\n    // In such case we assume the client understands W3C protocol and merge the given\n    // JSONWP caps to W3C caps\n    const w3cSettings = {\n      ...jwpSettings,\n      ...pullSettings((w3cCapabilities ?? {}).alwaysMatch ?? {}),\n    };\n    for (const firstMatchEntry of (w3cCapabilities ?? {}).firstMatch ?? []) {\n      Object.assign(w3cSettings, pullSettings(firstMatchEntry));\n    }\n\n    let protocol;\n    let innerSessionId, dCaps;\n    try {\n      // Parse the caps into a format that the InnerDriver will accept\n      const parsedCaps = parseCapsForInnerDriver(\n        jsonwpCaps,\n        w3cCapabilities,\n        this.desiredCapConstraints,\n        defaultCapabilities\n      );\n\n      const {desiredCaps, processedJsonwpCapabilities, processedW3CCapabilities} =\n        /** @type {import('./utils').ParsedDriverCaps} */ (parsedCaps);\n      protocol = parsedCaps.protocol;\n      const error = /** @type {import('./utils').InvalidCaps} */ (parsedCaps).error;\n      // If the parsing of the caps produced an error, throw it in here\n      if (error) {\n        throw error;\n      }\n\n      const {\n        driver: InnerDriver,\n        version: driverVersion,\n        driverName,\n      } = this.driverConfig.findMatchingDriver(desiredCaps);\n      this.printNewSessionAnnouncement(InnerDriver.name, driverVersion, InnerDriver.baseVersion);\n\n      if (this.args.sessionOverride) {\n        await this.deleteAllSessions();\n      }\n\n      /**\n       * @type {DriverData[]}\n       */\n      let runningDriversData = [];\n      /**\n       * @type {DriverData[]}\n       */\n      let otherPendingDriversData = [];\n\n      const driverInstance = new InnerDriver(this.args, true);\n\n      // We want to assign security values directly on the driver. The driver\n      // should not read security values from `this.opts` because those values\n      // could have been set by a malicious user via capabilities, whereas we\n      // want a guarantee the values were set by the appium server admin\n      if (this.args.relaxedSecurityEnabled) {\n        this.log.info(\n          `Applying relaxed security to '${InnerDriver.name}' as per ` +\n            `server command line argument. All insecure features will be ` +\n            `enabled unless explicitly disabled by --deny-insecure`\n        );\n        driverInstance.relaxedSecurityEnabled = true;\n      }\n\n      if (!_.isEmpty(this.args.denyInsecure)) {\n        this.log.info('Explicitly preventing use of insecure features:');\n        this.args.denyInsecure.map((a) => this.log.info(`    ${a}`));\n        driverInstance.denyInsecure = this.args.denyInsecure;\n      }\n\n      if (!_.isEmpty(this.args.allowInsecure)) {\n        this.log.info('Explicitly enabling use of insecure features:');\n        this.args.allowInsecure.map((a) => this.log.info(`    ${a}`));\n        driverInstance.allowInsecure = this.args.allowInsecure;\n      }\n\n      // Likewise, any driver-specific CLI args that were passed in should be assigned directly to\n      // the driver so that they cannot be mimicked by a malicious user sending in capabilities\n      const cliArgs = this.getCliArgsForDriver(driverName);\n      if (!_.isEmpty(cliArgs)) {\n        driverInstance.cliArgs = cliArgs;\n      }\n\n      // This assignment is required for correct web sockets functionality inside the driver\n      // Drivers/plugins might also want to know where they are hosted\n\n      // XXX: temporary hack to work around #16747\n      driverInstance.server = this.server;\n      driverInstance.serverHost = this.args.address;\n      driverInstance.serverPort = this.args.port;\n      driverInstance.serverPath = this.args.basePath;\n\n      try {\n        runningDriversData = (await this.curSessionDataForDriver(InnerDriver)) ?? [];\n      } catch (e) {\n        throw new errors.SessionNotCreatedError(e.message);\n      }\n      await pendingDriversGuard.acquire(AppiumDriver.name, () => {\n        this.pendingDrivers[InnerDriver.name] = this.pendingDrivers[InnerDriver.name] || [];\n        otherPendingDriversData = _.compact(\n          this.pendingDrivers[InnerDriver.name].map((drv) => drv.driverData)\n        );\n        this.pendingDrivers[InnerDriver.name].push(driverInstance);\n      });\n\n      try {\n        [innerSessionId, dCaps] = await driverInstance.createSession(\n          processedJsonwpCapabilities,\n          reqCaps,\n          processedW3CCapabilities,\n          [...runningDriversData, ...otherPendingDriversData]\n        );\n        protocol = driverInstance.protocol;\n        this.sessions[innerSessionId] = driverInstance;\n      } finally {\n        await pendingDriversGuard.acquire(AppiumDriver.name, () => {\n          _.pull(this.pendingDrivers[InnerDriver.name], driverInstance);\n        });\n      }\n\n      this.attachUnexpectedShutdownHandler(driverInstance, innerSessionId);\n\n      this.log.info(\n        `New ${InnerDriver.name} session created successfully, session ` +\n          `${innerSessionId} added to master session list`\n      );\n\n      // set the New Command Timeout for the inner driver\n      driverInstance.startNewCommandTimeout();\n\n      // apply initial values to Appium settings (if provided)\n      if (driverInstance.isW3CProtocol() && !_.isEmpty(w3cSettings)) {\n        this.log.info(\n          `Applying the initial values to Appium settings parsed from W3C caps: ` +\n            JSON.stringify(w3cSettings)\n        );\n        await driverInstance.updateSettings(w3cSettings);\n      } else if (driverInstance.isMjsonwpProtocol() && !_.isEmpty(jwpSettings)) {\n        this.log.info(\n          `Applying the initial values to Appium settings parsed from MJSONWP caps: ` +\n            JSON.stringify(jwpSettings)\n        );\n        await driverInstance.updateSettings(jwpSettings);\n      }\n    } catch (error) {\n      return {\n        protocol,\n        error,\n      };\n    }\n\n    return {\n      protocol,\n      value: [innerSessionId, dCaps, protocol],\n    };\n  }\n\n  /**\n   *\n   * @param {Driver} driver\n   * @param {string} innerSessionId\n   */\n  attachUnexpectedShutdownHandler(driver, innerSessionId) {\n    const onShutdown = (cause = new Error('Unknown error')) => {\n      this.log.warn(`Ending session, cause was '${cause.message}'`);\n\n      if (this.sessionPlugins[innerSessionId]) {\n        for (const plugin of this.sessionPlugins[innerSessionId]) {\n          if (_.isFunction(plugin.onUnexpectedShutdown)) {\n            this.log.debug(\n              `Plugin ${plugin.name} defines an unexpected shutdown handler; calling it now`\n            );\n            try {\n              plugin.onUnexpectedShutdown(driver, cause);\n            } catch (e) {\n              this.log.warn(\n                `Got an error when running plugin ${plugin.name} shutdown handler: ${e}`\n              );\n            }\n          } else {\n            this.log.debug(`Plugin ${plugin.name} does not define an unexpected shutdown handler`);\n          }\n        }\n      }\n\n      this.log.info(`Removing session '${innerSessionId}' from our master session list`);\n      delete this.sessions[innerSessionId];\n      delete this.sessionPlugins[innerSessionId];\n    };\n\n    if (_.isFunction(driver.onUnexpectedShutdown)) {\n      driver.onUnexpectedShutdown(onShutdown);\n    } else {\n      this.log.warn(\n        `Failed to attach the unexpected shutdown listener. ` +\n          `Is 'onUnexpectedShutdown' method available for '${driver.constructor.name}'?`\n      );\n    }\n  }\n\n  /**\n   *\n   * @param {DriverClass} InnerDriver\n   * @returns {Promise<DriverData[]>}}\n   */\n  // eslint-disable-next-line require-await\n  async curSessionDataForDriver(InnerDriver) {\n    const data = _.compact(\n      _.values(this.sessions)\n        .filter((s) => s.constructor.name === InnerDriver.name)\n        .map((s) => s.driverData)\n    );\n    for (const datum of data) {\n      if (!datum) {\n        throw new Error(\n          `Problem getting session data for driver type ` +\n            `${InnerDriver.name}; does it implement 'get driverData'?`\n        );\n      }\n    }\n    return data;\n  }\n\n  /**\n   * @param {string} sessionId\n   */\n  async deleteSession(sessionId) {\n    let protocol;\n    try {\n      let otherSessionsData;\n      const dstSession = await sessionsListGuard.acquire(AppiumDriver.name, () => {\n        if (!this.sessions[sessionId]) {\n          return;\n        }\n        const curConstructorName = this.sessions[sessionId].constructor.name;\n        otherSessionsData = _.toPairs(this.sessions)\n          .filter(\n            ([key, value]) => value.constructor.name === curConstructorName && key !== sessionId\n          )\n          .map(([, value]) => value.driverData);\n        const dstSession = this.sessions[sessionId];\n        protocol = dstSession.protocol;\n        this.log.info(`Removing session ${sessionId} from our master session list`);\n        // regardless of whether the deleteSession completes successfully or not\n        // make the session unavailable, because who knows what state it might\n        // be in otherwise\n        delete this.sessions[sessionId];\n        delete this.sessionPlugins[sessionId];\n        return dstSession;\n      });\n      // this may not be correct, but if `dstSession` was falsy, the call to `deleteSession()` would\n      // throw anyway.\n      if (!dstSession) {\n        throw new Error('Session not found');\n      }\n      return {\n        protocol,\n        value: await dstSession.deleteSession(sessionId, otherSessionsData),\n      };\n    } catch (e) {\n      this.log.error(`Had trouble ending session ${sessionId}: ${e.message}`);\n      return {\n        protocol,\n        error: e,\n      };\n    }\n  }\n\n  async deleteAllSessions(opts = {}) {\n    const sessionsCount = _.size(this.sessions);\n    if (0 === sessionsCount) {\n      this.log.debug('There are no active sessions for cleanup');\n      return;\n    }\n\n    const {force = false, reason} = opts;\n    this.log.debug(`Cleaning up ${util.pluralize('active session', sessionsCount, true)}`);\n    const cleanupPromises = force\n      ? _.values(this.sessions).map((drv) =>\n          drv.startUnexpectedShutdown(reason && new Error(reason))\n        )\n      : _.keys(this.sessions).map((id) => this.deleteSession(id));\n    for (const cleanupPromise of cleanupPromises) {\n      try {\n        await cleanupPromise;\n      } catch (e) {\n        this.log.debug(e);\n      }\n    }\n  }\n\n  /**\n   * Get the appropriate plugins for a session (or sessionless plugins)\n   *\n   * @param {?string} sessionId - the sessionId (or null) to use to find plugins\n   * @returns {Array} - array of plugin instances\n   */\n  pluginsForSession(sessionId = null) {\n    if (sessionId) {\n      if (!this.sessionPlugins[sessionId]) {\n        this.sessionPlugins[sessionId] = this.createPluginInstances();\n      }\n      return this.sessionPlugins[sessionId];\n    }\n\n    if (_.isEmpty(this.sessionlessPlugins)) {\n      this.sessionlessPlugins = this.createPluginInstances();\n    }\n    return this.sessionlessPlugins;\n  }\n\n  /**\n   * To get plugins for a command, we either get the plugin instances associated with the\n   * particular command's session, or in the case of sessionless plugins, pull from the set of\n   * plugin instances reserved for sessionless commands (and we lazily create plugin instances on\n   * first use)\n   *\n   * @param {string} cmd - the name of the command to find a plugin to handle\n   * @param {?string} sessionId - the particular session for which to find a plugin, or null if\n   * sessionless\n   */\n  pluginsToHandleCmd(cmd, sessionId = null) {\n    // to handle a given command, a plugin should either implement that command as a plugin\n    // instance method or it should implement a generic 'handle' method\n    return this.pluginsForSession(sessionId).filter(\n      (p) => _.isFunction(p[cmd]) || _.isFunction(p.handle)\n    );\n  }\n\n  /**\n   * Creates instances of all of the enabled Plugin classes\n   * @returns {Plugin[]}\n   */\n  createPluginInstances() {\n    /** @type {Plugin[]} */\n    const pluginInstances = [];\n    for (const [PluginClass, name] of this.pluginClasses.entries()) {\n      const cliArgs = this.getCliArgsForPlugin(name);\n      const plugin = new PluginClass(name, cliArgs);\n      pluginInstances.push(plugin);\n    }\n    return pluginInstances;\n  }\n\n  /**\n   *\n   * @param {string} cmd\n   * @param  {...any} args\n   * @returns {Promise<{value: any, error?: Error, protocol: string} | import('type-fest').AsyncReturnType<Driver['executeCommand']>>}\n   */\n  async executeCommand(cmd, ...args) {\n    // We have basically three cases for how to handle commands:\n    // 1. handle getStatus (we do this as a special out of band case so it doesn't get added to an\n    //    execution queue, and can be called while e.g. createSession is in progress)\n    // 2. handle commands that this umbrella driver should handle, rather than the actual session\n    //    driver (for example, deleteSession, or other non-session commands)\n    // 3. handle session driver commands.\n    // The tricky part is that because we support command plugins, we need to wrap any of these\n    // cases with plugin handling.\n\n    const isGetStatus = cmd === GET_STATUS_COMMAND;\n    const isUmbrellaCmd = isAppiumDriverCommand(cmd);\n    const isSessionCmd = isSessionCommand(cmd);\n\n    // if a plugin override proxying for this command and that is why we are here instead of just\n    // letting the protocol proxy the command entirely, determine that, get the request object for\n    // use later on, then clean up the args\n    const reqForProxy = _.last(args)?.reqForProxy;\n    if (reqForProxy) {\n      args.pop();\n    }\n\n    // first do some error checking. If we're requesting a session command execution, then make\n    // sure that session actually exists on the session driver, and set the session driver itself\n    let sessionId = null;\n    let dstSession = null;\n    let protocol = null;\n    /** @type {this | ExternalDriver} */\n    let driver = this;\n    if (isSessionCmd) {\n      sessionId = _.last(args);\n      dstSession = this.sessions[sessionId];\n      if (!dstSession) {\n        throw new Error(`The session with id '${sessionId}' does not exist`);\n      }\n      // now save the response protocol given that the session driver's protocol might differ\n      protocol = dstSession.protocol;\n      if (!isUmbrellaCmd) {\n        driver = dstSession;\n      }\n    }\n\n    // get any plugins which are registered as handling this command\n    const plugins = this.pluginsToHandleCmd(cmd, sessionId);\n\n    // now we define a 'cmdHandledBy' object which will keep track of which plugins have handled this\n    // command. we care about this because (a) multiple plugins can handle the same command, and\n    // (b) there's no guarantee that a plugin will actually call the next() method which runs the\n    // original command execution. This results in a situation where the command might be handled\n    // by some but not all plugins, or by plugin(s) but not by the default behavior. So start out\n    // this object declaring that the default handler has not been executed.\n    const cmdHandledBy = {default: false};\n\n    // now we define an async function which will be passed to plugins, and successively wrapped\n    // if there is more than one plugin that can handle the command. To start off with, the async\n    // function is defined as calling the default behavior, i.e., whichever of the 3 cases above is\n    // the appropriate one\n    const defaultBehavior = async () => {\n      // if we're running with plugins, make sure we log that the default behavior is actually\n      // happening so we can tell when the plugin call chain is unwrapping to the default behavior\n      // if that's what happens\n      plugins.length && this.log.info(`Executing default handling behavior for command '${cmd}'`);\n\n      // if we make it here, we know that the default behavior is handled\n      cmdHandledBy.default = true;\n\n      if (reqForProxy) {\n        // we would have proxied this command had a plugin not handled it, so the default behavior\n        // is to do the proxy and retrieve the result internally so it can be passed to the plugin\n        // in case it calls 'await next()'. This requires that the driver have defined\n        // 'proxyCommand' and not just 'proxyReqRes'.\n        if (!dstSession.proxyCommand) {\n          throw new NoDriverProxyCommandError();\n        }\n        return await dstSession.proxyCommand(\n          reqForProxy.originalUrl,\n          reqForProxy.method,\n          reqForProxy.body\n        );\n      }\n\n      if (isGetStatus) {\n        return await this.getStatus();\n      }\n\n      if (isUmbrellaCmd) {\n        // some commands, like deleteSession, we want to make sure to handle on *this* driver,\n        // not the platform driver\n        return await BaseDriver.prototype.executeCommand.call(this, cmd, ...args);\n      }\n\n      // here we know that we are executing a session command, and have a valid session driver\n      return await dstSession.executeCommand(cmd, ...args);\n    };\n\n    // now take our default behavior, wrap it with any number of plugin behaviors, and run it\n    const wrappedCmd = this.wrapCommandWithPlugins({\n      driver,\n      cmd,\n      args,\n      plugins,\n      cmdHandledBy,\n      next: defaultBehavior,\n    });\n    const res = await this.executeWrappedCommand({wrappedCmd, protocol});\n\n    // if we had plugins, make sure to log out the helpful report about which plugins ended up\n    // handling the command and which didn't\n    this.logPluginHandlerReport(plugins, {cmd, cmdHandledBy});\n\n    // And finally, if the command was createSession, we want to migrate any plugins which were\n    // previously sessionless to use the new sessionId, so that plugins can share state between\n    // their createSession method and other instance methods\n    if (cmd === CREATE_SESSION_COMMAND && this.sessionlessPlugins.length && !res.error) {\n      const sessionId = _.first(res.value);\n      this.log.info(\n        `Promoting ${this.sessionlessPlugins.length} sessionless plugins to be attached ` +\n          `to session ID ${sessionId}`\n      );\n      this.sessionPlugins[sessionId] = this.sessionlessPlugins;\n      this.sessionlessPlugins = [];\n    }\n\n    return res;\n  }\n\n  wrapCommandWithPlugins({driver, cmd, args, next, cmdHandledBy, plugins}) {\n    plugins.length &&\n      this.log.info(`Plugins which can handle cmd '${cmd}': ${plugins.map((p) => p.name)}`);\n\n    // now we can go through each plugin and wrap `next` around its own handler, passing the *old*\n    // next in so that it can call it if it wants to\n    for (const plugin of plugins) {\n      // need an IIFE here because we want the value of next that's passed to plugin.handle to be\n      // exactly the value of next here before reassignment; we don't want it to be lazily\n      // evaluated, otherwise we end up with infinite recursion of the last `next` to be defined.\n      cmdHandledBy[plugin.name] = false; // we see a new plugin, so add it to the 'cmdHandledBy' object\n      next = ((_next) => async () => {\n        this.log.info(`Plugin ${plugin.name} is now handling cmd '${cmd}'`);\n        cmdHandledBy[plugin.name] = true; // if we make it here, this plugin has attempted to handle cmd\n        // first attempt to handle the command via a command-specific handler on the plugin\n        if (plugin[cmd]) {\n          return await plugin[cmd](_next, driver, ...args);\n        }\n        // otherwise, call the generic 'handle' method\n        return await plugin.handle(_next, driver, cmd, ...args);\n      })(next);\n    }\n\n    return next;\n  }\n\n  logPluginHandlerReport(plugins, {cmd, cmdHandledBy}) {\n    if (!plugins.length) {\n      return;\n    }\n\n    // at the end of the day, we have an object representing which plugins ended up getting\n    // their code run as part of handling this command. Because plugins can choose *not* to\n    // pass control to other plugins or to the default driver behavior, this is information\n    // which is probably useful to the user (especially in situations where plugins might not\n    // interact well together, and it would be hard to debug otherwise without this kind of\n    // message).\n    const didHandle = Object.keys(cmdHandledBy).filter((k) => cmdHandledBy[k]);\n    const didntHandle = Object.keys(cmdHandledBy).filter((k) => !cmdHandledBy[k]);\n    if (didntHandle.length > 0) {\n      this.log.info(\n        `Command '${cmd}' was *not* handled by the following behaviours or plugins, even ` +\n          `though they were registered to handle it: ${JSON.stringify(didntHandle)}. The ` +\n          `command *was* handled by these: ${JSON.stringify(didHandle)}.`\n      );\n    }\n  }\n\n  async executeWrappedCommand({wrappedCmd, protocol}) {\n    let cmdRes,\n      cmdErr,\n      res = {};\n    try {\n      // At this point, `wrappedCmd` defines a whole sequence of plugin handlers, culminating in\n      // our default handler. Whatever it returns is what we're going to want to send back to the\n      // user.\n      cmdRes = await wrappedCmd();\n    } catch (e) {\n      cmdErr = e;\n    }\n\n    // Sadly, we don't know exactly what kind of object will be returned. It will either be a bare\n    // object, or a protocol-aware object with protocol and error/value keys. So we need to sniff\n    // it and make sure we don't double-wrap it if it's the latter kind.\n    if (_.isPlainObject(cmdRes) && _.has(cmdRes, 'protocol')) {\n      res = cmdRes;\n    } else {\n      res.value = cmdRes;\n      res.error = cmdErr;\n      res.protocol = protocol;\n    }\n    return res;\n  }\n\n  proxyActive(sessionId) {\n    const dstSession = this.sessions[sessionId];\n    return dstSession && _.isFunction(dstSession.proxyActive) && dstSession.proxyActive(sessionId);\n  }\n\n  getProxyAvoidList(sessionId) {\n    const dstSession = this.sessions[sessionId];\n    return dstSession ? dstSession.getProxyAvoidList() : [];\n  }\n\n  canProxy(sessionId) {\n    const dstSession = this.sessions[sessionId];\n    return dstSession && dstSession.canProxy(sessionId);\n  }\n}\n\n// help decide which commands should be proxied to sub-drivers and which\n// should be handled by this, our umbrella driver\nfunction isAppiumDriverCommand(cmd) {\n  return !isSessionCommand(cmd) || cmd === DELETE_SESSION_COMMAND;\n}\n\n/**\n * Thrown when Appium tried to proxy a command using a driver's `proxyCommand` method but the\n * method did not exist\n */\nexport class NoDriverProxyCommandError extends Error {\n  /**\n   * @type {Readonly<string>}\n   */\n  code = 'APPIUMERR_NO_DRIVER_PROXYCOMMAND';\n\n  constructor() {\n    super(\n      `The default behavior for this command was to proxy, but the driver ` +\n        `did not have the 'proxyCommand' method defined. To fully support ` +\n        `plugins, drivers should have 'proxyCommand' set to a jwpProxy object's ` +\n        `'command()' method, in addition to the normal 'proxyReqRes'`\n    );\n  }\n}\n\nexport {AppiumDriver};\n\n/**\n * @typedef {import('@appium/types').ExternalDriver} ExternalDriver\n * @typedef {import('@appium/types').Driver} Driver\n * @typedef {import('@appium/types').DriverClass} DriverClass\n * @typedef {import('@appium/types').W3CCapabilities} W3CCapabilities\n * @typedef {import('@appium/types').DriverData} DriverData\n * @typedef {import('@appium/types').ServerArgs} DriverOpts\n * @typedef {import('@appium/types').Constraints} Constraints\n * @typedef {import('@appium/types').AppiumServer} AppiumServer\n * @typedef {import('@appium/types').ExtensionType} ExtensionType\n * @typedef {import('./extension/driver-config').DriverConfig} DriverConfig\n * @typedef {import('@appium/types').Plugin} Plugin\n * @typedef {import('@appium/types').PluginClass} PluginClass\n * @typedef {import('@appium/types').PluginType} PluginType\n * @typedef {import('@appium/types').DriverType} DriverType\n * @typedef {import('@appium/types').SessionHandler<SessionHandlerResult<any[]>,SessionHandlerResult<void>>} SessionHandler\n */\n\n/**\n * Used by {@linkcode AppiumDriver.createSession} and {@linkcode AppiumDriver.deleteSession} to describe\n * result.\n * @template V\n * @typedef SessionHandlerResult\n * @property {V} [value]\n * @property {Error} [error]\n * @property {string} [protocol]\n */\n"],"mappings":"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"}
|
package/build/lib/cli/args.d.ts
CHANGED
|
@@ -1,7 +1,4 @@
|
|
|
1
|
-
|
|
2
|
-
* Alias
|
|
3
|
-
*/
|
|
4
|
-
export type ExtensionType = import('../extension/manifest').ExtensionType;
|
|
1
|
+
export type ExtensionType = import('@appium/types').ExtensionType;
|
|
5
2
|
/**
|
|
6
3
|
* A tuple of argument aliases and argument options
|
|
7
4
|
*/
|
|
@@ -15,6 +12,6 @@ export function getServerArgs(): ArgumentDefinitions;
|
|
|
15
12
|
/**
|
|
16
13
|
* Builds a Record of extension types to a Record of subcommands to their argument definitions
|
|
17
14
|
*/
|
|
18
|
-
export const getExtensionArgs: (() => Record<import("
|
|
15
|
+
export const getExtensionArgs: (() => Record<import("@appium/types").ExtensionType, Record<import("appium/types").CliExtensionSubcommand, ArgumentDefinitions>>) & _.MemoizedFunction;
|
|
19
16
|
import _ from "lodash";
|
|
20
17
|
//# sourceMappingURL=args.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"args.d.ts","sourceRoot":"","sources":["../../../lib/cli/args.js"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"args.d.ts","sourceRoot":"","sources":["../../../lib/cli/args.js"],"names":[],"mappings":"4BAyRa,OAAO,eAAe,EAAE,aAAa;;;;kCAKrC,IAAI,MAAM,EAAE,EAAC,OAAO,UAAU,EAAE,eAAe,CAAC;AA/D7D;;;;GAIG;AACH,qDAEC;AA/LD;;GAEG;AACH,sLAcG"}
|
package/build/lib/cli/args.js
CHANGED
|
@@ -141,4 +141,4 @@ const serverArgsDisallowedInConfig = new Map([[['--shell'], {
|
|
|
141
141
|
required: false,
|
|
142
142
|
help: 'Explicit path to Appium configuration file'
|
|
143
143
|
}]]);
|
|
144
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["DRIVER_EXAMPLE","PLUGIN_EXAMPLE","INSTALL_TYPES_ARRAY","INSTALL_TYPES","EXTENSION_TYPES","Set","DRIVER_TYPE","PLUGIN_TYPE","globalExtensionArgs","Map","required","default","action","help","dest","getExtensionArgs","_","memoize","extensionArgs","type","EXT_SUBCOMMAND_LIST","makeListArgs","EXT_SUBCOMMAND_INSTALL","makeInstallArgs","EXT_SUBCOMMAND_UNINSTALL","makeUninstallArgs","EXT_SUBCOMMAND_UPDATE","makeUpdateArgs","EXT_SUBCOMMAND_RUN","makeRunArgs","choices","join","getServerArgs","toParserArgs","serverArgsDisallowedInConfig","const"],"sources":["../../../lib/cli/args.js"],"sourcesContent":["// @ts-ignore\nimport _ from 'lodash';\nimport {\n  DRIVER_TYPE,\n  PLUGIN_TYPE,\n  EXT_SUBCOMMAND_INSTALL,\n  EXT_SUBCOMMAND_LIST,\n  EXT_SUBCOMMAND_RUN,\n  EXT_SUBCOMMAND_UNINSTALL,\n  EXT_SUBCOMMAND_UPDATE,\n} from '../constants';\nimport {INSTALL_TYPES} from '../extension/extension-config';\nimport {toParserArgs} from '../schema/cli-args';\nconst DRIVER_EXAMPLE = 'xcuitest';\nconst PLUGIN_EXAMPLE = 'find_by_image';\n\n/**\n * This is necessary because we pass the array into `argparse`. `argparse` is bad and mutates things. We don't want that.\n * Bad `argparse`! Bad!\n */\nconst INSTALL_TYPES_ARRAY = [...INSTALL_TYPES];\n\n/** @type {Set<ExtensionType>} */\nconst EXTENSION_TYPES = new Set([DRIVER_TYPE, PLUGIN_TYPE]);\n\n// this set of args works for both drivers and plugins ('extensions')\n/** @type {ArgumentDefinitions} */\nconst globalExtensionArgs = new Map([\n  [\n    ['--json'],\n    {\n      required: false,\n      default: false,\n      action: 'store_true',\n      help: 'Use JSON for output format',\n      dest: 'json',\n    },\n  ],\n]);\n\n/**\n * Builds a Record of extension types to a Record of subcommands to their argument definitions\n */\nconst getExtensionArgs = _.memoize(function getExtensionArgs() {\n  const extensionArgs = {};\n  for (const type of EXTENSION_TYPES) {\n    extensionArgs[type] = {\n      [EXT_SUBCOMMAND_LIST]: makeListArgs(type),\n      [EXT_SUBCOMMAND_INSTALL]: makeInstallArgs(type),\n      [EXT_SUBCOMMAND_UNINSTALL]: makeUninstallArgs(type),\n      [EXT_SUBCOMMAND_UPDATE]: makeUpdateArgs(type),\n      [EXT_SUBCOMMAND_RUN]: makeRunArgs(type),\n    };\n  }\n  return /** @type {Record<ExtensionType, Record<import('appium/types').CliExtensionSubcommand,ArgumentDefinitions>>} */ (\n    extensionArgs\n  );\n});\n\n/**\n * Makes the opts for the `list` subcommand for each extension type.\n * @param {ExtensionType} type\n * @returns {ArgumentDefinitions}\n */\nfunction makeListArgs(type) {\n  return new Map([\n    ...globalExtensionArgs,\n    [\n      ['--installed'],\n      {\n        required: false,\n        default: false,\n        action: 'store_true',\n        help: `List only installed ${type}s`,\n        dest: 'showInstalled',\n      },\n    ],\n    [\n      ['--updates'],\n      {\n        required: false,\n        default: false,\n        action: 'store_true',\n        help: 'Show information about newer versions',\n        dest: 'showUpdates',\n      },\n    ],\n  ]);\n}\n\n/**\n * Makes the opts for the `install` subcommand for each extension type\n * @param {ExtensionType} type\n * @returns {ArgumentDefinitions}\n */\nfunction makeInstallArgs(type) {\n  return new Map([\n    ...globalExtensionArgs,\n    [\n      [type],\n      {\n        type: 'str',\n        help:\n          `Name of the ${type} to install, for example: ` + type === DRIVER_TYPE\n            ? DRIVER_EXAMPLE\n            : PLUGIN_EXAMPLE,\n      },\n    ],\n    [\n      ['--source'],\n      {\n        required: false,\n        default: null,\n        choices: INSTALL_TYPES_ARRAY,\n        help:\n          `Where to look for the ${type} if it is not one of Appium's verified ` +\n          `${type}s. Possible values: ${INSTALL_TYPES_ARRAY.join(', ')}`,\n        dest: 'installType',\n      },\n    ],\n    [\n      ['--package'],\n      {\n        required: false,\n        default: null,\n        type: 'str',\n        help:\n          `If installing from Git or GitHub, the package name, as defined in the plugin's ` +\n          `package.json file in the \"name\" field, cannot be determined automatically, and ` +\n          `should be reported here, otherwise the install will probably fail.`,\n        dest: 'packageName',\n      },\n    ],\n  ]);\n}\n\n/**\n * Makes the opts for the `uninstall` subcommand for each extension type\n * @param {ExtensionType} type\n * @returns {ArgumentDefinitions}\n */\nfunction makeUninstallArgs(type) {\n  return new Map([\n    ...globalExtensionArgs,\n    [\n      [type],\n      {\n        type: 'str',\n        help:\n          'Name of the driver to uninstall, for example: ' + type === DRIVER_TYPE\n            ? DRIVER_EXAMPLE\n            : PLUGIN_EXAMPLE,\n      },\n    ],\n  ]);\n}\n\n/**\n * Makes the opts for the `update` subcommand for each extension type\n * @param {ExtensionType} type\n * @returns {ArgumentDefinitions}\n */\nfunction makeUpdateArgs(type) {\n  return new Map([\n    ...globalExtensionArgs,\n    [\n      [type],\n      {\n        type: 'str',\n        help:\n          `Name of the ${type} to update, or the word \"installed\" to update all installed ` +\n            `${type}s. To see available updates, run \"appium ${type} list --installed --updates\". ` +\n            'For example: ' +\n            type ===\n          DRIVER_TYPE\n            ? DRIVER_EXAMPLE\n            : PLUGIN_EXAMPLE,\n      },\n    ],\n    [\n      ['--unsafe'],\n      {\n        required: false,\n        default: false,\n        action: 'store_true',\n        help:\n          `Include updates that might have a new major revision, and potentially include ` +\n          `breaking changes`,\n      },\n    ],\n  ]);\n}\n\n/**\n * Makes the opts for the `run` subcommand for each extension type\n * @param {ExtensionType} type\n * @returns {ArgumentDefinitions}\n */\nfunction makeRunArgs(type) {\n  return new Map([\n    ...globalExtensionArgs,\n    [\n      [type],\n      {\n        type: 'str',\n        help:\n          `Name of the ${type} to run a script from, for example: ` + type === DRIVER_TYPE\n            ? DRIVER_EXAMPLE\n            : PLUGIN_EXAMPLE,\n      },\n    ],\n    [\n      ['scriptName'],\n      {\n        default: null,\n        type: 'str',\n        help:\n          `Name of the script to run from the ${type}. The script name must be cached ` +\n          `inside the \"scripts\" field under \"appium\" inside the ${type}'s \"package.json\" file`,\n      },\n    ],\n  ]);\n}\n\n/**\n * Derives the options for the `server` command from the schema, and adds the arguments\n * which are disallowed in the config file.\n * @returns {ArgumentDefinitions}\n */\nfunction getServerArgs() {\n  return new Map([...toParserArgs(), ...serverArgsDisallowedInConfig]);\n}\n\n/**\n * These don't make sense in the context of a config file for obvious reasons.\n * @type {ArgumentDefinitions}\n */\nconst serverArgsDisallowedInConfig = new Map([\n  [\n    ['--shell'],\n    {\n      required: false,\n      help: 'Enter REPL mode',\n      action: 'store_const',\n      const: true,\n      dest: 'shell',\n    },\n  ],\n  [\n    ['--show-build-info'],\n    {\n      dest: 'showBuildInfo',\n      action: 'store_const',\n      const: true,\n      required: false,\n      help: 'Show info about the Appium build and exit',\n    },\n  ],\n  [\n    ['--show-config'],\n    {\n      dest: 'showConfig',\n      action: 'store_const',\n      const: true,\n      required: false,\n      help: 'Show the current Appium configuration and exit',\n    },\n  ],\n  [\n    ['--config'],\n    {\n      dest: 'configFile',\n      type: 'string',\n      required: false,\n      help: 'Explicit path to Appium configuration file',\n    },\n  ],\n]);\n\nexport {getServerArgs, getExtensionArgs};\n\n/**\n * Alias\n * @typedef {import('../extension/manifest').ExtensionType} ExtensionType\n */\n\n/**\n * A tuple of argument aliases and argument options\n * @typedef {Map<string[],import('argparse').ArgumentOptions>} ArgumentDefinitions\n */\n"],"mappings":"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"}
|
|
144
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["DRIVER_EXAMPLE","PLUGIN_EXAMPLE","INSTALL_TYPES_ARRAY","INSTALL_TYPES","EXTENSION_TYPES","Set","DRIVER_TYPE","PLUGIN_TYPE","globalExtensionArgs","Map","required","default","action","help","dest","getExtensionArgs","_","memoize","extensionArgs","type","EXT_SUBCOMMAND_LIST","makeListArgs","EXT_SUBCOMMAND_INSTALL","makeInstallArgs","EXT_SUBCOMMAND_UNINSTALL","makeUninstallArgs","EXT_SUBCOMMAND_UPDATE","makeUpdateArgs","EXT_SUBCOMMAND_RUN","makeRunArgs","choices","join","getServerArgs","toParserArgs","serverArgsDisallowedInConfig","const"],"sources":["../../../lib/cli/args.js"],"sourcesContent":["import _ from 'lodash';\nimport {\n  DRIVER_TYPE,\n  PLUGIN_TYPE,\n  EXT_SUBCOMMAND_INSTALL,\n  EXT_SUBCOMMAND_LIST,\n  EXT_SUBCOMMAND_RUN,\n  EXT_SUBCOMMAND_UNINSTALL,\n  EXT_SUBCOMMAND_UPDATE,\n} from '../constants';\nimport {INSTALL_TYPES} from '../extension/extension-config';\nimport {toParserArgs} from '../schema/cli-args';\nconst DRIVER_EXAMPLE = 'xcuitest';\nconst PLUGIN_EXAMPLE = 'find_by_image';\n\n/**\n * This is necessary because we pass the array into `argparse`. `argparse` is bad and mutates things. We don't want that.\n * Bad `argparse`! Bad!\n */\nconst INSTALL_TYPES_ARRAY = [...INSTALL_TYPES];\n\n/** @type {Set<ExtensionType>} */\nconst EXTENSION_TYPES = new Set([DRIVER_TYPE, PLUGIN_TYPE]);\n\n// this set of args works for both drivers and plugins ('extensions')\n/** @type {ArgumentDefinitions} */\nconst globalExtensionArgs = new Map([\n  [\n    ['--json'],\n    {\n      required: false,\n      default: false,\n      action: 'store_true',\n      help: 'Use JSON for output format',\n      dest: 'json',\n    },\n  ],\n]);\n\n/**\n * Builds a Record of extension types to a Record of subcommands to their argument definitions\n */\nconst getExtensionArgs = _.memoize(function getExtensionArgs() {\n  const extensionArgs = {};\n  for (const type of EXTENSION_TYPES) {\n    extensionArgs[type] = {\n      [EXT_SUBCOMMAND_LIST]: makeListArgs(type),\n      [EXT_SUBCOMMAND_INSTALL]: makeInstallArgs(type),\n      [EXT_SUBCOMMAND_UNINSTALL]: makeUninstallArgs(type),\n      [EXT_SUBCOMMAND_UPDATE]: makeUpdateArgs(type),\n      [EXT_SUBCOMMAND_RUN]: makeRunArgs(type),\n    };\n  }\n  return /** @type {Record<ExtensionType, Record<import('appium/types').CliExtensionSubcommand,ArgumentDefinitions>>} */ (\n    extensionArgs\n  );\n});\n\n/**\n * Makes the opts for the `list` subcommand for each extension type.\n * @param {ExtensionType} type\n * @returns {ArgumentDefinitions}\n */\nfunction makeListArgs(type) {\n  return new Map([\n    ...globalExtensionArgs,\n    [\n      ['--installed'],\n      {\n        required: false,\n        default: false,\n        action: 'store_true',\n        help: `List only installed ${type}s`,\n        dest: 'showInstalled',\n      },\n    ],\n    [\n      ['--updates'],\n      {\n        required: false,\n        default: false,\n        action: 'store_true',\n        help: 'Show information about newer versions',\n        dest: 'showUpdates',\n      },\n    ],\n  ]);\n}\n\n/**\n * Makes the opts for the `install` subcommand for each extension type\n * @param {ExtensionType} type\n * @returns {ArgumentDefinitions}\n */\nfunction makeInstallArgs(type) {\n  return new Map([\n    ...globalExtensionArgs,\n    [\n      [type],\n      {\n        type: 'str',\n        help:\n          `Name of the ${type} to install, for example: ` + type === DRIVER_TYPE\n            ? DRIVER_EXAMPLE\n            : PLUGIN_EXAMPLE,\n      },\n    ],\n    [\n      ['--source'],\n      {\n        required: false,\n        default: null,\n        choices: INSTALL_TYPES_ARRAY,\n        help:\n          `Where to look for the ${type} if it is not one of Appium's verified ` +\n          `${type}s. Possible values: ${INSTALL_TYPES_ARRAY.join(', ')}`,\n        dest: 'installType',\n      },\n    ],\n    [\n      ['--package'],\n      {\n        required: false,\n        default: null,\n        type: 'str',\n        help:\n          `If installing from Git or GitHub, the package name, as defined in the plugin's ` +\n          `package.json file in the \"name\" field, cannot be determined automatically, and ` +\n          `should be reported here, otherwise the install will probably fail.`,\n        dest: 'packageName',\n      },\n    ],\n  ]);\n}\n\n/**\n * Makes the opts for the `uninstall` subcommand for each extension type\n * @param {ExtensionType} type\n * @returns {ArgumentDefinitions}\n */\nfunction makeUninstallArgs(type) {\n  return new Map([\n    ...globalExtensionArgs,\n    [\n      [type],\n      {\n        type: 'str',\n        help:\n          'Name of the driver to uninstall, for example: ' + type === DRIVER_TYPE\n            ? DRIVER_EXAMPLE\n            : PLUGIN_EXAMPLE,\n      },\n    ],\n  ]);\n}\n\n/**\n * Makes the opts for the `update` subcommand for each extension type\n * @param {ExtensionType} type\n * @returns {ArgumentDefinitions}\n */\nfunction makeUpdateArgs(type) {\n  return new Map([\n    ...globalExtensionArgs,\n    [\n      [type],\n      {\n        type: 'str',\n        help:\n          `Name of the ${type} to update, or the word \"installed\" to update all installed ` +\n            `${type}s. To see available updates, run \"appium ${type} list --installed --updates\". ` +\n            'For example: ' +\n            type ===\n          DRIVER_TYPE\n            ? DRIVER_EXAMPLE\n            : PLUGIN_EXAMPLE,\n      },\n    ],\n    [\n      ['--unsafe'],\n      {\n        required: false,\n        default: false,\n        action: 'store_true',\n        help:\n          `Include updates that might have a new major revision, and potentially include ` +\n          `breaking changes`,\n      },\n    ],\n  ]);\n}\n\n/**\n * Makes the opts for the `run` subcommand for each extension type\n * @param {ExtensionType} type\n * @returns {ArgumentDefinitions}\n */\nfunction makeRunArgs(type) {\n  return new Map([\n    ...globalExtensionArgs,\n    [\n      [type],\n      {\n        type: 'str',\n        help:\n          `Name of the ${type} to run a script from, for example: ` + type === DRIVER_TYPE\n            ? DRIVER_EXAMPLE\n            : PLUGIN_EXAMPLE,\n      },\n    ],\n    [\n      ['scriptName'],\n      {\n        default: null,\n        type: 'str',\n        help:\n          `Name of the script to run from the ${type}. The script name must be cached ` +\n          `inside the \"scripts\" field under \"appium\" inside the ${type}'s \"package.json\" file`,\n      },\n    ],\n  ]);\n}\n\n/**\n * Derives the options for the `server` command from the schema, and adds the arguments\n * which are disallowed in the config file.\n * @returns {ArgumentDefinitions}\n */\nfunction getServerArgs() {\n  return new Map([...toParserArgs(), ...serverArgsDisallowedInConfig]);\n}\n\n/**\n * These don't make sense in the context of a config file for obvious reasons.\n * @type {ArgumentDefinitions}\n */\nconst serverArgsDisallowedInConfig = new Map([\n  [\n    ['--shell'],\n    {\n      required: false,\n      help: 'Enter REPL mode',\n      action: 'store_const',\n      const: true,\n      dest: 'shell',\n    },\n  ],\n  [\n    ['--show-build-info'],\n    {\n      dest: 'showBuildInfo',\n      action: 'store_const',\n      const: true,\n      required: false,\n      help: 'Show info about the Appium build and exit',\n    },\n  ],\n  [\n    ['--show-config'],\n    {\n      dest: 'showConfig',\n      action: 'store_const',\n      const: true,\n      required: false,\n      help: 'Show the current Appium configuration and exit',\n    },\n  ],\n  [\n    ['--config'],\n    {\n      dest: 'configFile',\n      type: 'string',\n      required: false,\n      help: 'Explicit path to Appium configuration file',\n    },\n  ],\n]);\n\nexport {getServerArgs, getExtensionArgs};\n\n/**\n * @typedef {import('@appium/types').ExtensionType} ExtensionType\n */\n\n/**\n * A tuple of argument aliases and argument options\n * @typedef {Map<string[],import('argparse').ArgumentOptions>} ArgumentDefinitions\n */\n"],"mappings":"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"}
|
package/build/lib/config-file.js
CHANGED
|
@@ -108,7 +108,7 @@ async function readConfigFile(filepath, opts = {}) {
|
|
|
108
108
|
}
|
|
109
109
|
}
|
|
110
110
|
|
|
111
|
-
return result
|
|
111
|
+
return result ?? {};
|
|
112
112
|
}
|
|
113
113
|
|
|
114
114
|
function normalizeConfig(config) {
|
|
@@ -118,9 +118,9 @@ function normalizeConfig(config) {
|
|
|
118
118
|
const obj = _lodash.default.isUndefined(section) ? config : _lodash.default.get(config, section, config);
|
|
119
119
|
|
|
120
120
|
const mappedObj = _lodash.default.mapKeys(obj, (__, prop) => {
|
|
121
|
-
var _schema$properties$pr
|
|
121
|
+
var _schema$properties$pr;
|
|
122
122
|
|
|
123
|
-
return (_schema$properties$pr =
|
|
123
|
+
return ((_schema$properties$pr = schema.properties[prop]) === null || _schema$properties$pr === void 0 ? void 0 : _schema$properties$pr.appiumCliDest) ?? _lodash.default.camelCase(prop);
|
|
124
124
|
});
|
|
125
125
|
|
|
126
126
|
return _lodash.default.mapValues(mappedObj, (value, property) => {
|
|
@@ -133,4 +133,4 @@ function normalizeConfig(config) {
|
|
|
133
133
|
|
|
134
134
|
return normalize(config);
|
|
135
135
|
}
|
|
136
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["yamlLoader","filepath","content","yaml","parse","rawConfig","Map","jsonLoader","set","JSON","loadConfigFile","lc","load","err","code","message","SyntaxError","searchConfigFile","search","formatErrors","errors","config","opts","length","TypeError","betterAjvErrors","getSchema","schemaId","json","format","readConfigFile","lilconfig","loaders","noExt","packageProp","result","isEmpty","pretty","configResult","validate","_","reason","get","normalizeConfig","delete","schema","normalize","section","obj","isUndefined","mappedObj","mapKeys","__","prop","properties","appiumCliDest","camelCase","mapValues","value","property","nextSection","isSchemaTypeObject","Boolean"],"sources":["../../lib/config-file.js"],"sourcesContent":["import betterAjvErrors from '@sidvind/better-ajv-errors';\nimport {lilconfig} from 'lilconfig';\nimport _ from 'lodash';\nimport yaml from 'yaml';\nimport {getSchema, validate} from './schema/schema';\n\n/**\n * lilconfig loader to handle `.yaml` files\n * @type {import('lilconfig').LoaderSync}\n */\nfunction yamlLoader(filepath, content) {\n  return yaml.parse(content);\n}\n\n/**\n * A cache of the raw config file (a JSON string) at a filepath.\n * This is used for better error reporting.\n * Note that config files needn't be JSON, but it helps if they are.\n * @type {Map<string,RawJson>}\n */\nconst rawConfig = new Map();\n\n/**\n * Custom JSON loader that caches the raw config file (for use with `better-ajv-errors`).\n * If it weren't for this cache, this would be unnecessary.\n * @type {import('lilconfig').LoaderSync}\n */\nfunction jsonLoader(filepath, content) {\n  rawConfig.set(filepath, content);\n  return JSON.parse(content);\n}\n\n/**\n * Loads a config file from an explicit path\n * @param {LilconfigAsyncSearcher} lc - lilconfig instance\n * @param {string} filepath - Path to config file\n * @returns {Promise<import('lilconfig').LilconfigResult>}\n */\nasync function loadConfigFile(lc, filepath) {\n  try {\n    // removing \"await\" will cause any rejection to _not_ be caught in this block!\n    return await lc.load(filepath);\n  } catch (/** @type {unknown} */ err) {\n    if (/** @type {NodeJS.ErrnoException} */ (err).code === 'ENOENT') {\n      /** @type {NodeJS.ErrnoException} */ (\n        err\n      ).message = `Config file not found at user-provided path: ${filepath}`;\n      throw err;\n    } else if (err instanceof SyntaxError) {\n      // generally invalid JSON\n      err.message = `Config file at user-provided path ${filepath} is invalid:\\n${err.message}`;\n      throw err;\n    }\n    throw err;\n  }\n}\n\n/**\n * Searches for a config file\n * @param {LilconfigAsyncSearcher} lc - lilconfig instance\n * @returns {Promise<import('lilconfig').LilconfigResult>}\n */\nasync function searchConfigFile(lc) {\n  return await lc.search();\n}\n\n/**\n * Given an array of errors and the result of loading a config file, generate a\n * helpful string for the user.\n *\n * - If `opts` contains a `json` property, this should be the original JSON\n *   _string_ of the config file.  This is only applicable if the config file\n *   was in JSON format. If present, it will associate line numbers with errors.\n * - If `errors` happens to be empty, this will throw.\n * @param {import('ajv').ErrorObject[]} errors - Non-empty array of errors. Required.\n * @param {ReadConfigFileResult['config']|any} [config] -\n * Configuration & metadata\n * @param {FormatConfigErrorsOptions} [opts]\n * @throws {TypeError} If `errors` is empty\n * @returns {string}\n */\nexport function formatErrors(errors = [], config = {}, opts = {}) {\n  if (errors && !errors.length) {\n    throw new TypeError('Array of errors must be non-empty');\n  }\n  return betterAjvErrors(getSchema(opts.schemaId), config, errors, {\n    json: opts.json,\n    format: 'cli',\n  });\n}\n\n/**\n * Given an optional path, read a config file. Validates the config file.\n *\n * Call {@link validate} if you already have a config object.\n * @param {string} [filepath] - Path to config file, if we have one\n * @param {ReadConfigFileOptions} [opts] - Options\n * @public\n * @returns {Promise<ReadConfigFileResult>} Contains config and filepath, if found, and any errors\n */\nexport async function readConfigFile(filepath, opts = {}) {\n  const lc = lilconfig('appium', {\n    loaders: {\n      '.yaml': yamlLoader,\n      '.yml': yamlLoader,\n      '.json': jsonLoader,\n      noExt: jsonLoader,\n    },\n    packageProp: 'appiumConfig',\n  });\n\n  const result = filepath ? await loadConfigFile(lc, filepath) : await searchConfigFile(lc);\n\n  if (result?.filepath && !result?.isEmpty) {\n    const {pretty = true} = opts;\n    try {\n      let configResult;\n      const errors = validate(result.config);\n      if (_.isEmpty(errors)) {\n        configResult = {...result, errors};\n      } else {\n        const reason = formatErrors(errors, result.config, {\n          json: rawConfig.get(result.filepath),\n          pretty,\n        });\n        configResult = reason ? {...result, errors, reason} : {...result, errors};\n      }\n\n      // normalize (to camel case) all top-level property names of the config file\n      configResult.config = normalizeConfig(/** @type {AppiumConfig} */ (configResult.config));\n\n      return configResult;\n    } finally {\n      // clean up the raw config file cache, which is only kept to better report errors.\n      rawConfig.delete(result.filepath);\n    }\n  }\n  return result ?? {};\n}\n\n/**\n * Convert schema property names to either a) the value of the `appiumCliDest` property, if any; or b) camel-case\n * @param {AppiumConfig} config - Configuration object\n * @returns {NormalizedAppiumConfig} New object with camel-cased keys (or `dest` keys).\n */\nexport function normalizeConfig(config) {\n  const schema = getSchema();\n  /**\n   * @param {AppiumConfig} config\n   * @param {string} [section] - Keypath (lodash `_.get()` style) to section of config. If omitted, assume root Appium config schema\n   * @todo Rewrite as a loop\n   * @returns Normalized section of config\n   */\n  const normalize = (config, section) => {\n    const obj = _.isUndefined(section) ? config : _.get(config, section, config);\n\n    const mappedObj = _.mapKeys(\n      obj,\n      (__, prop) => schema.properties[prop]?.appiumCliDest ?? _.camelCase(prop)\n    );\n\n    return _.mapValues(mappedObj, (value, property) => {\n      const nextSection = section ? `${section}.${property}` : property;\n      return isSchemaTypeObject(value) ? normalize(config, nextSection) : value;\n    });\n  };\n\n  /**\n   * Returns `true` if the schema prop references an object, or if it's an object itself\n   * @param {import('ajv').SchemaObject|object} schema - Referencing schema object\n   */\n  const isSchemaTypeObject = (schema) => Boolean(schema.properties);\n\n  return normalize(config);\n}\n\n/**\n * Result of calling {@link readConfigFile}.\n * @typedef ReadConfigFileResult\n * @property {import('ajv').ErrorObject[]} [errors] - Validation errors\n * @property {string} [filepath] - The path to the config file, if found\n * @property {boolean} [isEmpty] - If `true`, the config file exists but is empty\n * @property {NormalizedAppiumConfig} [config] - The parsed configuration\n * @property {string|import('@sidvind/better-ajv-errors').IOutputError[]} [reason] - Human-readable error messages and suggestions. If the `pretty` option is `true`, this will be a nice string to print.\n */\n\n/**\n * Options for {@link readConfigFile}.\n * @typedef ReadConfigFileOptions\n * @property {boolean} [pretty=true] If `false`, do not use color and fancy formatting in the `reason` property of the {@link ReadConfigFileResult}. The value of `reason` is then suitable for machine-reading.\n */\n\n/**\n * This is an `AsyncSearcher` which is inexplicably _not_ exported by the `lilconfig` type definition.\n * @typedef {ReturnType<import('lilconfig')[\"lilconfig\"]>} LilconfigAsyncSearcher\n */\n\n/**\n * The contents of an Appium config file. Generated from schema\n * @typedef {import('@appium/types').AppiumConfig} AppiumConfig\n */\n\n/**\n * The contents of an Appium config file with camelcased property names (and using `appiumCliDest` value if present). Generated from {@link AppiumConfig}\n * @typedef {import('@appium/types').NormalizedAppiumConfig} NormalizedAppiumConfig\n */\n\n/**\n * The string should be a raw JSON string.\n * @typedef {string} RawJson\n */\n\n/**\n * Options for {@link formatErrors}.\n * @typedef FormatConfigErrorsOptions\n * @property {import('./config-file').RawJson} [json] - Raw JSON config (as string)\n * @property {boolean} [pretty=true] - Whether to format errors as a CLI-friendly string\n * @property {string}  [schemaId] - Specific ID of a prop; otherwise entire schema\n */\n"],"mappings":"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"}
|
|
136
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["yamlLoader","filepath","content","yaml","parse","rawConfig","Map","jsonLoader","set","JSON","loadConfigFile","lc","load","err","code","message","SyntaxError","searchConfigFile","search","formatErrors","errors","config","opts","length","TypeError","betterAjvErrors","getSchema","schemaId","json","format","readConfigFile","lilconfig","loaders","noExt","packageProp","result","isEmpty","pretty","configResult","validate","_","reason","get","normalizeConfig","delete","schema","normalize","section","obj","isUndefined","mappedObj","mapKeys","__","prop","properties","appiumCliDest","camelCase","mapValues","value","property","nextSection","isSchemaTypeObject","Boolean"],"sources":["../../lib/config-file.js"],"sourcesContent":["import betterAjvErrors from '@sidvind/better-ajv-errors';\nimport {lilconfig} from 'lilconfig';\nimport _ from 'lodash';\nimport yaml from 'yaml';\nimport {getSchema, validate} from './schema/schema';\n\n/**\n * lilconfig loader to handle `.yaml` files\n * @type {import('lilconfig').LoaderSync}\n */\nfunction yamlLoader(filepath, content) {\n  return yaml.parse(content);\n}\n\n/**\n * A cache of the raw config file (a JSON string) at a filepath.\n * This is used for better error reporting.\n * Note that config files needn't be JSON, but it helps if they are.\n * @type {Map<string,RawJson>}\n */\nconst rawConfig = new Map();\n\n/**\n * Custom JSON loader that caches the raw config file (for use with `better-ajv-errors`).\n * If it weren't for this cache, this would be unnecessary.\n * @type {import('lilconfig').LoaderSync}\n */\nfunction jsonLoader(filepath, content) {\n  rawConfig.set(filepath, content);\n  return JSON.parse(content);\n}\n\n/**\n * Loads a config file from an explicit path\n * @param {LilconfigAsyncSearcher} lc - lilconfig instance\n * @param {string} filepath - Path to config file\n * @returns {Promise<import('lilconfig').LilconfigResult>}\n */\nasync function loadConfigFile(lc, filepath) {\n  try {\n    // removing \"await\" will cause any rejection to _not_ be caught in this block!\n    return await lc.load(filepath);\n  } catch (/** @type {unknown} */ err) {\n    if (/** @type {NodeJS.ErrnoException} */ (err).code === 'ENOENT') {\n      /** @type {NodeJS.ErrnoException} */ (\n        err\n      ).message = `Config file not found at user-provided path: ${filepath}`;\n      throw err;\n    } else if (err instanceof SyntaxError) {\n      // generally invalid JSON\n      err.message = `Config file at user-provided path ${filepath} is invalid:\\n${err.message}`;\n      throw err;\n    }\n    throw err;\n  }\n}\n\n/**\n * Searches for a config file\n * @param {LilconfigAsyncSearcher} lc - lilconfig instance\n * @returns {Promise<import('lilconfig').LilconfigResult>}\n */\nasync function searchConfigFile(lc) {\n  return await lc.search();\n}\n\n/**\n * Given an array of errors and the result of loading a config file, generate a\n * helpful string for the user.\n *\n * - If `opts` contains a `json` property, this should be the original JSON\n *   _string_ of the config file.  This is only applicable if the config file\n *   was in JSON format. If present, it will associate line numbers with errors.\n * - If `errors` happens to be empty, this will throw.\n * @param {import('ajv').ErrorObject[]} errors - Non-empty array of errors. Required.\n * @param {ReadConfigFileResult['config']|any} [config] -\n * Configuration & metadata\n * @param {FormatConfigErrorsOptions} [opts]\n * @throws {TypeError} If `errors` is empty\n * @returns {string}\n */\nexport function formatErrors(errors = [], config = {}, opts = {}) {\n  if (errors && !errors.length) {\n    throw new TypeError('Array of errors must be non-empty');\n  }\n  return betterAjvErrors(getSchema(opts.schemaId), config, errors, {\n    json: opts.json,\n    format: 'cli',\n  });\n}\n\n/**\n * Given an optional path, read a config file. Validates the config file.\n *\n * Call {@link validate} if you already have a config object.\n * @param {string} [filepath] - Path to config file, if we have one\n * @param {ReadConfigFileOptions} [opts] - Options\n * @public\n * @returns {Promise<ReadConfigFileResult>} Contains config and filepath, if found, and any errors\n */\nexport async function readConfigFile(filepath, opts = {}) {\n  const lc = lilconfig('appium', {\n    loaders: {\n      '.yaml': yamlLoader,\n      '.yml': yamlLoader,\n      '.json': jsonLoader,\n      noExt: jsonLoader,\n    },\n    packageProp: 'appiumConfig',\n  });\n\n  const result = filepath ? await loadConfigFile(lc, filepath) : await searchConfigFile(lc);\n\n  if (result?.filepath && !result?.isEmpty) {\n    const {pretty = true} = opts;\n    try {\n      let configResult;\n      const errors = validate(result.config);\n      if (_.isEmpty(errors)) {\n        configResult = {...result, errors};\n      } else {\n        const reason = formatErrors(errors, result.config, {\n          json: rawConfig.get(result.filepath),\n          pretty,\n        });\n        configResult = reason ? {...result, errors, reason} : {...result, errors};\n      }\n\n      // normalize (to camel case) all top-level property names of the config file\n      configResult.config = normalizeConfig(/** @type {AppiumConfig} */ (configResult.config));\n\n      return configResult;\n    } finally {\n      // clean up the raw config file cache, which is only kept to better report errors.\n      rawConfig.delete(result.filepath);\n    }\n  }\n  return result ?? {};\n}\n\n/**\n * Convert schema property names to either a) the value of the `appiumCliDest` property, if any; or b) camel-case\n * @param {AppiumConfig} config - Configuration object\n * @returns {NormalizedAppiumConfig} New object with camel-cased keys (or `dest` keys).\n */\nexport function normalizeConfig(config) {\n  const schema = getSchema();\n  /**\n   * @param {AppiumConfig} config\n   * @param {string} [section] - Keypath (lodash `_.get()` style) to section of config. If omitted, assume root Appium config schema\n   * @todo Rewrite as a loop\n   * @returns Normalized section of config\n   */\n  const normalize = (config, section) => {\n    const obj = _.isUndefined(section) ? config : _.get(config, section, config);\n\n    const mappedObj = _.mapKeys(\n      obj,\n      (__, prop) => schema.properties[prop]?.appiumCliDest ?? _.camelCase(prop)\n    );\n\n    return _.mapValues(mappedObj, (value, property) => {\n      const nextSection = section ? `${section}.${property}` : property;\n      return isSchemaTypeObject(value) ? normalize(config, nextSection) : value;\n    });\n  };\n\n  /**\n   * Returns `true` if the schema prop references an object, or if it's an object itself\n   * @param {import('ajv').SchemaObject|object} schema - Referencing schema object\n   */\n  const isSchemaTypeObject = (schema) => Boolean(schema.properties);\n\n  return normalize(config);\n}\n\n/**\n * Result of calling {@link readConfigFile}.\n * @typedef ReadConfigFileResult\n * @property {import('ajv').ErrorObject[]} [errors] - Validation errors\n * @property {string} [filepath] - The path to the config file, if found\n * @property {boolean} [isEmpty] - If `true`, the config file exists but is empty\n * @property {NormalizedAppiumConfig} [config] - The parsed configuration\n * @property {string|import('@sidvind/better-ajv-errors').IOutputError[]} [reason] - Human-readable error messages and suggestions. If the `pretty` option is `true`, this will be a nice string to print.\n */\n\n/**\n * Options for {@link readConfigFile}.\n * @typedef ReadConfigFileOptions\n * @property {boolean} [pretty=true] If `false`, do not use color and fancy formatting in the `reason` property of the {@link ReadConfigFileResult}. The value of `reason` is then suitable for machine-reading.\n */\n\n/**\n * This is an `AsyncSearcher` which is inexplicably _not_ exported by the `lilconfig` type definition.\n * @typedef {ReturnType<import('lilconfig')[\"lilconfig\"]>} LilconfigAsyncSearcher\n */\n\n/**\n * The contents of an Appium config file. Generated from schema\n * @typedef {import('@appium/types').AppiumConfig} AppiumConfig\n */\n\n/**\n * The contents of an Appium config file with camelcased property names (and using `appiumCliDest` value if present). Generated from {@link AppiumConfig}\n * @typedef {import('@appium/types').NormalizedAppiumConfig} NormalizedAppiumConfig\n */\n\n/**\n * The string should be a raw JSON string.\n * @typedef {string} RawJson\n */\n\n/**\n * Options for {@link formatErrors}.\n * @typedef FormatConfigErrorsOptions\n * @property {import('./config-file').RawJson} [json] - Raw JSON config (as string)\n * @property {boolean} [pretty=true] - Whether to format errors as a CLI-friendly string\n * @property {string}  [schemaId] - Specific ID of a prop; otherwise entire schema\n */\n"],"mappings":"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"}
|