appium-android-driver 4.48.2 → 4.49.0

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.
@@ -17,6 +17,8 @@ var _logger = _interopRequireDefault(require("../logger"));
17
17
 
18
18
  var _androidHelpers = require("../android-helpers");
19
19
 
20
+ var _appiumBaseDriver = require("appium-base-driver");
21
+
20
22
  const APP_EXTENSIONS = ['.apk', '.apks'];
21
23
  let commands = {};
22
24
  exports.commands = commands;
@@ -99,8 +101,20 @@ commands.installApp = async function installApp(appPath, options = {}) {
99
101
  await this.adb.install(localPath, options);
100
102
  };
101
103
 
104
+ commands.mobileClearApp = async function mobileClearApp(opts = {}) {
105
+ const {
106
+ appId
107
+ } = opts;
108
+
109
+ if (!appId) {
110
+ throw new _appiumBaseDriver.errors.InvalidArgumentError(`The 'appId' argument is required`);
111
+ }
112
+
113
+ await this.adb.clear(appId);
114
+ };
115
+
102
116
  var _default = commands;
103
117
  exports.default = _default;require('source-map-support').install();
104
118
 
105
119
 
106
- //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/commands/app-management.js"],"names":["APP_EXTENSIONS","commands","isAppInstalled","appId","adb","queryAppState","log","info","APP_STATE","NOT_INSTALLED","processExists","NOT_RUNNING","line","dumpWindows","split","includes","RUNNING_IN_FOREGROUND","RUNNING_IN_BACKGROUND","activateApp","cmd","output","debug","join","shell","e","errorAndThrow","message","removeApp","options","uninstallApk","terminateApp","forceStop","timeout","util","hasValue","isNaN","parseInt","waitMs","intervalMs","installApp","appPath","localPath","helpers","configureApp","install"],"mappings":"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","sourcesContent":["import { waitForCondition } from 'asyncbox';\nimport { util } from 'appium-support';\nimport log from '../logger';\nimport { APP_STATE } from '../android-helpers';\n\nconst APP_EXTENSIONS = ['.apk', '.apks'];\n\nlet commands = {};\n\n/**\n * Verify whether an application is installed or not\n *\n * @param {string} appId - Application package identifier\n * @returns {boolean} true if the app is installed\n */\ncommands.isAppInstalled = async function isAppInstalled (appId) {\n  return await this.adb.isAppInstalled(appId);\n};\n\n/**\n * Queries the current state of the app.\n *\n * @param {string} appId - Application package identifier\n * @returns {number} The corresponding constant, which describes\n *                   the current application state:\n * 0 - is the app is not installed\n * 1 - if the app is installed, but is not running\n * 3 - if the app is running in the background\n * 4 - if the app is running in the foreground\n */\ncommands.queryAppState = async function queryAppState (appId) {\n  log.info(`Querying the state of '${appId}'`);\n  if (!await this.adb.isAppInstalled(appId)) {\n    return APP_STATE.NOT_INSTALLED;\n  }\n  if (!await this.adb.processExists(appId)) {\n    return APP_STATE.NOT_RUNNING;\n  }\n  for (const line of (await this.adb.dumpWindows()).split('\\n')) {\n    if (line.includes(appId) && (line.includes('mCurrentFocus') || line.includes('mFocusedApp'))) {\n      return APP_STATE.RUNNING_IN_FOREGROUND;\n    }\n  }\n  return APP_STATE.RUNNING_IN_BACKGROUND;\n};\n\n/**\n * Activates the given application or launches it if necessary.\n * The action is done with monkey tool and literally simulates\n * clicking the corresponding application icon on the dashboard.\n *\n * @param {string} appId - Application package identifier\n */\ncommands.activateApp = async function activateApp (appId) {\n  const cmd = ['monkey',\n    '-p', appId,\n    '-c', 'android.intent.category.LAUNCHER',\n    '1'];\n  let output = '';\n  try {\n    log.debug(`Activating '${appId}' with 'adb shell ${cmd.join(' ')}' command`);\n    output = await this.adb.shell(cmd);\n    log.debug(`Command stdout: ${output}`);\n  } catch (e) {\n    log.errorAndThrow(`Cannot activate '${appId}'. Original error: ${e.message}`);\n  }\n  if (output.includes('monkey aborted')) {\n    log.errorAndThrow(`Cannot activate '${appId}'. Are you sure it is installed?`);\n  }\n};\n\n/**\n * @typedef {Object} UninstallOptions\n * @property {number} timeout [20000] - The count of milliseconds to wait until the\n *                                      app is uninstalled.\n * @property {boolean} keepData [false] - Set to true in order to keep the\n *                                        application data and cache folders after uninstall.\n */\n\n/**\n * Remove the corresponding application if is installed.\n * The call is ignored if the app is not installed.\n *\n * @param {string} appId - Application package identifier\n * @param {?UninstallOptions} options - The set of removal options\n * @returns {boolean} True if the package was found on the device and\n *                    successfully uninstalled.\n */\ncommands.removeApp = async function removeApp (appId, options = {}) {\n  return await this.adb.uninstallApk(appId, options);\n};\n\n/**\n * @typedef {Object} TerminateOptions\n * @property {number|string} timeout [500] - The count of milliseconds to wait until the\n *                                           app is terminated.\n */\n\n/**\n * Terminates the app if it is running.\n *\n * @param {string} appId - Application package identifier\n * @param {?TerminateOptions} options - The set of application termination options\n * @returns {boolean} True if the app has been successfully terminated.\n * @throws {Error} if the app has not been terminated within the given timeout.\n */\ncommands.terminateApp = async function terminateApp (appId, options = {}) {\n  log.info(`Terminating '${appId}'`);\n  if (!(await this.adb.processExists(appId))) {\n    log.info(`The app '${appId}' is not running`);\n    return false;\n  }\n  await this.adb.forceStop(appId);\n  const timeout = util.hasValue(options.timeout) && !isNaN(options.timeout) ? parseInt(options.timeout, 10) : 500;\n  try {\n    await waitForCondition(async () => await this.queryAppState(appId) <= APP_STATE.NOT_RUNNING,\n                           {waitMs: timeout, intervalMs: 100});\n  } catch (e) {\n    log.errorAndThrow(`'${appId}' is still running after ${timeout}ms timeout`);\n  }\n  log.info(`'${appId}' has been successfully terminated`);\n  return true;\n};\n\n/**\n * @typedef {Object} InstallOptions\n * @property {number} timeout [60000] - The count of milliseconds to wait until the\n *                                      app is installed.\n * @property {boolean} allowTestPackages [false] - Set to true in order to allow test\n *                                                 packages installation.\n * @property {boolean} useSdcard [false] - Set to true to install the app on sdcard\n *                                         instead of the device memory.\n * @property {boolean} grantPermissions [false] - Set to true in order to grant all the\n *                                                permissions requested in the application's manifest\n *                                                automatically after the installation is completed\n *                                                under Android 6+.\n * @property {boolean} replace [true] - Set it to false if you don't want\n *                                      the application to be upgraded/reinstalled\n *                                      if it is already present on the device.\n */\n\n/**\n * Installs the given application to the device under test\n *\n * @param {string} appPath - The local apk path or a remote url\n * @param {?InstallOptions} options - The set of installation options\n * @throws {Error} if the given apk does not exist or is not reachable\n */\ncommands.installApp = async function installApp (appPath, options = {}) {\n  const localPath = await this.helpers.configureApp(appPath, APP_EXTENSIONS);\n  await this.adb.install(localPath, options);\n};\n\n\nexport { commands };\nexport default commands;\n"],"file":"lib/commands/app-management.js","sourceRoot":"../../.."}
120
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/commands/app-management.js"],"names":["APP_EXTENSIONS","commands","isAppInstalled","appId","adb","queryAppState","log","info","APP_STATE","NOT_INSTALLED","processExists","NOT_RUNNING","line","dumpWindows","split","includes","RUNNING_IN_FOREGROUND","RUNNING_IN_BACKGROUND","activateApp","cmd","output","debug","join","shell","e","errorAndThrow","message","removeApp","options","uninstallApk","terminateApp","forceStop","timeout","util","hasValue","isNaN","parseInt","waitMs","intervalMs","installApp","appPath","localPath","helpers","configureApp","install","mobileClearApp","opts","errors","InvalidArgumentError","clear"],"mappings":"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","sourcesContent":["import { waitForCondition } from 'asyncbox';\nimport { util } from 'appium-support';\nimport log from '../logger';\nimport { APP_STATE } from '../android-helpers';\nimport { errors } from 'appium-base-driver';\n\nconst APP_EXTENSIONS = ['.apk', '.apks'];\n\nlet commands = {};\n\n/**\n * Verify whether an application is installed or not\n *\n * @param {string} appId - Application package identifier\n * @returns {boolean} true if the app is installed\n */\ncommands.isAppInstalled = async function isAppInstalled (appId) {\n  return await this.adb.isAppInstalled(appId);\n};\n\n/**\n * Queries the current state of the app.\n *\n * @param {string} appId - Application package identifier\n * @returns {number} The corresponding constant, which describes\n *                   the current application state:\n * 0 - is the app is not installed\n * 1 - if the app is installed, but is not running\n * 3 - if the app is running in the background\n * 4 - if the app is running in the foreground\n */\ncommands.queryAppState = async function queryAppState (appId) {\n  log.info(`Querying the state of '${appId}'`);\n  if (!await this.adb.isAppInstalled(appId)) {\n    return APP_STATE.NOT_INSTALLED;\n  }\n  if (!await this.adb.processExists(appId)) {\n    return APP_STATE.NOT_RUNNING;\n  }\n  for (const line of (await this.adb.dumpWindows()).split('\\n')) {\n    if (line.includes(appId) && (line.includes('mCurrentFocus') || line.includes('mFocusedApp'))) {\n      return APP_STATE.RUNNING_IN_FOREGROUND;\n    }\n  }\n  return APP_STATE.RUNNING_IN_BACKGROUND;\n};\n\n/**\n * Activates the given application or launches it if necessary.\n * The action is done with monkey tool and literally simulates\n * clicking the corresponding application icon on the dashboard.\n *\n * @param {string} appId - Application package identifier\n */\ncommands.activateApp = async function activateApp (appId) {\n  const cmd = ['monkey',\n    '-p', appId,\n    '-c', 'android.intent.category.LAUNCHER',\n    '1'];\n  let output = '';\n  try {\n    log.debug(`Activating '${appId}' with 'adb shell ${cmd.join(' ')}' command`);\n    output = await this.adb.shell(cmd);\n    log.debug(`Command stdout: ${output}`);\n  } catch (e) {\n    log.errorAndThrow(`Cannot activate '${appId}'. Original error: ${e.message}`);\n  }\n  if (output.includes('monkey aborted')) {\n    log.errorAndThrow(`Cannot activate '${appId}'. Are you sure it is installed?`);\n  }\n};\n\n/**\n * @typedef {Object} UninstallOptions\n * @property {number} timeout [20000] - The count of milliseconds to wait until the\n *                                      app is uninstalled.\n * @property {boolean} keepData [false] - Set to true in order to keep the\n *                                        application data and cache folders after uninstall.\n */\n\n/**\n * Remove the corresponding application if is installed.\n * The call is ignored if the app is not installed.\n *\n * @param {string} appId - Application package identifier\n * @param {?UninstallOptions} options - The set of removal options\n * @returns {boolean} True if the package was found on the device and\n *                    successfully uninstalled.\n */\ncommands.removeApp = async function removeApp (appId, options = {}) {\n  return await this.adb.uninstallApk(appId, options);\n};\n\n/**\n * @typedef {Object} TerminateOptions\n * @property {number|string} timeout [500] - The count of milliseconds to wait until the\n *                                           app is terminated.\n */\n\n/**\n * Terminates the app if it is running.\n *\n * @param {string} appId - Application package identifier\n * @param {?TerminateOptions} options - The set of application termination options\n * @returns {boolean} True if the app has been successfully terminated.\n * @throws {Error} if the app has not been terminated within the given timeout.\n */\ncommands.terminateApp = async function terminateApp (appId, options = {}) {\n  log.info(`Terminating '${appId}'`);\n  if (!(await this.adb.processExists(appId))) {\n    log.info(`The app '${appId}' is not running`);\n    return false;\n  }\n  await this.adb.forceStop(appId);\n  const timeout = util.hasValue(options.timeout) && !isNaN(options.timeout) ? parseInt(options.timeout, 10) : 500;\n  try {\n    await waitForCondition(async () => await this.queryAppState(appId) <= APP_STATE.NOT_RUNNING,\n                           {waitMs: timeout, intervalMs: 100});\n  } catch (e) {\n    log.errorAndThrow(`'${appId}' is still running after ${timeout}ms timeout`);\n  }\n  log.info(`'${appId}' has been successfully terminated`);\n  return true;\n};\n\n/**\n * @typedef {Object} InstallOptions\n * @property {number} timeout [60000] - The count of milliseconds to wait until the\n *                                      app is installed.\n * @property {boolean} allowTestPackages [false] - Set to true in order to allow test\n *                                                 packages installation.\n * @property {boolean} useSdcard [false] - Set to true to install the app on sdcard\n *                                         instead of the device memory.\n * @property {boolean} grantPermissions [false] - Set to true in order to grant all the\n *                                                permissions requested in the application's manifest\n *                                                automatically after the installation is completed\n *                                                under Android 6+.\n * @property {boolean} replace [true] - Set it to false if you don't want\n *                                      the application to be upgraded/reinstalled\n *                                      if it is already present on the device.\n */\n\n/**\n * Installs the given application to the device under test\n *\n * @param {string} appPath - The local apk path or a remote url\n * @param {?InstallOptions} options - The set of installation options\n * @throws {Error} if the given apk does not exist or is not reachable\n */\ncommands.installApp = async function installApp (appPath, options = {}) {\n  const localPath = await this.helpers.configureApp(appPath, APP_EXTENSIONS);\n  await this.adb.install(localPath, options);\n};\n\n/**\n * @typedef {Object} ClearAppOptions\n * @property {!string} appId The identifier of the application package to be cleared\n */\n\n/**\n * Deletes all data associated with a package.\n *\n * @param {ClearAppOptions} opts\n * @throws {Error} If cleaning of the app data fails\n */\ncommands.mobileClearApp = async function mobileClearApp (opts = {}) {\n  const {appId} = opts;\n  if (!appId) {\n    throw new errors.InvalidArgumentError(`The 'appId' argument is required`);\n  }\n  await this.adb.clear(appId);\n};\n\nexport { commands };\nexport default commands;\n"],"file":"lib/commands/app-management.js","sourceRoot":"../../.."}
@@ -52,6 +52,7 @@ extensions.executeMobile = async function executeMobile(mobileCommand, opts = {}
52
52
  getNotifications: 'mobileGetNotifications',
53
53
  listSms: 'mobileListSms',
54
54
  deleteFile: 'mobileDeleteFile',
55
+ clearApp: 'mobileClearApp',
55
56
  startService: 'mobileStartService',
56
57
  stopService: 'mobileStopService',
57
58
  startActivity: 'mobileStartActivity',
@@ -70,4 +71,4 @@ var _default = extensions;
70
71
  exports.default = _default;require('source-map-support').install();
71
72
 
72
73
 
73
- //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImxpYi9jb21tYW5kcy9leGVjdXRlLmpzIl0sIm5hbWVzIjpbImV4dGVuc2lvbnMiLCJleGVjdXRlIiwic2NyaXB0IiwiYXJncyIsIm1hdGNoIiwibG9nZ2VyIiwiaW5mbyIsInJlcGxhY2UiLCJ0cmltIiwiZXhlY3V0ZU1vYmlsZSIsIl8iLCJpc0FycmF5IiwiaXNXZWJDb250ZXh0IiwiZXJyb3JzIiwiTm90SW1wbGVtZW50ZWRFcnJvciIsImVuZHBvaW50IiwiY2hyb21lZHJpdmVyIiwiandwcm94eSIsImRvd25zdHJlYW1Qcm90b2NvbCIsIlBST1RPQ09MUyIsIk1KU09OV1AiLCJjb21tYW5kIiwibW9iaWxlQ29tbWFuZCIsIm9wdHMiLCJtb2JpbGVDb21tYW5kc01hcHBpbmciLCJzaGVsbCIsImV4ZWNFbXVDb25zb2xlQ29tbWFuZCIsInN0YXJ0TG9nc0Jyb2FkY2FzdCIsInN0b3BMb2dzQnJvYWRjYXN0IiwiY2hhbmdlUGVybWlzc2lvbnMiLCJnZXRQZXJtaXNzaW9ucyIsInBlcmZvcm1FZGl0b3JBY3Rpb24iLCJzZW5zb3JTZXQiLCJnZXREZXZpY2VUaW1lIiwic3RhcnRTY3JlZW5TdHJlYW1pbmciLCJzdG9wU2NyZWVuU3RyZWFtaW5nIiwiZ2V0Tm90aWZpY2F0aW9ucyIsImxpc3RTbXMiLCJkZWxldGVGaWxlIiwic3RhcnRTZXJ2aWNlIiwic3RvcFNlcnZpY2UiLCJzdGFydEFjdGl2aXR5IiwiYnJvYWRjYXN0IiwiZ2V0Q29udGV4dHMiLCJoYXMiLCJVbmtub3duQ29tbWFuZEVycm9yIiwia2V5cyJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7QUFBQTs7QUFDQTs7QUFDQTs7QUFFQSxJQUFJQSxVQUFVLEdBQUcsRUFBakI7O0FBRUFBLFVBQVUsQ0FBQ0MsT0FBWCxHQUFxQixlQUFlQSxPQUFmLENBQXdCQyxNQUF4QixFQUFnQ0MsSUFBaEMsRUFBc0M7QUFDekQsTUFBSUQsTUFBTSxDQUFDRSxLQUFQLENBQWEsVUFBYixDQUFKLEVBQThCO0FBQzVCQyxvQkFBT0MsSUFBUCxDQUFhLDZCQUE0QkosTUFBTyxHQUFoRDs7QUFDQUEsSUFBQUEsTUFBTSxHQUFHQSxNQUFNLENBQUNLLE9BQVAsQ0FBZSxVQUFmLEVBQTJCLEVBQTNCLEVBQStCQyxJQUEvQixFQUFUO0FBQ0EsV0FBTyxNQUFNLEtBQUtDLGFBQUwsQ0FBbUJQLE1BQW5CLEVBQTJCUSxnQkFBRUMsT0FBRixDQUFVUixJQUFWLElBQWtCQSxJQUFJLENBQUMsQ0FBRCxDQUF0QixHQUE0QkEsSUFBdkQsQ0FBYjtBQUNEOztBQUNELE1BQUksQ0FBQyxLQUFLUyxZQUFMLEVBQUwsRUFBMEI7QUFDeEIsVUFBTSxJQUFJQyx5QkFBT0MsbUJBQVgsRUFBTjtBQUNEOztBQUNELFFBQU1DLFFBQVEsR0FBRyxLQUFLQyxZQUFMLENBQWtCQyxPQUFsQixDQUEwQkMsa0JBQTFCLEtBQWlEQyw0QkFBVUMsT0FBM0QsR0FDYixVQURhLEdBRWIsZUFGSjtBQUdBLFNBQU8sTUFBTSxLQUFLSixZQUFMLENBQWtCQyxPQUFsQixDQUEwQkksT0FBMUIsQ0FBa0NOLFFBQWxDLEVBQTRDLE1BQTVDLEVBQW9EO0FBQy9EYixJQUFBQSxNQUQrRDtBQUUvREMsSUFBQUE7QUFGK0QsR0FBcEQsQ0FBYjtBQUlELENBaEJEOztBQWtCQUgsVUFBVSxDQUFDUyxhQUFYLEdBQTJCLGVBQWVBLGFBQWYsQ0FBOEJhLGFBQTlCLEVBQTZDQyxJQUFJLEdBQUcsRUFBcEQsRUFBd0Q7QUFDakYsUUFBTUMscUJBQXFCLEdBQUc7QUFDNUJDLElBQUFBLEtBQUssRUFBRSxhQURxQjtBQUc1QkMsSUFBQUEscUJBQXFCLEVBQUUsNkJBSEs7QUFLNUJDLElBQUFBLGtCQUFrQixFQUFFLDBCQUxRO0FBTTVCQyxJQUFBQSxpQkFBaUIsRUFBRSx5QkFOUztBQVE1QkMsSUFBQUEsaUJBQWlCLEVBQUUseUJBUlM7QUFTNUJDLElBQUFBLGNBQWMsRUFBRSxzQkFUWTtBQVc1QkMsSUFBQUEsbUJBQW1CLEVBQUUsMkJBWE87QUFhNUJDLElBQUFBLFNBQVMsRUFBRSxXQWJpQjtBQWU1QkMsSUFBQUEsYUFBYSxFQUFFLHFCQWZhO0FBaUI1QkMsSUFBQUEsb0JBQW9CLEVBQUUsNEJBakJNO0FBa0I1QkMsSUFBQUEsbUJBQW1CLEVBQUUsMkJBbEJPO0FBb0I1QkMsSUFBQUEsZ0JBQWdCLEVBQUUsd0JBcEJVO0FBc0I1QkMsSUFBQUEsT0FBTyxFQUFFLGVBdEJtQjtBQXdCNUJDLElBQUFBLFVBQVUsRUFBRSxrQkF4QmdCO0FBMEI1QkMsSUFBQUEsWUFBWSxFQUFFLG9CQTFCYztBQTJCNUJDLElBQUFBLFdBQVcsRUFBRSxtQkEzQmU7QUE0QjVCQyxJQUFBQSxhQUFhLEVBQUUscUJBNUJhO0FBNkI1QkMsSUFBQUEsU0FBUyxFQUFFLGlCQTdCaUI7QUErQjVCQyxJQUFBQSxXQUFXLEVBQUU7QUEvQmUsR0FBOUI7O0FBa0NBLE1BQUksQ0FBQ2pDLGdCQUFFa0MsR0FBRixDQUFNcEIscUJBQU4sRUFBNkJGLGFBQTdCLENBQUwsRUFBa0Q7QUFDaEQsVUFBTSxJQUFJVCx5QkFBT2dDLG1CQUFYLENBQWdDLDJCQUEwQnZCLGFBQWMsS0FBekMsR0FDbEMsUUFBT1osZ0JBQUVvQyxJQUFGLENBQU90QixxQkFBUCxDQUE4QiwwQkFEbEMsQ0FBTjtBQUVEOztBQUNELFNBQU8sTUFBTSxLQUFLQSxxQkFBcUIsQ0FBQ0YsYUFBRCxDQUExQixFQUEyQ0MsSUFBM0MsQ0FBYjtBQUNELENBeENEOztlQTBDZXZCLFUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgXyBmcm9tICdsb2Rhc2gnO1xuaW1wb3J0IHsgZXJyb3JzLCBQUk9UT0NPTFMgfSBmcm9tICdhcHBpdW0tYmFzZS1kcml2ZXInO1xuaW1wb3J0IGxvZ2dlciBmcm9tICcuLi9sb2dnZXInO1xuXG5sZXQgZXh0ZW5zaW9ucyA9IHt9O1xuXG5leHRlbnNpb25zLmV4ZWN1dGUgPSBhc3luYyBmdW5jdGlvbiBleGVjdXRlIChzY3JpcHQsIGFyZ3MpIHtcbiAgaWYgKHNjcmlwdC5tYXRjaCgvXm1vYmlsZTovKSkge1xuICAgIGxvZ2dlci5pbmZvKGBFeGVjdXRpbmcgbmF0aXZlIGNvbW1hbmQgJyR7c2NyaXB0fSdgKTtcbiAgICBzY3JpcHQgPSBzY3JpcHQucmVwbGFjZSgvXm1vYmlsZTovLCAnJykudHJpbSgpO1xuICAgIHJldHVybiBhd2FpdCB0aGlzLmV4ZWN1dGVNb2JpbGUoc2NyaXB0LCBfLmlzQXJyYXkoYXJncykgPyBhcmdzWzBdIDogYXJncyk7XG4gIH1cbiAgaWYgKCF0aGlzLmlzV2ViQ29udGV4dCgpKSB7XG4gICAgdGhyb3cgbmV3IGVycm9ycy5Ob3RJbXBsZW1lbnRlZEVycm9yKCk7XG4gIH1cbiAgY29uc3QgZW5kcG9pbnQgPSB0aGlzLmNocm9tZWRyaXZlci5qd3Byb3h5LmRvd25zdHJlYW1Qcm90b2NvbCA9PT0gUFJPVE9DT0xTLk1KU09OV1BcbiAgICA/ICcvZXhlY3V0ZSdcbiAgICA6ICcvZXhlY3V0ZS9zeW5jJztcbiAgcmV0dXJuIGF3YWl0IHRoaXMuY2hyb21lZHJpdmVyLmp3cHJveHkuY29tbWFuZChlbmRwb2ludCwgJ1BPU1QnLCB7XG4gICAgc2NyaXB0LFxuICAgIGFyZ3MsXG4gIH0pO1xufTtcblxuZXh0ZW5zaW9ucy5leGVjdXRlTW9iaWxlID0gYXN5bmMgZnVuY3Rpb24gZXhlY3V0ZU1vYmlsZSAobW9iaWxlQ29tbWFuZCwgb3B0cyA9IHt9KSB7XG4gIGNvbnN0IG1vYmlsZUNvbW1hbmRzTWFwcGluZyA9IHtcbiAgICBzaGVsbDogJ21vYmlsZVNoZWxsJyxcblxuICAgIGV4ZWNFbXVDb25zb2xlQ29tbWFuZDogJ21vYmlsZUV4ZWNFbXVDb25zb2xlQ29tbWFuZCcsXG5cbiAgICBzdGFydExvZ3NCcm9hZGNhc3Q6ICdtb2JpbGVTdGFydExvZ3NCcm9hZGNhc3QnLFxuICAgIHN0b3BMb2dzQnJvYWRjYXN0OiAnbW9iaWxlU3RvcExvZ3NCcm9hZGNhc3QnLFxuXG4gICAgY2hhbmdlUGVybWlzc2lvbnM6ICdtb2JpbGVDaGFuZ2VQZXJtaXNzaW9ucycsXG4gICAgZ2V0UGVybWlzc2lvbnM6ICdtb2JpbGVHZXRQZXJtaXNzaW9ucycsXG5cbiAgICBwZXJmb3JtRWRpdG9yQWN0aW9uOiAnbW9iaWxlUGVyZm9ybUVkaXRvckFjdGlvbicsXG5cbiAgICBzZW5zb3JTZXQ6ICdzZW5zb3JTZXQnLFxuXG4gICAgZ2V0RGV2aWNlVGltZTogJ21vYmlsZUdldERldmljZVRpbWUnLFxuXG4gICAgc3RhcnRTY3JlZW5TdHJlYW1pbmc6ICdtb2JpbGVTdGFydFNjcmVlblN0cmVhbWluZycsXG4gICAgc3RvcFNjcmVlblN0cmVhbWluZzogJ21vYmlsZVN0b3BTY3JlZW5TdHJlYW1pbmcnLFxuXG4gICAgZ2V0Tm90aWZpY2F0aW9uczogJ21vYmlsZUdldE5vdGlmaWNhdGlvbnMnLFxuXG4gICAgbGlzdFNtczogJ21vYmlsZUxpc3RTbXMnLFxuXG4gICAgZGVsZXRlRmlsZTogJ21vYmlsZURlbGV0ZUZpbGUnLFxuXG4gICAgc3RhcnRTZXJ2aWNlOiAnbW9iaWxlU3RhcnRTZXJ2aWNlJyxcbiAgICBzdG9wU2VydmljZTogJ21vYmlsZVN0b3BTZXJ2aWNlJyxcbiAgICBzdGFydEFjdGl2aXR5OiAnbW9iaWxlU3RhcnRBY3Rpdml0eScsXG4gICAgYnJvYWRjYXN0OiAnbW9iaWxlQnJvYWRjYXN0JyxcblxuICAgIGdldENvbnRleHRzOiAnbW9iaWxlR2V0Q29udGV4dHMnLFxuICB9O1xuXG4gIGlmICghXy5oYXMobW9iaWxlQ29tbWFuZHNNYXBwaW5nLCBtb2JpbGVDb21tYW5kKSkge1xuICAgIHRocm93IG5ldyBlcnJvcnMuVW5rbm93bkNvbW1hbmRFcnJvcihgVW5rbm93biBtb2JpbGUgY29tbWFuZCBcIiR7bW9iaWxlQ29tbWFuZH1cIi4gYCArXG4gICAgICBgT25seSAke18ua2V5cyhtb2JpbGVDb21tYW5kc01hcHBpbmcpfSBjb21tYW5kcyBhcmUgc3VwcG9ydGVkLmApO1xuICB9XG4gIHJldHVybiBhd2FpdCB0aGlzW21vYmlsZUNvbW1hbmRzTWFwcGluZ1ttb2JpbGVDb21tYW5kXV0ob3B0cyk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBleHRlbnNpb25zO1xuIl0sImZpbGUiOiJsaWIvY29tbWFuZHMvZXhlY3V0ZS5qcyIsInNvdXJjZVJvb3QiOiIuLi8uLi8uLiJ9
74
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImxpYi9jb21tYW5kcy9leGVjdXRlLmpzIl0sIm5hbWVzIjpbImV4dGVuc2lvbnMiLCJleGVjdXRlIiwic2NyaXB0IiwiYXJncyIsIm1hdGNoIiwibG9nZ2VyIiwiaW5mbyIsInJlcGxhY2UiLCJ0cmltIiwiZXhlY3V0ZU1vYmlsZSIsIl8iLCJpc0FycmF5IiwiaXNXZWJDb250ZXh0IiwiZXJyb3JzIiwiTm90SW1wbGVtZW50ZWRFcnJvciIsImVuZHBvaW50IiwiY2hyb21lZHJpdmVyIiwiandwcm94eSIsImRvd25zdHJlYW1Qcm90b2NvbCIsIlBST1RPQ09MUyIsIk1KU09OV1AiLCJjb21tYW5kIiwibW9iaWxlQ29tbWFuZCIsIm9wdHMiLCJtb2JpbGVDb21tYW5kc01hcHBpbmciLCJzaGVsbCIsImV4ZWNFbXVDb25zb2xlQ29tbWFuZCIsInN0YXJ0TG9nc0Jyb2FkY2FzdCIsInN0b3BMb2dzQnJvYWRjYXN0IiwiY2hhbmdlUGVybWlzc2lvbnMiLCJnZXRQZXJtaXNzaW9ucyIsInBlcmZvcm1FZGl0b3JBY3Rpb24iLCJzZW5zb3JTZXQiLCJnZXREZXZpY2VUaW1lIiwic3RhcnRTY3JlZW5TdHJlYW1pbmciLCJzdG9wU2NyZWVuU3RyZWFtaW5nIiwiZ2V0Tm90aWZpY2F0aW9ucyIsImxpc3RTbXMiLCJkZWxldGVGaWxlIiwiY2xlYXJBcHAiLCJzdGFydFNlcnZpY2UiLCJzdG9wU2VydmljZSIsInN0YXJ0QWN0aXZpdHkiLCJicm9hZGNhc3QiLCJnZXRDb250ZXh0cyIsImhhcyIsIlVua25vd25Db21tYW5kRXJyb3IiLCJrZXlzIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7OztBQUFBOztBQUNBOztBQUNBOztBQUVBLElBQUlBLFVBQVUsR0FBRyxFQUFqQjs7QUFFQUEsVUFBVSxDQUFDQyxPQUFYLEdBQXFCLGVBQWVBLE9BQWYsQ0FBd0JDLE1BQXhCLEVBQWdDQyxJQUFoQyxFQUFzQztBQUN6RCxNQUFJRCxNQUFNLENBQUNFLEtBQVAsQ0FBYSxVQUFiLENBQUosRUFBOEI7QUFDNUJDLG9CQUFPQyxJQUFQLENBQWEsNkJBQTRCSixNQUFPLEdBQWhEOztBQUNBQSxJQUFBQSxNQUFNLEdBQUdBLE1BQU0sQ0FBQ0ssT0FBUCxDQUFlLFVBQWYsRUFBMkIsRUFBM0IsRUFBK0JDLElBQS9CLEVBQVQ7QUFDQSxXQUFPLE1BQU0sS0FBS0MsYUFBTCxDQUFtQlAsTUFBbkIsRUFBMkJRLGdCQUFFQyxPQUFGLENBQVVSLElBQVYsSUFBa0JBLElBQUksQ0FBQyxDQUFELENBQXRCLEdBQTRCQSxJQUF2RCxDQUFiO0FBQ0Q7O0FBQ0QsTUFBSSxDQUFDLEtBQUtTLFlBQUwsRUFBTCxFQUEwQjtBQUN4QixVQUFNLElBQUlDLHlCQUFPQyxtQkFBWCxFQUFOO0FBQ0Q7O0FBQ0QsUUFBTUMsUUFBUSxHQUFHLEtBQUtDLFlBQUwsQ0FBa0JDLE9BQWxCLENBQTBCQyxrQkFBMUIsS0FBaURDLDRCQUFVQyxPQUEzRCxHQUNiLFVBRGEsR0FFYixlQUZKO0FBR0EsU0FBTyxNQUFNLEtBQUtKLFlBQUwsQ0FBa0JDLE9BQWxCLENBQTBCSSxPQUExQixDQUFrQ04sUUFBbEMsRUFBNEMsTUFBNUMsRUFBb0Q7QUFDL0RiLElBQUFBLE1BRCtEO0FBRS9EQyxJQUFBQTtBQUYrRCxHQUFwRCxDQUFiO0FBSUQsQ0FoQkQ7O0FBa0JBSCxVQUFVLENBQUNTLGFBQVgsR0FBMkIsZUFBZUEsYUFBZixDQUE4QmEsYUFBOUIsRUFBNkNDLElBQUksR0FBRyxFQUFwRCxFQUF3RDtBQUNqRixRQUFNQyxxQkFBcUIsR0FBRztBQUM1QkMsSUFBQUEsS0FBSyxFQUFFLGFBRHFCO0FBRzVCQyxJQUFBQSxxQkFBcUIsRUFBRSw2QkFISztBQUs1QkMsSUFBQUEsa0JBQWtCLEVBQUUsMEJBTFE7QUFNNUJDLElBQUFBLGlCQUFpQixFQUFFLHlCQU5TO0FBUTVCQyxJQUFBQSxpQkFBaUIsRUFBRSx5QkFSUztBQVM1QkMsSUFBQUEsY0FBYyxFQUFFLHNCQVRZO0FBVzVCQyxJQUFBQSxtQkFBbUIsRUFBRSwyQkFYTztBQWE1QkMsSUFBQUEsU0FBUyxFQUFFLFdBYmlCO0FBZTVCQyxJQUFBQSxhQUFhLEVBQUUscUJBZmE7QUFpQjVCQyxJQUFBQSxvQkFBb0IsRUFBRSw0QkFqQk07QUFrQjVCQyxJQUFBQSxtQkFBbUIsRUFBRSwyQkFsQk87QUFvQjVCQyxJQUFBQSxnQkFBZ0IsRUFBRSx3QkFwQlU7QUFzQjVCQyxJQUFBQSxPQUFPLEVBQUUsZUF0Qm1CO0FBd0I1QkMsSUFBQUEsVUFBVSxFQUFFLGtCQXhCZ0I7QUEwQjVCQyxJQUFBQSxRQUFRLEVBQUUsZ0JBMUJrQjtBQTRCNUJDLElBQUFBLFlBQVksRUFBRSxvQkE1QmM7QUE2QjVCQyxJQUFBQSxXQUFXLEVBQUUsbUJBN0JlO0FBOEI1QkMsSUFBQUEsYUFBYSxFQUFFLHFCQTlCYTtBQStCNUJDLElBQUFBLFNBQVMsRUFBRSxpQkEvQmlCO0FBaUM1QkMsSUFBQUEsV0FBVyxFQUFFO0FBakNlLEdBQTlCOztBQW9DQSxNQUFJLENBQUNsQyxnQkFBRW1DLEdBQUYsQ0FBTXJCLHFCQUFOLEVBQTZCRixhQUE3QixDQUFMLEVBQWtEO0FBQ2hELFVBQU0sSUFBSVQseUJBQU9pQyxtQkFBWCxDQUFnQywyQkFBMEJ4QixhQUFjLEtBQXpDLEdBQ2xDLFFBQU9aLGdCQUFFcUMsSUFBRixDQUFPdkIscUJBQVAsQ0FBOEIsMEJBRGxDLENBQU47QUFFRDs7QUFDRCxTQUFPLE1BQU0sS0FBS0EscUJBQXFCLENBQUNGLGFBQUQsQ0FBMUIsRUFBMkNDLElBQTNDLENBQWI7QUFDRCxDQTFDRDs7ZUE0Q2V2QixVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IF8gZnJvbSAnbG9kYXNoJztcbmltcG9ydCB7IGVycm9ycywgUFJPVE9DT0xTIH0gZnJvbSAnYXBwaXVtLWJhc2UtZHJpdmVyJztcbmltcG9ydCBsb2dnZXIgZnJvbSAnLi4vbG9nZ2VyJztcblxubGV0IGV4dGVuc2lvbnMgPSB7fTtcblxuZXh0ZW5zaW9ucy5leGVjdXRlID0gYXN5bmMgZnVuY3Rpb24gZXhlY3V0ZSAoc2NyaXB0LCBhcmdzKSB7XG4gIGlmIChzY3JpcHQubWF0Y2goL15tb2JpbGU6LykpIHtcbiAgICBsb2dnZXIuaW5mbyhgRXhlY3V0aW5nIG5hdGl2ZSBjb21tYW5kICcke3NjcmlwdH0nYCk7XG4gICAgc2NyaXB0ID0gc2NyaXB0LnJlcGxhY2UoL15tb2JpbGU6LywgJycpLnRyaW0oKTtcbiAgICByZXR1cm4gYXdhaXQgdGhpcy5leGVjdXRlTW9iaWxlKHNjcmlwdCwgXy5pc0FycmF5KGFyZ3MpID8gYXJnc1swXSA6IGFyZ3MpO1xuICB9XG4gIGlmICghdGhpcy5pc1dlYkNvbnRleHQoKSkge1xuICAgIHRocm93IG5ldyBlcnJvcnMuTm90SW1wbGVtZW50ZWRFcnJvcigpO1xuICB9XG4gIGNvbnN0IGVuZHBvaW50ID0gdGhpcy5jaHJvbWVkcml2ZXIuandwcm94eS5kb3duc3RyZWFtUHJvdG9jb2wgPT09IFBST1RPQ09MUy5NSlNPTldQXG4gICAgPyAnL2V4ZWN1dGUnXG4gICAgOiAnL2V4ZWN1dGUvc3luYyc7XG4gIHJldHVybiBhd2FpdCB0aGlzLmNocm9tZWRyaXZlci5qd3Byb3h5LmNvbW1hbmQoZW5kcG9pbnQsICdQT1NUJywge1xuICAgIHNjcmlwdCxcbiAgICBhcmdzLFxuICB9KTtcbn07XG5cbmV4dGVuc2lvbnMuZXhlY3V0ZU1vYmlsZSA9IGFzeW5jIGZ1bmN0aW9uIGV4ZWN1dGVNb2JpbGUgKG1vYmlsZUNvbW1hbmQsIG9wdHMgPSB7fSkge1xuICBjb25zdCBtb2JpbGVDb21tYW5kc01hcHBpbmcgPSB7XG4gICAgc2hlbGw6ICdtb2JpbGVTaGVsbCcsXG5cbiAgICBleGVjRW11Q29uc29sZUNvbW1hbmQ6ICdtb2JpbGVFeGVjRW11Q29uc29sZUNvbW1hbmQnLFxuXG4gICAgc3RhcnRMb2dzQnJvYWRjYXN0OiAnbW9iaWxlU3RhcnRMb2dzQnJvYWRjYXN0JyxcbiAgICBzdG9wTG9nc0Jyb2FkY2FzdDogJ21vYmlsZVN0b3BMb2dzQnJvYWRjYXN0JyxcblxuICAgIGNoYW5nZVBlcm1pc3Npb25zOiAnbW9iaWxlQ2hhbmdlUGVybWlzc2lvbnMnLFxuICAgIGdldFBlcm1pc3Npb25zOiAnbW9iaWxlR2V0UGVybWlzc2lvbnMnLFxuXG4gICAgcGVyZm9ybUVkaXRvckFjdGlvbjogJ21vYmlsZVBlcmZvcm1FZGl0b3JBY3Rpb24nLFxuXG4gICAgc2Vuc29yU2V0OiAnc2Vuc29yU2V0JyxcblxuICAgIGdldERldmljZVRpbWU6ICdtb2JpbGVHZXREZXZpY2VUaW1lJyxcblxuICAgIHN0YXJ0U2NyZWVuU3RyZWFtaW5nOiAnbW9iaWxlU3RhcnRTY3JlZW5TdHJlYW1pbmcnLFxuICAgIHN0b3BTY3JlZW5TdHJlYW1pbmc6ICdtb2JpbGVTdG9wU2NyZWVuU3RyZWFtaW5nJyxcblxuICAgIGdldE5vdGlmaWNhdGlvbnM6ICdtb2JpbGVHZXROb3RpZmljYXRpb25zJyxcblxuICAgIGxpc3RTbXM6ICdtb2JpbGVMaXN0U21zJyxcblxuICAgIGRlbGV0ZUZpbGU6ICdtb2JpbGVEZWxldGVGaWxlJyxcblxuICAgIGNsZWFyQXBwOiAnbW9iaWxlQ2xlYXJBcHAnLFxuXG4gICAgc3RhcnRTZXJ2aWNlOiAnbW9iaWxlU3RhcnRTZXJ2aWNlJyxcbiAgICBzdG9wU2VydmljZTogJ21vYmlsZVN0b3BTZXJ2aWNlJyxcbiAgICBzdGFydEFjdGl2aXR5OiAnbW9iaWxlU3RhcnRBY3Rpdml0eScsXG4gICAgYnJvYWRjYXN0OiAnbW9iaWxlQnJvYWRjYXN0JyxcblxuICAgIGdldENvbnRleHRzOiAnbW9iaWxlR2V0Q29udGV4dHMnLFxuICB9O1xuXG4gIGlmICghXy5oYXMobW9iaWxlQ29tbWFuZHNNYXBwaW5nLCBtb2JpbGVDb21tYW5kKSkge1xuICAgIHRocm93IG5ldyBlcnJvcnMuVW5rbm93bkNvbW1hbmRFcnJvcihgVW5rbm93biBtb2JpbGUgY29tbWFuZCBcIiR7bW9iaWxlQ29tbWFuZH1cIi4gYCArXG4gICAgICBgT25seSAke18ua2V5cyhtb2JpbGVDb21tYW5kc01hcHBpbmcpfSBjb21tYW5kcyBhcmUgc3VwcG9ydGVkLmApO1xuICB9XG4gIHJldHVybiBhd2FpdCB0aGlzW21vYmlsZUNvbW1hbmRzTWFwcGluZ1ttb2JpbGVDb21tYW5kXV0ob3B0cyk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBleHRlbnNpb25zO1xuIl0sImZpbGUiOiJsaWIvY29tbWFuZHMvZXhlY3V0ZS5qcyIsInNvdXJjZVJvb3QiOiIuLi8uLi8uLiJ9
@@ -2,6 +2,7 @@ import { waitForCondition } from 'asyncbox';
2
2
  import { util } from 'appium-support';
3
3
  import log from '../logger';
4
4
  import { APP_STATE } from '../android-helpers';
5
+ import { errors } from 'appium-base-driver';
5
6
 
6
7
  const APP_EXTENSIONS = ['.apk', '.apks'];
7
8
 
@@ -151,6 +152,24 @@ commands.installApp = async function installApp (appPath, options = {}) {
151
152
  await this.adb.install(localPath, options);
152
153
  };
153
154
 
155
+ /**
156
+ * @typedef {Object} ClearAppOptions
157
+ * @property {!string} appId The identifier of the application package to be cleared
158
+ */
159
+
160
+ /**
161
+ * Deletes all data associated with a package.
162
+ *
163
+ * @param {ClearAppOptions} opts
164
+ * @throws {Error} If cleaning of the app data fails
165
+ */
166
+ commands.mobileClearApp = async function mobileClearApp (opts = {}) {
167
+ const {appId} = opts;
168
+ if (!appId) {
169
+ throw new errors.InvalidArgumentError(`The 'appId' argument is required`);
170
+ }
171
+ await this.adb.clear(appId);
172
+ };
154
173
 
155
174
  export { commands };
156
175
  export default commands;
@@ -49,6 +49,8 @@ extensions.executeMobile = async function executeMobile (mobileCommand, opts = {
49
49
 
50
50
  deleteFile: 'mobileDeleteFile',
51
51
 
52
+ clearApp: 'mobileClearApp',
53
+
52
54
  startService: 'mobileStartService',
53
55
  stopService: 'mobileStopService',
54
56
  startActivity: 'mobileStartActivity',
package/package.json CHANGED
@@ -9,7 +9,7 @@
9
9
  "mobile",
10
10
  "mobile testing"
11
11
  ],
12
- "version": "4.48.2",
12
+ "version": "4.49.0",
13
13
  "author": "appium",
14
14
  "license": "Apache-2.0",
15
15
  "repository": {