appium 2.0.0-beta.26 → 2.0.0-beta.29
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 +215 -0
- package/build/lib/appium.d.ts.map +1 -0
- package/build/lib/appium.js +62 -54
- package/build/lib/cli/args.d.ts +20 -0
- package/build/lib/cli/args.d.ts.map +1 -0
- package/build/lib/cli/args.js +1 -1
- package/build/lib/cli/driver-command.d.ts +36 -0
- package/build/lib/cli/driver-command.d.ts.map +1 -0
- package/build/lib/cli/driver-command.js +8 -7
- package/build/lib/cli/extension-command.d.ts +345 -0
- package/build/lib/cli/extension-command.d.ts.map +1 -0
- package/build/lib/cli/extension-command.js +52 -38
- package/build/lib/cli/extension.d.ts +14 -0
- package/build/lib/cli/extension.d.ts.map +1 -0
- package/build/lib/cli/extension.js +7 -2
- package/build/lib/cli/parser.d.ts +79 -0
- package/build/lib/cli/parser.d.ts.map +1 -0
- package/build/lib/cli/parser.js +1 -1
- package/build/lib/cli/plugin-command.d.ts +39 -0
- package/build/lib/cli/plugin-command.d.ts.map +1 -0
- package/build/lib/cli/plugin-command.js +6 -7
- package/build/lib/cli/utils.d.ts +29 -0
- package/build/lib/cli/utils.d.ts.map +1 -0
- package/build/lib/cli/utils.js +1 -1
- package/build/lib/config-file.d.ts +100 -0
- package/build/lib/config-file.d.ts.map +1 -0
- package/build/lib/config-file.js +1 -1
- package/build/lib/config.d.ts +40 -0
- package/build/lib/config.d.ts.map +1 -0
- package/build/lib/config.js +2 -2
- package/build/lib/constants.d.ts +48 -0
- package/build/lib/constants.d.ts.map +1 -0
- package/build/lib/constants.js +1 -1
- package/build/lib/extension/driver-config.d.ts +84 -0
- package/build/lib/extension/driver-config.d.ts.map +1 -0
- package/build/lib/extension/driver-config.js +1 -1
- package/build/lib/extension/extension-config.d.ts +170 -0
- package/build/lib/extension/extension-config.d.ts.map +1 -0
- package/build/lib/extension/extension-config.js +2 -2
- package/build/lib/extension/index.d.ts +39 -0
- package/build/lib/extension/index.d.ts.map +1 -0
- package/build/lib/extension/index.js +1 -1
- package/build/lib/extension/manifest.d.ts +174 -0
- package/build/lib/extension/manifest.d.ts.map +1 -0
- package/build/lib/extension/manifest.js +1 -1
- package/build/lib/extension/package-changed.d.ts +11 -0
- package/build/lib/extension/package-changed.d.ts.map +1 -0
- package/build/lib/extension/package-changed.js +1 -1
- package/build/lib/extension/plugin-config.d.ts +62 -0
- package/build/lib/extension/plugin-config.d.ts.map +1 -0
- package/build/lib/extension/plugin-config.js +1 -1
- package/build/lib/grid-register.d.ts +10 -0
- package/build/lib/grid-register.d.ts.map +1 -0
- package/build/lib/logger.d.ts +3 -0
- package/build/lib/logger.d.ts.map +1 -0
- package/build/lib/logsink.d.ts +4 -0
- package/build/lib/logsink.d.ts.map +1 -0
- package/build/lib/logsink.js +1 -1
- package/build/lib/main.d.ts +51 -0
- package/build/lib/main.d.ts.map +1 -0
- package/build/lib/main.js +1 -1
- package/build/lib/schema/arg-spec.d.ts +143 -0
- package/build/lib/schema/arg-spec.d.ts.map +1 -0
- package/build/lib/schema/arg-spec.js +1 -1
- package/build/lib/schema/cli-args.d.ts +19 -0
- package/build/lib/schema/cli-args.d.ts.map +1 -0
- package/build/lib/schema/cli-args.js +1 -1
- package/build/lib/schema/cli-transformers.d.ts +5 -0
- package/build/lib/schema/cli-transformers.d.ts.map +1 -0
- package/build/lib/schema/cli-transformers.js +1 -1
- package/build/lib/schema/index.d.ts +3 -0
- package/build/lib/schema/index.d.ts.map +1 -0
- package/build/lib/schema/keywords.d.ts +24 -0
- package/build/lib/schema/keywords.d.ts.map +1 -0
- package/build/lib/schema/keywords.js +1 -1
- package/build/lib/schema/schema.d.ts +259 -0
- package/build/lib/schema/schema.d.ts.map +1 -0
- package/build/lib/schema/schema.js +3 -3
- package/build/lib/utils.d.ts +66 -0
- package/build/lib/utils.d.ts.map +1 -0
- package/build/lib/utils.js +6 -4
- package/build/tsconfig.tsbuildinfo +1 -0
- package/lib/appium.js +163 -81
- package/lib/cli/args.js +1 -2
- package/lib/cli/driver-command.js +11 -8
- package/lib/cli/extension-command.js +129 -80
- package/lib/cli/extension.js +13 -3
- package/lib/cli/parser.js +1 -2
- package/lib/cli/plugin-command.js +16 -6
- package/lib/cli/utils.js +1 -1
- package/lib/config-file.js +3 -4
- package/lib/config.js +12 -8
- package/lib/constants.js +0 -1
- package/lib/extension/driver-config.js +31 -12
- package/lib/extension/extension-config.js +21 -22
- package/lib/extension/index.js +1 -2
- package/lib/extension/manifest.js +23 -127
- package/lib/extension/package-changed.js +0 -1
- package/lib/extension/plugin-config.js +9 -7
- package/lib/logsink.js +4 -0
- package/lib/main.js +9 -10
- package/lib/schema/arg-spec.js +10 -6
- package/lib/schema/cli-args.js +0 -1
- package/lib/schema/cli-transformers.js +0 -1
- package/lib/schema/keywords.js +0 -1
- package/lib/schema/schema.js +2 -3
- package/lib/utils.js +49 -16
- package/package.json +12 -14
- package/types/appium-manifest.d.ts +61 -0
- package/types/cli.d.ts +134 -0
- package/types/extension.d.ts +56 -0
- package/types/external-manifest.d.ts +58 -0
- package/types/index.d.ts +7 -0
- package/build/lib/appium-config.schema.json +0 -278
- package/build/lib/schema/appium-config-schema.js +0 -251
- package/lib/schema/appium-config-schema.js +0 -287
- package/types/appium-config.d.ts +0 -197
- package/types/types.d.ts +0 -245
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,"sources":["../../../lib/cli/args.js"],"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","serverArgsDisallowedInConfig","const"],"mappings":"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","sourcesContent":["// @ts-check\n\n// @ts-ignore\nimport _ from 'lodash';\nimport { DRIVER_TYPE, PLUGIN_TYPE, EXT_SUBCOMMAND_INSTALL, EXT_SUBCOMMAND_LIST, EXT_SUBCOMMAND_RUN, EXT_SUBCOMMAND_UNINSTALL, EXT_SUBCOMMAND_UPDATE } 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  [['--json'], {\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 * 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('../../types/types').CliExtensionSubcommand,ArgumentDefinitions>>} */(extensionArgs);\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    [['--installed'], {\n      required: false,\n      default: false,\n      action: 'store_true',\n      help: `List only installed ${type}s`,\n      dest: 'showInstalled'\n    }],\n    [['--updates'], {\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 * 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    [[type], {\n      type: 'str',\n      help: `Name of the ${type} to install, for example: ` +\n            type === DRIVER_TYPE ? DRIVER_EXAMPLE : PLUGIN_EXAMPLE,\n    }],\n    [['--source'], {\n      required: false,\n      default: null,\n      choices: INSTALL_TYPES_ARRAY,\n      help: `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    [['--package'], {\n      required: false,\n      default: null,\n      type: 'str',\n      help: `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    [[type], {\n      type: 'str',\n      help: 'Name of the driver to uninstall, for example: ' +\n            type === DRIVER_TYPE ? DRIVER_EXAMPLE : PLUGIN_EXAMPLE\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    [[type], {\n      type: 'str',\n      help: `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: ' + type === DRIVER_TYPE ? DRIVER_EXAMPLE : PLUGIN_EXAMPLE,\n    }],\n    [['--unsafe'], {\n      required: false,\n      default: false,\n      action: 'store_true',\n      help: `Include updates that might have a new major revision, and potentially include ` +\n            `breaking changes`,\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    [[type], {\n      type: 'str',\n      help: `Name of the ${type} to run a script from, for example: ` +\n            type === DRIVER_TYPE ? DRIVER_EXAMPLE : PLUGIN_EXAMPLE,\n    }],\n    [['scriptName'], {\n      default: null,\n      type: 'str',\n      help: `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 * 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([\n    ...toParserArgs(),\n    ...serverArgsDisallowedInConfig,\n  ]);\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 {\n  getServerArgs,\n  getExtensionArgs\n};\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"]}
|
|
144
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../lib/cli/args.js"],"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","serverArgsDisallowedInConfig","const"],"mappings":"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","sourcesContent":["\n// @ts-ignore\nimport _ from 'lodash';\nimport { DRIVER_TYPE, PLUGIN_TYPE, EXT_SUBCOMMAND_INSTALL, EXT_SUBCOMMAND_LIST, EXT_SUBCOMMAND_RUN, EXT_SUBCOMMAND_UNINSTALL, EXT_SUBCOMMAND_UPDATE } 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  [['--json'], {\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 * 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('../../types/cli').CliExtensionSubcommand,ArgumentDefinitions>>} */(extensionArgs);\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    [['--installed'], {\n      required: false,\n      default: false,\n      action: 'store_true',\n      help: `List only installed ${type}s`,\n      dest: 'showInstalled'\n    }],\n    [['--updates'], {\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 * 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    [[type], {\n      type: 'str',\n      help: `Name of the ${type} to install, for example: ` +\n            type === DRIVER_TYPE ? DRIVER_EXAMPLE : PLUGIN_EXAMPLE,\n    }],\n    [['--source'], {\n      required: false,\n      default: null,\n      choices: INSTALL_TYPES_ARRAY,\n      help: `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    [['--package'], {\n      required: false,\n      default: null,\n      type: 'str',\n      help: `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    [[type], {\n      type: 'str',\n      help: 'Name of the driver to uninstall, for example: ' +\n            type === DRIVER_TYPE ? DRIVER_EXAMPLE : PLUGIN_EXAMPLE\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    [[type], {\n      type: 'str',\n      help: `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: ' + type === DRIVER_TYPE ? DRIVER_EXAMPLE : PLUGIN_EXAMPLE,\n    }],\n    [['--unsafe'], {\n      required: false,\n      default: false,\n      action: 'store_true',\n      help: `Include updates that might have a new major revision, and potentially include ` +\n            `breaking changes`,\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    [[type], {\n      type: 'str',\n      help: `Name of the ${type} to run a script from, for example: ` +\n            type === DRIVER_TYPE ? DRIVER_EXAMPLE : PLUGIN_EXAMPLE,\n    }],\n    [['scriptName'], {\n      default: null,\n      type: 'str',\n      help: `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 * 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([\n    ...toParserArgs(),\n    ...serverArgsDisallowedInConfig,\n  ]);\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 {\n  getServerArgs,\n  getExtensionArgs\n};\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"]}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @extends {ExtensionCommand<import('../extension/manifest').DriverType>}
|
|
3
|
+
*/
|
|
4
|
+
export default class DriverCommand extends ExtensionCommand<"driver"> {
|
|
5
|
+
/**
|
|
6
|
+
* @param {DriverCommandOptions} opts
|
|
7
|
+
*/
|
|
8
|
+
constructor({ config, json }: DriverCommandOptions);
|
|
9
|
+
install({ driver, installType, packageName }: {
|
|
10
|
+
driver: any;
|
|
11
|
+
installType: any;
|
|
12
|
+
packageName: any;
|
|
13
|
+
}): Promise<import("./extension-command").ExtRecord<"driver">>;
|
|
14
|
+
uninstall({ driver }: {
|
|
15
|
+
driver: any;
|
|
16
|
+
}): Promise<import("./extension-command").ExtRecord<"driver">>;
|
|
17
|
+
update({ driver, unsafe }: {
|
|
18
|
+
driver: any;
|
|
19
|
+
unsafe: any;
|
|
20
|
+
}): Promise<import("./extension-command").ExtensionUpdateResult>;
|
|
21
|
+
run({ driver, scriptName }: {
|
|
22
|
+
driver: any;
|
|
23
|
+
scriptName: any;
|
|
24
|
+
}): Promise<import("./extension-command").RunOutput>;
|
|
25
|
+
getPostInstallText({ extName, extData }: {
|
|
26
|
+
extName: any;
|
|
27
|
+
extData: any;
|
|
28
|
+
}): string;
|
|
29
|
+
validateExtensionFields(appiumPkgData: any): void;
|
|
30
|
+
}
|
|
31
|
+
export type DriverCommandOptions = {
|
|
32
|
+
config: import('../extension/extension-config').ExtensionConfig<import('../extension/manifest').DriverType>;
|
|
33
|
+
json: boolean;
|
|
34
|
+
};
|
|
35
|
+
import ExtensionCommand from "./extension-command";
|
|
36
|
+
//# sourceMappingURL=driver-command.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"driver-command.d.ts","sourceRoot":"","sources":["../../../lib/cli/driver-command.js"],"names":[],"mappings":"AAMA;;GAEG;AACH;IAEE;;OAEG;IACH,8BAFW,oBAAoB,EAK9B;IAED;;;;mEAEC;IAED;;mEAEC;IAED;;;qEAEC;IAED;;;yDAEC;IAED;;;eAIC;IAED,kDAUC;CAEF;;YAIa,OAAO,+BAA+B,EAAE,eAAe,CAAC,OAAO,uBAAuB,EAAE,UAAU,CAAC;UACnG,OAAO"}
|
|
@@ -15,6 +15,8 @@ var _extensionCommand = _interopRequireDefault(require("./extension-command"));
|
|
|
15
15
|
|
|
16
16
|
var _constants = require("../constants");
|
|
17
17
|
|
|
18
|
+
require("@colors/colors");
|
|
19
|
+
|
|
18
20
|
const REQ_DRIVER_FIELDS = ['driverName', 'automationName', 'platformNames', 'mainClass'];
|
|
19
21
|
|
|
20
22
|
class DriverCommand extends _extensionCommand.default {
|
|
@@ -24,8 +26,7 @@ class DriverCommand extends _extensionCommand.default {
|
|
|
24
26
|
}) {
|
|
25
27
|
super({
|
|
26
28
|
config,
|
|
27
|
-
json
|
|
28
|
-
type: _constants.DRIVER_TYPE
|
|
29
|
+
json
|
|
29
30
|
});
|
|
30
31
|
this.knownExtensions = _constants.KNOWN_DRIVERS;
|
|
31
32
|
}
|
|
@@ -35,7 +36,7 @@ class DriverCommand extends _extensionCommand.default {
|
|
|
35
36
|
installType,
|
|
36
37
|
packageName
|
|
37
38
|
}) {
|
|
38
|
-
return await super.
|
|
39
|
+
return await super._install({
|
|
39
40
|
ext: driver,
|
|
40
41
|
installType,
|
|
41
42
|
packageName
|
|
@@ -45,7 +46,7 @@ class DriverCommand extends _extensionCommand.default {
|
|
|
45
46
|
async uninstall({
|
|
46
47
|
driver
|
|
47
48
|
}) {
|
|
48
|
-
return await super.
|
|
49
|
+
return await super._uninstall({
|
|
49
50
|
ext: driver
|
|
50
51
|
});
|
|
51
52
|
}
|
|
@@ -54,7 +55,7 @@ class DriverCommand extends _extensionCommand.default {
|
|
|
54
55
|
driver,
|
|
55
56
|
unsafe
|
|
56
57
|
}) {
|
|
57
|
-
return await super.
|
|
58
|
+
return await super._update({
|
|
58
59
|
ext: driver,
|
|
59
60
|
unsafe
|
|
60
61
|
});
|
|
@@ -64,7 +65,7 @@ class DriverCommand extends _extensionCommand.default {
|
|
|
64
65
|
driver,
|
|
65
66
|
scriptName
|
|
66
67
|
}) {
|
|
67
|
-
return await super.
|
|
68
|
+
return await super._run({
|
|
68
69
|
ext: driver,
|
|
69
70
|
scriptName
|
|
70
71
|
});
|
|
@@ -88,4 +89,4 @@ class DriverCommand extends _extensionCommand.default {
|
|
|
88
89
|
}
|
|
89
90
|
|
|
90
91
|
exports.default = DriverCommand;
|
|
91
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
92
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL2xpYi9jbGkvZHJpdmVyLWNvbW1hbmQuanMiXSwibmFtZXMiOlsiUkVRX0RSSVZFUl9GSUVMRFMiLCJEcml2ZXJDb21tYW5kIiwiRXh0ZW5zaW9uQ29tbWFuZCIsImNvbnN0cnVjdG9yIiwiY29uZmlnIiwianNvbiIsImtub3duRXh0ZW5zaW9ucyIsIktOT1dOX0RSSVZFUlMiLCJpbnN0YWxsIiwiZHJpdmVyIiwiaW5zdGFsbFR5cGUiLCJwYWNrYWdlTmFtZSIsIl9pbnN0YWxsIiwiZXh0IiwidW5pbnN0YWxsIiwiX3VuaW5zdGFsbCIsInVwZGF0ZSIsInVuc2FmZSIsIl91cGRhdGUiLCJydW4iLCJzY3JpcHROYW1lIiwiX3J1biIsImdldFBvc3RJbnN0YWxsVGV4dCIsImV4dE5hbWUiLCJleHREYXRhIiwidmVyc2lvbiIsImdyZWVuIiwiYXV0b21hdGlvbk5hbWUiLCJKU09OIiwic3RyaW5naWZ5IiwicGxhdGZvcm1OYW1lcyIsInZhbGlkYXRlRXh0ZW5zaW9uRmllbGRzIiwiYXBwaXVtUGtnRGF0YSIsIm1pc3NpbmdGaWVsZHMiLCJyZWR1Y2UiLCJhY2MiLCJmaWVsZCIsIl8iLCJpc0VtcHR5IiwiRXJyb3IiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7O0FBQUE7O0FBQ0E7O0FBQ0E7O0FBQ0E7O0FBRUEsTUFBTUEsaUJBQWlCLEdBQUcsQ0FBQyxZQUFELEVBQWUsZ0JBQWYsRUFBaUMsZUFBakMsRUFBa0QsV0FBbEQsQ0FBMUI7O0FBSWUsTUFBTUMsYUFBTixTQUE0QkMseUJBQTVCLENBQTZDO0FBSzFEQyxFQUFBQSxXQUFXLENBQUU7QUFBQ0MsSUFBQUEsTUFBRDtBQUFTQyxJQUFBQTtBQUFULEdBQUYsRUFBa0I7QUFDM0IsVUFBTTtBQUFDRCxNQUFBQSxNQUFEO0FBQVNDLE1BQUFBO0FBQVQsS0FBTjtBQUNBLFNBQUtDLGVBQUwsR0FBdUJDLHdCQUF2QjtBQUNEOztBQUVZLFFBQVBDLE9BQU8sQ0FBRTtBQUFDQyxJQUFBQSxNQUFEO0FBQVNDLElBQUFBLFdBQVQ7QUFBc0JDLElBQUFBO0FBQXRCLEdBQUYsRUFBc0M7QUFDakQsV0FBTyxNQUFNLE1BQU1DLFFBQU4sQ0FBZTtBQUFDQyxNQUFBQSxHQUFHLEVBQUVKLE1BQU47QUFBY0MsTUFBQUEsV0FBZDtBQUEyQkMsTUFBQUE7QUFBM0IsS0FBZixDQUFiO0FBQ0Q7O0FBRWMsUUFBVEcsU0FBUyxDQUFFO0FBQUNMLElBQUFBO0FBQUQsR0FBRixFQUFZO0FBQ3pCLFdBQU8sTUFBTSxNQUFNTSxVQUFOLENBQWlCO0FBQUNGLE1BQUFBLEdBQUcsRUFBRUo7QUFBTixLQUFqQixDQUFiO0FBQ0Q7O0FBRVcsUUFBTk8sTUFBTSxDQUFFO0FBQUNQLElBQUFBLE1BQUQ7QUFBU1EsSUFBQUE7QUFBVCxHQUFGLEVBQW9CO0FBQzlCLFdBQU8sTUFBTSxNQUFNQyxPQUFOLENBQWM7QUFBQ0wsTUFBQUEsR0FBRyxFQUFFSixNQUFOO0FBQWNRLE1BQUFBO0FBQWQsS0FBZCxDQUFiO0FBQ0Q7O0FBRVEsUUFBSEUsR0FBRyxDQUFFO0FBQUNWLElBQUFBLE1BQUQ7QUFBU1csSUFBQUE7QUFBVCxHQUFGLEVBQXdCO0FBQy9CLFdBQU8sTUFBTSxNQUFNQyxJQUFOLENBQVc7QUFBQ1IsTUFBQUEsR0FBRyxFQUFFSixNQUFOO0FBQWNXLE1BQUFBO0FBQWQsS0FBWCxDQUFiO0FBQ0Q7O0FBRURFLEVBQUFBLGtCQUFrQixDQUFFO0FBQUNDLElBQUFBLE9BQUQ7QUFBVUMsSUFBQUE7QUFBVixHQUFGLEVBQXNCO0FBQ3RDLFdBQVEsVUFBU0QsT0FBUSxJQUFHQyxPQUFPLENBQUNDLE9BQVEsMkJBQXJDLENBQWdFQyxLQUFoRSxHQUNDLHFCQUFvQkYsT0FBTyxDQUFDRyxjQUFSLENBQXVCRCxLQUFNLElBRGxELEdBRUMsb0JBQW1CRSxJQUFJLENBQUNDLFNBQUwsQ0FBZUwsT0FBTyxDQUFDTSxhQUF2QixFQUFzQ0osS0FBTSxFQUZ2RTtBQUdEOztBQUVESyxFQUFBQSx1QkFBdUIsQ0FBRUMsYUFBRixFQUFpQjtBQUN0QyxVQUFNQyxhQUFhLEdBQUdqQyxpQkFBaUIsQ0FBQ2tDLE1BQWxCLENBQXlCLENBQUNDLEdBQUQsRUFBTUMsS0FBTixLQUM3Q0osYUFBYSxDQUFDSSxLQUFELENBQWIsR0FBdUJELEdBQXZCLEdBQTZCLENBQUMsR0FBR0EsR0FBSixFQUFTQyxLQUFULENBRFQsRUFFbkIsRUFGbUIsQ0FBdEI7O0FBSUEsUUFBSSxDQUFDQyxnQkFBRUMsT0FBRixDQUFVTCxhQUFWLENBQUwsRUFBK0I7QUFDN0IsWUFBTSxJQUFJTSxLQUFKLENBQVcsaUVBQUQsR0FDQyxnQ0FBK0JYLElBQUksQ0FBQ0MsU0FBTCxDQUFlSSxhQUFmLENBQThCLEVBRHhFLENBQU47QUFFRDtBQUVGOztBQTFDeUQiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgXyBmcm9tICdsb2Rhc2gnO1xuaW1wb3J0IEV4dGVuc2lvbkNvbW1hbmQgZnJvbSAnLi9leHRlbnNpb24tY29tbWFuZCc7XG5pbXBvcnQgeyBLTk9XTl9EUklWRVJTIH0gZnJvbSAnLi4vY29uc3RhbnRzJztcbmltcG9ydCAnQGNvbG9ycy9jb2xvcnMnO1xuXG5jb25zdCBSRVFfRFJJVkVSX0ZJRUxEUyA9IFsnZHJpdmVyTmFtZScsICdhdXRvbWF0aW9uTmFtZScsICdwbGF0Zm9ybU5hbWVzJywgJ21haW5DbGFzcyddO1xuLyoqXG4gKiBAZXh0ZW5kcyB7RXh0ZW5zaW9uQ29tbWFuZDxpbXBvcnQoJy4uL2V4dGVuc2lvbi9tYW5pZmVzdCcpLkRyaXZlclR5cGU+fVxuICovXG5leHBvcnQgZGVmYXVsdCBjbGFzcyBEcml2ZXJDb21tYW5kIGV4dGVuZHMgRXh0ZW5zaW9uQ29tbWFuZCB7XG5cbiAgLyoqXG4gICAqIEBwYXJhbSB7RHJpdmVyQ29tbWFuZE9wdGlvbnN9IG9wdHNcbiAgICovXG4gIGNvbnN0cnVjdG9yICh7Y29uZmlnLCBqc29ufSkge1xuICAgIHN1cGVyKHtjb25maWcsIGpzb259KTtcbiAgICB0aGlzLmtub3duRXh0ZW5zaW9ucyA9IEtOT1dOX0RSSVZFUlM7XG4gIH1cblxuICBhc3luYyBpbnN0YWxsICh7ZHJpdmVyLCBpbnN0YWxsVHlwZSwgcGFja2FnZU5hbWV9KSB7XG4gICAgcmV0dXJuIGF3YWl0IHN1cGVyLl9pbnN0YWxsKHtleHQ6IGRyaXZlciwgaW5zdGFsbFR5cGUsIHBhY2thZ2VOYW1lfSk7XG4gIH1cblxuICBhc3luYyB1bmluc3RhbGwgKHtkcml2ZXJ9KSB7XG4gICAgcmV0dXJuIGF3YWl0IHN1cGVyLl91bmluc3RhbGwoe2V4dDogZHJpdmVyfSk7XG4gIH1cblxuICBhc3luYyB1cGRhdGUgKHtkcml2ZXIsIHVuc2FmZX0pIHtcbiAgICByZXR1cm4gYXdhaXQgc3VwZXIuX3VwZGF0ZSh7ZXh0OiBkcml2ZXIsIHVuc2FmZX0pO1xuICB9XG5cbiAgYXN5bmMgcnVuICh7ZHJpdmVyLCBzY3JpcHROYW1lfSkge1xuICAgIHJldHVybiBhd2FpdCBzdXBlci5fcnVuKHtleHQ6IGRyaXZlciwgc2NyaXB0TmFtZX0pO1xuICB9XG5cbiAgZ2V0UG9zdEluc3RhbGxUZXh0ICh7ZXh0TmFtZSwgZXh0RGF0YX0pIHtcbiAgICByZXR1cm4gYERyaXZlciAke2V4dE5hbWV9QCR7ZXh0RGF0YS52ZXJzaW9ufSBzdWNjZXNzZnVsbHkgaW5zdGFsbGVkXFxuYC5ncmVlbiArXG4gICAgICAgICAgIGAtIGF1dG9tYXRpb25OYW1lOiAke2V4dERhdGEuYXV0b21hdGlvbk5hbWUuZ3JlZW59XFxuYCArXG4gICAgICAgICAgIGAtIHBsYXRmb3JtTmFtZXM6ICR7SlNPTi5zdHJpbmdpZnkoZXh0RGF0YS5wbGF0Zm9ybU5hbWVzKS5ncmVlbn1gO1xuICB9XG5cbiAgdmFsaWRhdGVFeHRlbnNpb25GaWVsZHMgKGFwcGl1bVBrZ0RhdGEpIHtcbiAgICBjb25zdCBtaXNzaW5nRmllbGRzID0gUkVRX0RSSVZFUl9GSUVMRFMucmVkdWNlKChhY2MsIGZpZWxkKSA9PiAoXG4gICAgICBhcHBpdW1Qa2dEYXRhW2ZpZWxkXSA/IGFjYyA6IFsuLi5hY2MsIGZpZWxkXVxuICAgICksIFtdKTtcblxuICAgIGlmICghXy5pc0VtcHR5KG1pc3NpbmdGaWVsZHMpKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoYEluc3RhbGxlZCBkcml2ZXIgZGlkIG5vdCBleHBvc2UgY29ycmVjdCBmaWVsZHMgZm9yIGNvbXBhYmlsaXR5IGAgK1xuICAgICAgICAgICAgICAgICAgICAgIGB3aXRoIEFwcGl1bS4gTWlzc2luZyBmaWVsZHM6ICR7SlNPTi5zdHJpbmdpZnkobWlzc2luZ0ZpZWxkcyl9YCk7XG4gICAgfVxuXG4gIH1cblxufVxuXG4vKipcbiAqIEB0eXBlZGVmIERyaXZlckNvbW1hbmRPcHRpb25zXG4gKiBAcHJvcGVydHkge2ltcG9ydCgnLi4vZXh0ZW5zaW9uL2V4dGVuc2lvbi1jb25maWcnKS5FeHRlbnNpb25Db25maWc8aW1wb3J0KCcuLi9leHRlbnNpb24vbWFuaWZlc3QnKS5Ecml2ZXJUeXBlPn0gY29uZmlnXG4gKiBAcHJvcGVydHkge2Jvb2xlYW59IGpzb25cbiAqL1xuIl19
|
|
@@ -0,0 +1,345 @@
|
|
|
1
|
+
export default ExtensionCommand;
|
|
2
|
+
/**
|
|
3
|
+
* Options for the {@linkcode ExtensionCommand } constructor
|
|
4
|
+
*/
|
|
5
|
+
export type ExtensionCommandOptions<ExtType extends import("../../types").ExtensionType> = {
|
|
6
|
+
/**
|
|
7
|
+
* - the `DriverConfig` or `PluginConfig` instance used for this command
|
|
8
|
+
*/
|
|
9
|
+
config: ExtensionConfig<ExtType>;
|
|
10
|
+
/**
|
|
11
|
+
* - whether the output of this command should be JSON or text
|
|
12
|
+
*/
|
|
13
|
+
json: boolean;
|
|
14
|
+
};
|
|
15
|
+
/**
|
|
16
|
+
* Extra stuff about extensions; used indirectly by {@linkcode ExtensionCommand.list }.
|
|
17
|
+
*/
|
|
18
|
+
export type ExtensionMetadata = {
|
|
19
|
+
/**
|
|
20
|
+
* - If `true`, the extension is installed
|
|
21
|
+
*/
|
|
22
|
+
installed: boolean;
|
|
23
|
+
/**
|
|
24
|
+
* - If the extension is installed, the version it can be updated to
|
|
25
|
+
*/
|
|
26
|
+
updateVersion: string | null;
|
|
27
|
+
/**
|
|
28
|
+
* - Same as above, but a major version bump
|
|
29
|
+
*/
|
|
30
|
+
unsafeUpdateVersion: string | null;
|
|
31
|
+
/**
|
|
32
|
+
* - If the extension is installed and the latest
|
|
33
|
+
*/
|
|
34
|
+
upToDate: boolean;
|
|
35
|
+
};
|
|
36
|
+
export type ExtensionType = import('../../types').ExtensionType;
|
|
37
|
+
export type DriverType = import('../../types').DriverType;
|
|
38
|
+
export type PluginType = import('../../types').PluginType;
|
|
39
|
+
export type ExtRecord<ExtType extends import("../../types").ExtensionType> = import('../../types/appium-manifest').ExtRecord<ExtType>;
|
|
40
|
+
export type ExtensionConfig<ExtType extends import("../../types").ExtensionType> = import('../extension/extension-config').ExtensionConfig<ExtType>;
|
|
41
|
+
export type ExtMetadata<ExtType extends import("../../types").ExtensionType> = import('../../types/external-manifest').ExtMetadata<ExtType>;
|
|
42
|
+
export type ExtManifest<ExtType extends import("../../types").ExtensionType> = import('../../types/appium-manifest').ExtManifest<ExtType>;
|
|
43
|
+
export type ExtPackageJson<ExtType extends import("../../types").ExtensionType> = import('../../types/external-manifest').ExtPackageJson<ExtType>;
|
|
44
|
+
/**
|
|
45
|
+
* Possible return value for {@linkcode ExtensionCommand.list }
|
|
46
|
+
*/
|
|
47
|
+
export type UninstalledExtensionListData = {
|
|
48
|
+
pkgName: string;
|
|
49
|
+
installed: false;
|
|
50
|
+
};
|
|
51
|
+
/**
|
|
52
|
+
* Possible return value for {@linkcode ExtensionCommand.list }
|
|
53
|
+
*/
|
|
54
|
+
export type InstalledExtensionListData = import('../../types/appium-manifest').InternalMetadata & ExtensionMetadata;
|
|
55
|
+
/**
|
|
56
|
+
* Return value of {@linkcode ExtensionCommand.list }.
|
|
57
|
+
*/
|
|
58
|
+
export type ExtensionListData = Record<string, InstalledExtensionListData | UninstalledExtensionListData>;
|
|
59
|
+
/**
|
|
60
|
+
* Options for {@linkcode ExtensionCommand._run }.
|
|
61
|
+
*/
|
|
62
|
+
export type RunOptions = {
|
|
63
|
+
/**
|
|
64
|
+
* - name of the extension to run a script from
|
|
65
|
+
*/
|
|
66
|
+
ext: string;
|
|
67
|
+
/**
|
|
68
|
+
* - name of the script to run
|
|
69
|
+
*/
|
|
70
|
+
scriptName: string;
|
|
71
|
+
};
|
|
72
|
+
/**
|
|
73
|
+
* Return value of {@linkcode ExtensionCommand._run }
|
|
74
|
+
*/
|
|
75
|
+
export type RunOutput = {
|
|
76
|
+
/**
|
|
77
|
+
* - error message if script ran unsuccessfully, otherwise undefined
|
|
78
|
+
*/
|
|
79
|
+
error?: string | undefined;
|
|
80
|
+
/**
|
|
81
|
+
* - script output
|
|
82
|
+
*/
|
|
83
|
+
output: string[];
|
|
84
|
+
};
|
|
85
|
+
/**
|
|
86
|
+
* Options for {@linkcode ExtensionCommand._update }.
|
|
87
|
+
*/
|
|
88
|
+
export type ExtensionUpdateOpts = {
|
|
89
|
+
/**
|
|
90
|
+
* - the name of the extension to update
|
|
91
|
+
*/
|
|
92
|
+
ext: string;
|
|
93
|
+
/**
|
|
94
|
+
* - if true, will perform unsafe updates past major revision boundaries
|
|
95
|
+
*/
|
|
96
|
+
unsafe: boolean;
|
|
97
|
+
};
|
|
98
|
+
/**
|
|
99
|
+
* Return value of {@linkcode ExtensionCommand._update }.
|
|
100
|
+
*/
|
|
101
|
+
export type ExtensionUpdateResult = {
|
|
102
|
+
/**
|
|
103
|
+
* - map of ext names to error objects
|
|
104
|
+
*/
|
|
105
|
+
errors: Record<string, Error>;
|
|
106
|
+
/**
|
|
107
|
+
* - map of ext names to {@linkcode UpdateReport }s
|
|
108
|
+
*/
|
|
109
|
+
updates: Record<string, UpdateReport>;
|
|
110
|
+
};
|
|
111
|
+
/**
|
|
112
|
+
* Part of result of {@linkcode ExtensionCommand._update }.
|
|
113
|
+
*/
|
|
114
|
+
export type UpdateReport = {
|
|
115
|
+
/**
|
|
116
|
+
* - version the extension was updated from
|
|
117
|
+
*/
|
|
118
|
+
from: string;
|
|
119
|
+
/**
|
|
120
|
+
* - version the extension was updated to
|
|
121
|
+
*/
|
|
122
|
+
to: string;
|
|
123
|
+
};
|
|
124
|
+
/**
|
|
125
|
+
* Options for {@linkcode ExtensionCommand._uninstall }.
|
|
126
|
+
*/
|
|
127
|
+
export type UninstallOpts = {
|
|
128
|
+
/**
|
|
129
|
+
* - the name or spec of an extension to uninstall
|
|
130
|
+
*/
|
|
131
|
+
ext: string;
|
|
132
|
+
};
|
|
133
|
+
/**
|
|
134
|
+
* Used by {@linkcode ExtensionCommand.getPostInstallText }
|
|
135
|
+
*/
|
|
136
|
+
export type ExtensionArgs = {
|
|
137
|
+
/**
|
|
138
|
+
* - the name of an extension
|
|
139
|
+
*/
|
|
140
|
+
extName: string;
|
|
141
|
+
/**
|
|
142
|
+
* - the data for an installed extension
|
|
143
|
+
*/
|
|
144
|
+
extData: object;
|
|
145
|
+
};
|
|
146
|
+
/**
|
|
147
|
+
* Options for {@linkcode ExtensionCommand.installViaNpm }
|
|
148
|
+
*/
|
|
149
|
+
export type InstallViaNpmArgs = {
|
|
150
|
+
/**
|
|
151
|
+
* - the name or spec of an extension to install
|
|
152
|
+
*/
|
|
153
|
+
ext: string;
|
|
154
|
+
/**
|
|
155
|
+
* - the NPM package name of the extension
|
|
156
|
+
*/
|
|
157
|
+
pkgName: string;
|
|
158
|
+
/**
|
|
159
|
+
* - the specific version of the NPM package
|
|
160
|
+
*/
|
|
161
|
+
pkgVer?: string | undefined;
|
|
162
|
+
};
|
|
163
|
+
/**
|
|
164
|
+
* Object returned by {@linkcode ExtensionCommand.checkForExtensionUpdate }
|
|
165
|
+
*/
|
|
166
|
+
export type PossibleUpdates = {
|
|
167
|
+
/**
|
|
168
|
+
* - current version
|
|
169
|
+
*/
|
|
170
|
+
current: string;
|
|
171
|
+
/**
|
|
172
|
+
* - version we can safely update to if it exists, or null
|
|
173
|
+
*/
|
|
174
|
+
safeUpdate: string | null;
|
|
175
|
+
/**
|
|
176
|
+
* - version we can unsafely update to if it exists, or null
|
|
177
|
+
*/
|
|
178
|
+
unsafeUpdate: string | null;
|
|
179
|
+
};
|
|
180
|
+
/**
|
|
181
|
+
* Options for {@linkcode ExtensionCommand._install }
|
|
182
|
+
*/
|
|
183
|
+
export type InstallArgs = {
|
|
184
|
+
/**
|
|
185
|
+
* - the name or spec of an extension to install
|
|
186
|
+
*/
|
|
187
|
+
ext: string;
|
|
188
|
+
/**
|
|
189
|
+
* - how to install this extension. One of the INSTALL_TYPES
|
|
190
|
+
*/
|
|
191
|
+
installType: import('../../types/appium-manifest').InstallType;
|
|
192
|
+
/**
|
|
193
|
+
* - for git/github installs, the extension node package name
|
|
194
|
+
*/
|
|
195
|
+
packageName?: string | undefined;
|
|
196
|
+
};
|
|
197
|
+
/**
|
|
198
|
+
* Returned by {@linkcode ExtensionCommand.getExtensionFields }
|
|
199
|
+
*/
|
|
200
|
+
export type ExtensionFields<ExtType extends import("../../types").ExtensionType> = ExtMetadata<ExtType> & {
|
|
201
|
+
pkgName: string;
|
|
202
|
+
version: string;
|
|
203
|
+
} & import('../../types/external-manifest').CommonMetadata;
|
|
204
|
+
export type KnownExtensions<ExtType extends import("../../types").ExtensionType> = ExtType extends DriverType ? typeof import('../constants').KNOWN_DRIVERS : ExtType extends PluginType ? typeof import('../constants').KNOWN_PLUGINS : never;
|
|
205
|
+
/**
|
|
206
|
+
* @template {ExtensionType} ExtType
|
|
207
|
+
*/
|
|
208
|
+
export class ExtensionCommand<ExtType extends import("../../types").ExtensionType> {
|
|
209
|
+
/**
|
|
210
|
+
* Build an ExtensionCommand
|
|
211
|
+
* @param {ExtensionCommandOptions<ExtType>} opts
|
|
212
|
+
*/
|
|
213
|
+
constructor({ config, json }: ExtensionCommandOptions<ExtType>);
|
|
214
|
+
/**
|
|
215
|
+
* This is the `DriverConfig` or `PluginConfig`, depending on `ExtType`.
|
|
216
|
+
* @type {ExtensionConfig<ExtType>}
|
|
217
|
+
*/
|
|
218
|
+
config: ExtensionConfig<ExtType>;
|
|
219
|
+
/**
|
|
220
|
+
* {@linkcode Record} of official plugins or drivers.
|
|
221
|
+
* @type {KnownExtensions<ExtType>}
|
|
222
|
+
*/
|
|
223
|
+
knownExtensions: KnownExtensions<ExtType>;
|
|
224
|
+
/**
|
|
225
|
+
* If `true`, command output has been requested as JSON.
|
|
226
|
+
* @type {boolean}
|
|
227
|
+
*/
|
|
228
|
+
isJsonOutput: boolean;
|
|
229
|
+
/**
|
|
230
|
+
* `driver` or `plugin`, depending on the `ExtensionConfig`.
|
|
231
|
+
*/
|
|
232
|
+
get type(): ExtType;
|
|
233
|
+
/**
|
|
234
|
+
* Take a CLI parse and run an extension command based on its type
|
|
235
|
+
*
|
|
236
|
+
* @param {object} args - a key/value object with CLI flags and values
|
|
237
|
+
* @return {Promise<object>} the result of the specific command which is executed
|
|
238
|
+
*/
|
|
239
|
+
execute(args: object): Promise<object>;
|
|
240
|
+
/**
|
|
241
|
+
* @typedef ListOptions
|
|
242
|
+
* @property {boolean} showInstalled - whether should show only installed extensions
|
|
243
|
+
* @property {boolean} showUpdates - whether should show available updates
|
|
244
|
+
*/
|
|
245
|
+
/**
|
|
246
|
+
* List extensions
|
|
247
|
+
*
|
|
248
|
+
* @param {ListOptions} opts
|
|
249
|
+
* @return {Promise<ExtensionListData>} map of extension names to extension data
|
|
250
|
+
*/
|
|
251
|
+
list({ showInstalled, showUpdates }: {
|
|
252
|
+
/**
|
|
253
|
+
* - whether should show only installed extensions
|
|
254
|
+
*/
|
|
255
|
+
showInstalled: boolean;
|
|
256
|
+
/**
|
|
257
|
+
* - whether should show available updates
|
|
258
|
+
*/
|
|
259
|
+
showUpdates: boolean;
|
|
260
|
+
}): Promise<ExtensionListData>;
|
|
261
|
+
/**
|
|
262
|
+
* Install an extension
|
|
263
|
+
*
|
|
264
|
+
* @param {InstallArgs} args
|
|
265
|
+
* @return {Promise<ExtRecord<ExtType>>} map of all installed extension names to extension data
|
|
266
|
+
*/
|
|
267
|
+
_install({ ext, installType, packageName }: InstallArgs): Promise<ExtRecord<ExtType>>;
|
|
268
|
+
/**
|
|
269
|
+
* Install an extension via NPM
|
|
270
|
+
*
|
|
271
|
+
* @param {InstallViaNpmArgs} args
|
|
272
|
+
*/
|
|
273
|
+
installViaNpm({ ext, pkgName, pkgVer }: InstallViaNpmArgs): Promise<ExtensionFields<ExtType>>;
|
|
274
|
+
/**
|
|
275
|
+
* Get the text which should be displayed to the user after an extension has been installed. This
|
|
276
|
+
* is designed to be overridden by drivers/plugins with their own particular text.
|
|
277
|
+
*
|
|
278
|
+
* @param {ExtensionArgs} args
|
|
279
|
+
* @returns {string}
|
|
280
|
+
*/
|
|
281
|
+
getPostInstallText(args: ExtensionArgs): string;
|
|
282
|
+
/**
|
|
283
|
+
* Take an NPM module's package.json and extract Appium driver information from a special
|
|
284
|
+
* 'appium' field in the JSON data. We need this information to e.g. determine which class to
|
|
285
|
+
* load as the main driver class, or to be able to detect incompatibilities between driver and
|
|
286
|
+
* appium versions.
|
|
287
|
+
*
|
|
288
|
+
* @param {ExtPackageJson<ExtType>} pkgJsonData - the package.json data for a driver module, as if it had been
|
|
289
|
+
* straightforwardly 'require'd
|
|
290
|
+
* @returns {ExtensionFields<ExtType>}
|
|
291
|
+
*/
|
|
292
|
+
getExtensionFields(pkgJsonData: ExtPackageJson<ExtType>): ExtensionFields<ExtType>;
|
|
293
|
+
/**
|
|
294
|
+
* For any package.json fields which a particular type of extension requires, validate the
|
|
295
|
+
* presence and form of those fields on the package.json data, throwing an error if anything is
|
|
296
|
+
* amiss.
|
|
297
|
+
*
|
|
298
|
+
* @param {ExtMetadata<ExtType>} appiumPkgData - the data in the "appium" field of package.json for an extension
|
|
299
|
+
*/
|
|
300
|
+
validateExtensionFields(appiumPkgData: ExtMetadata<ExtType>): void;
|
|
301
|
+
/**
|
|
302
|
+
* Uninstall an extension
|
|
303
|
+
*
|
|
304
|
+
* @param {UninstallOpts} opts
|
|
305
|
+
* @return {Promise<ExtRecord<ExtType>>} map of all installed extension names to extension data
|
|
306
|
+
*/
|
|
307
|
+
_uninstall({ ext }: UninstallOpts): Promise<ExtRecord<ExtType>>;
|
|
308
|
+
/**
|
|
309
|
+
* Attempt to update one or more drivers using NPM
|
|
310
|
+
*
|
|
311
|
+
* @param {ExtensionUpdateOpts} updateSpec
|
|
312
|
+
* @return {Promise<ExtensionUpdateResult>}
|
|
313
|
+
*/
|
|
314
|
+
_update({ ext, unsafe }: ExtensionUpdateOpts): Promise<ExtensionUpdateResult>;
|
|
315
|
+
/**
|
|
316
|
+
* Given an extension name, figure out what its highest possible version upgrade is, and also the
|
|
317
|
+
* highest possible safe upgrade.
|
|
318
|
+
*
|
|
319
|
+
* @param {string} ext - name of extension
|
|
320
|
+
* @return {Promise<PossibleUpdates>}
|
|
321
|
+
*/
|
|
322
|
+
checkForExtensionUpdate(ext: string): Promise<PossibleUpdates>;
|
|
323
|
+
/**
|
|
324
|
+
* Actually update an extension installed by NPM, using the NPM cli. And update the installation
|
|
325
|
+
* manifest.
|
|
326
|
+
*
|
|
327
|
+
* @param {string} ext - name of extension to update
|
|
328
|
+
* @param {string} version - version string identifier to update extension to
|
|
329
|
+
* @returns {Promise<void>}
|
|
330
|
+
*/
|
|
331
|
+
updateExtension(ext: string, version: string): Promise<void>;
|
|
332
|
+
/**
|
|
333
|
+
* Runs a script cached inside the "scripts" field under "appium"
|
|
334
|
+
* inside of the driver/plugins "package.json" file. Will throw
|
|
335
|
+
* an error if the driver/plugin does not contain a "scripts" field
|
|
336
|
+
* underneath the "appium" field in its package.json, if the
|
|
337
|
+
* "scripts" field is not a plain object, or if the scriptName is
|
|
338
|
+
* not found within "scripts" object.
|
|
339
|
+
*
|
|
340
|
+
* @param {RunOptions} opts
|
|
341
|
+
* @return {Promise<RunOutput>}
|
|
342
|
+
*/
|
|
343
|
+
_run({ ext, scriptName }: RunOptions): Promise<RunOutput>;
|
|
344
|
+
}
|
|
345
|
+
//# sourceMappingURL=extension-command.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"extension-command.d.ts","sourceRoot":"","sources":["../../../lib/cli/extension-command.js"],"names":[],"mappings":"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"}
|