appium-uiautomator2-driver 1.72.0 → 2.0.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.
@@ -5,13 +5,13 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
5
5
  Object.defineProperty(exports, "__esModule", {
6
6
  value: true
7
7
  });
8
- exports.default = exports.SERVER_TEST_PACKAGE_ID = exports.SERVER_PACKAGE_ID = exports.INSTRUMENTATION_TARGET = exports.UiAutomator2Server = void 0;
8
+ exports.default = exports.UiAutomator2Server = exports.SERVER_TEST_PACKAGE_ID = exports.SERVER_PACKAGE_ID = exports.INSTRUMENTATION_TARGET = void 0;
9
9
 
10
10
  require("source-map-support/register");
11
11
 
12
12
  var _lodash = _interopRequireDefault(require("lodash"));
13
13
 
14
- var _appiumBaseDriver = require("appium-base-driver");
14
+ var _baseDriver = require("@appium/base-driver");
15
15
 
16
16
  var _asyncbox = require("asyncbox");
17
17
 
@@ -19,7 +19,7 @@ var _logger = _interopRequireDefault(require("./logger"));
19
19
 
20
20
  var _appiumUiautomator2Server = require("appium-uiautomator2-server");
21
21
 
22
- var _appiumSupport = require("appium-support");
22
+ var _support = require("@appium/support");
23
23
 
24
24
  var _bluebird = _interopRequireDefault(require("bluebird"));
25
25
 
@@ -40,12 +40,12 @@ exports.SERVER_TEST_PACKAGE_ID = SERVER_TEST_PACKAGE_ID;
40
40
  const INSTRUMENTATION_TARGET = `${SERVER_TEST_PACKAGE_ID}/androidx.test.runner.AndroidJUnitRunner`;
41
41
  exports.INSTRUMENTATION_TARGET = INSTRUMENTATION_TARGET;
42
42
 
43
- const instrumentationLogger = _appiumSupport.logger.getLogger('Instrumentation');
43
+ const instrumentationLogger = _support.logger.getLogger('Instrumentation');
44
44
 
45
- class UIA2Proxy extends _appiumBaseDriver.JWProxy {
45
+ class UIA2Proxy extends _baseDriver.JWProxy {
46
46
  async proxyCommand(url, method, body = null) {
47
47
  if (this.didInstrumentationExit) {
48
- throw new _appiumBaseDriver.errors.InvalidContextError(`'${method} ${url}' cannot be proxied to UiAutomator2 server because ` + 'the instrumentation process is not running (probably crashed). ' + 'Check the server log and/or the logcat output for more details');
48
+ throw new _baseDriver.errors.InvalidContextError(`'${method} ${url}' cannot be proxied to UiAutomator2 server because ` + 'the instrumentation process is not running (probably crashed). ' + 'Check the server log and/or the logcat output for more details');
49
49
  }
50
50
 
51
51
  return await super.proxyCommand(url, method, body);
@@ -56,7 +56,7 @@ class UIA2Proxy extends _appiumBaseDriver.JWProxy {
56
56
  class UiAutomator2Server {
57
57
  constructor(opts = {}) {
58
58
  for (let req of REQD_PARAMS) {
59
- if (!opts || !_appiumSupport.util.hasValue(opts[req])) {
59
+ if (!opts || !_support.util.hasValue(opts[req])) {
60
60
  throw new Error(`Option '${req}' is required!`);
61
61
  }
62
62
 
@@ -81,7 +81,7 @@ class UiAutomator2Server {
81
81
  }
82
82
 
83
83
  async installServerApk(installTimeout = SERVER_INSTALL_RETRIES * 1000) {
84
- const tmpRoot = await _appiumSupport.tempDir.openDir();
84
+ const tmpRoot = await _support.tempDir.openDir();
85
85
 
86
86
  const packageInfosMapper = async ({
87
87
  appPath,
@@ -98,7 +98,7 @@ class UiAutomator2Server {
98
98
 
99
99
  const dstPath = _path.default.resolve(tmpRoot, _path.default.basename(appPath));
100
100
 
101
- await _appiumSupport.fs.copyFile(appPath, dstPath);
101
+ await _support.fs.copyFile(appPath, dstPath);
102
102
  return {
103
103
  appPath: dstPath,
104
104
  appId
@@ -178,7 +178,7 @@ class UiAutomator2Server {
178
178
  }
179
179
  }
180
180
  } finally {
181
- await _appiumSupport.fs.rimraf(tmpRoot);
181
+ await _support.fs.rimraf(tmpRoot);
182
182
  }
183
183
 
184
184
  await this.verifyServicesAvailability();
@@ -247,7 +247,7 @@ class UiAutomator2Server {
247
247
  }
248
248
 
249
249
  const timeout = caps.uiautomator2ServerLaunchTimeout || SERVER_LAUNCH_TIMEOUT;
250
- const timer = new _appiumSupport.timing.Timer().start();
250
+ const timer = new _support.timing.Timer().start();
251
251
  let retries = 0;
252
252
  const maxRetries = 2;
253
253
  const delayBetweenRetries = 3000;
@@ -357,7 +357,7 @@ class UiAutomator2Server {
357
357
  if (activeSessionIds.length) {
358
358
  _logger.default.debug(`The following obsolete sessions are still running: ${JSON.stringify(activeSessionIds)}`);
359
359
 
360
- _logger.default.debug(`Cleaning up ${_appiumSupport.util.pluralize('obsolete session', activeSessionIds.length, true)}`);
360
+ _logger.default.debug(`Cleaning up ${_support.util.pluralize('obsolete session', activeSessionIds.length, true)}`);
361
361
 
362
362
  await _bluebird.default.all(activeSessionIds.map(id => _axios.default.delete(`http://${this.host}:${this.systemPort}/wd/hub/session/${id}`)));
363
363
  await _bluebird.default.delay(1000);
@@ -388,4 +388,4 @@ var _default = UiAutomator2Server;
388
388
  exports.default = _default;require('source-map-support').install();
389
389
 
390
390
 
391
- //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/uiautomator2.js"],"names":["REQD_PARAMS","SERVER_LAUNCH_TIMEOUT","SERVER_INSTALL_RETRIES","SERVICES_LAUNCH_TIMEOUT","SERVER_PACKAGE_ID","SERVER_TEST_PACKAGE_ID","INSTRUMENTATION_TARGET","instrumentationLogger","logger","getLogger","UIA2Proxy","JWProxy","proxyCommand","url","method","body","didInstrumentationExit","errors","InvalidContextError","UiAutomator2Server","constructor","opts","req","util","hasValue","Error","disableSuppressAccessibilityService","proxyOpts","server","host","port","systemPort","keepAlive","readTimeout","timeout","jwproxy","proxyReqRes","bind","command","installServerApk","installTimeout","tmpRoot","tempDir","openDir","packageInfosMapper","appPath","appId","helpers","isWriteable","log","info","dstPath","path","resolve","basename","fs","copyFile","packagesInfo","B","all","map","apkPath","testApkPath","shouldUninstallServerPackages","shouldInstallServerPackages","isAppInstalled","adb","checkApkCert","signApp","appState","getApplicationInstallState","debug","APP_INSTALL_STATE","OLDER_VERSION_INSTALLED","NEWER_VERSION_INSTALLED","includes","NOT_INSTALLED","uninstallApk","err","warn","message","install","noIncremental","replace","timeoutCapName","rimraf","verifyServicesAvailability","isPmServiceAvailable","pmOutput","pmError","shell","e","waitMs","intervalMs","error","line","split","startSession","caps","cleanupAutomationLeftovers","skipServerInstallation","serverVersion","uiautomator2ServerLaunchTimeout","timer","timing","Timer","start","retries","maxRetries","delayBetweenRetries","startInstrumentationProcess","errorAndThrow","delay","getDuration","asMilliSeconds","toFixed","capabilities","firstMatch","alwaysMatch","cmd","disableWindowAnimation","push","_","isBoolean","instrumentationProcess","createSubProcess","on","stdout","stderr","output","trim","code","deleteSession","strictCleanup","value","data","activeSessionIds","id","filter","Boolean","length","JSON","stringify","pluralize","axios","delete","forceStop","ignore","killProcessesByName"],"mappings":"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","sourcesContent":["import _ from 'lodash';\nimport { JWProxy, errors } from 'appium-base-driver';\nimport { waitForCondition } from 'asyncbox';\nimport log from './logger';\nimport {\n  SERVER_APK_PATH as apkPath,\n  TEST_APK_PATH as testApkPath,\n  version as serverVersion\n} from 'appium-uiautomator2-server';\nimport {\n  util, logger, tempDir, fs, timing\n} from 'appium-support';\nimport B from 'bluebird';\nimport helpers from './helpers';\nimport axios from 'axios';\nimport path from 'path';\n\nconst REQD_PARAMS = ['adb', 'tmpDir', 'host', 'systemPort', 'devicePort', 'disableWindowAnimation'];\nconst SERVER_LAUNCH_TIMEOUT = 30000;\nconst SERVER_INSTALL_RETRIES = 20;\nconst SERVICES_LAUNCH_TIMEOUT = 30000;\nconst SERVER_PACKAGE_ID = 'io.appium.uiautomator2.server';\nconst SERVER_TEST_PACKAGE_ID = `${SERVER_PACKAGE_ID}.test`;\nconst INSTRUMENTATION_TARGET = `${SERVER_TEST_PACKAGE_ID}/androidx.test.runner.AndroidJUnitRunner`;\nconst instrumentationLogger = logger.getLogger('Instrumentation');\n\nclass UIA2Proxy extends JWProxy {\n  async proxyCommand (url, method, body = null) {\n    if (this.didInstrumentationExit) {\n      throw new errors.InvalidContextError(\n        `'${method} ${url}' cannot be proxied to UiAutomator2 server because ` +\n        'the instrumentation process is not running (probably crashed). ' +\n        'Check the server log and/or the logcat output for more details');\n    }\n    return await super.proxyCommand(url, method, body);\n  }\n}\n\nclass UiAutomator2Server {\n  constructor (opts = {}) {\n    for (let req of REQD_PARAMS) {\n      if (!opts || !util.hasValue(opts[req])) {\n        throw new Error(`Option '${req}' is required!`);\n      }\n      this[req] = opts[req];\n    }\n    this.disableSuppressAccessibilityService = opts.disableSuppressAccessibilityService;\n    const proxyOpts = {\n      server: this.host,\n      port: this.systemPort,\n      keepAlive: true,\n    };\n    if (opts.readTimeout && opts.readTimeout > 0) {\n      proxyOpts.timeout = opts.readTimeout;\n    }\n    this.jwproxy = new UIA2Proxy(proxyOpts);\n    this.proxyReqRes = this.jwproxy.proxyReqRes.bind(this.jwproxy);\n    this.proxyCommand = this.jwproxy.command.bind(this.jwproxy);\n    this.jwproxy.didInstrumentationExit = false;\n  }\n\n  /**\n   * Installs the apks on to the device or emulator.\n   *\n   * @param {number} installTimeout - Installation timeout\n   */\n  async installServerApk (installTimeout = SERVER_INSTALL_RETRIES * 1000) {\n    const tmpRoot = await tempDir.openDir();\n    const packageInfosMapper = async ({appPath, appId}) => {\n      if (await helpers.isWriteable(appPath)) {\n        return { appPath, appId };\n      }\n\n      log.info(`Server package at '${appPath}' is not writeable. ` +\n        `Will copy it into the temporary location at '${tmpRoot}' as a workaround. ` +\n        `Consider making this file writeable manually in order to improve the performance of session startup.`);\n      const dstPath = path.resolve(tmpRoot, path.basename(appPath));\n      await fs.copyFile(appPath, dstPath);\n      return {\n        appPath: dstPath,\n        appId,\n      };\n    };\n\n    try {\n      const packagesInfo = await B.all(B.map([\n        {\n          appPath: apkPath,\n          appId: SERVER_PACKAGE_ID,\n        }, {\n          appPath: testApkPath,\n          appId: SERVER_TEST_PACKAGE_ID,\n        },\n      ], packageInfosMapper));\n\n      let shouldUninstallServerPackages = false;\n      let shouldInstallServerPackages = false;\n      for (const {appId, appPath} of packagesInfo) {\n        if (appId === SERVER_TEST_PACKAGE_ID) {\n          const isAppInstalled = await this.adb.isAppInstalled(appId);\n\n          // There is no point in getting the state for test server,\n          // since it does not contain version info\n          if (!await this.adb.checkApkCert(appPath, appId)) {\n            await helpers.signApp(this.adb, appPath);\n            shouldUninstallServerPackages = shouldUninstallServerPackages || isAppInstalled;\n            shouldInstallServerPackages = true;\n          }\n\n          if (!isAppInstalled) {\n            shouldInstallServerPackages = true;\n          }\n          continue;\n        }\n\n        const appState = await this.adb.getApplicationInstallState(appPath, appId);\n        log.debug(`${appId} installation state: ${appState}`);\n        if (await this.adb.checkApkCert(appPath, appId)) {\n          shouldUninstallServerPackages = shouldUninstallServerPackages || [\n            this.adb.APP_INSTALL_STATE.OLDER_VERSION_INSTALLED,\n            this.adb.APP_INSTALL_STATE.NEWER_VERSION_INSTALLED,\n          ].includes(appState);\n        } else {\n          await helpers.signApp(this.adb, appPath);\n          shouldUninstallServerPackages = shouldUninstallServerPackages || ![\n            this.adb.APP_INSTALL_STATE.NOT_INSTALLED,\n          ].includes(appState);\n        }\n        shouldInstallServerPackages = shouldInstallServerPackages || shouldUninstallServerPackages || [\n          this.adb.APP_INSTALL_STATE.NOT_INSTALLED,\n        ].includes(appState);\n      }\n      log.info(`Server packages are ${shouldInstallServerPackages ? '' : 'not '}going to be (re)installed`);\n      if (shouldInstallServerPackages && shouldUninstallServerPackages) {\n        log.info('Full packages reinstall is going to be performed');\n      }\n      for (const {appId, appPath} of packagesInfo) {\n        if (shouldUninstallServerPackages) {\n          try {\n            await this.adb.uninstallApk(appId);\n          } catch (err) {\n            log.warn(`Error uninstalling '${appId}': ${err.message}`);\n          }\n        }\n        if (shouldInstallServerPackages) {\n          await this.adb.install(appPath, {\n            noIncremental: true,\n            replace: true,\n            timeout: installTimeout,\n            timeoutCapName: 'uiautomator2ServerInstallTimeout'\n          });\n        }\n      }\n    } finally {\n      await fs.rimraf(tmpRoot);\n    }\n\n    await this.verifyServicesAvailability();\n  }\n\n  async verifyServicesAvailability () {\n    log.debug(`Waiting up to ${SERVICES_LAUNCH_TIMEOUT}ms for services to be available`);\n    let isPmServiceAvailable = false;\n    let pmOutput = '';\n    let pmError = null;\n    try {\n      await waitForCondition(async () => {\n        if (!isPmServiceAvailable) {\n          pmError = null;\n          pmOutput = '';\n          try {\n            pmOutput = await this.adb.shell(['pm', 'list', 'instrumentation']);\n          } catch (e) {\n            pmError = e;\n          }\n          if (pmOutput.includes('Could not access the Package Manager')) {\n            pmError = new Error(`Problem running Package Manager: ${pmOutput}`);\n            pmOutput = ''; // remove output, so it is not printed below\n          } else if (pmOutput.includes(INSTRUMENTATION_TARGET)) {\n            pmOutput = ''; // remove output, so it is not printed below\n            log.debug(`Instrumentation target '${INSTRUMENTATION_TARGET}' is available`);\n            // eslint-disable-next-line require-atomic-updates\n            isPmServiceAvailable = true;\n          } else if (!pmError) {\n            pmError = new Error('The instrumentation target is not listed by Package Manager');\n          }\n        }\n        return isPmServiceAvailable;\n      }, {\n        waitMs: SERVICES_LAUNCH_TIMEOUT,\n        intervalMs: 1000,\n      });\n    } catch (err) {\n      log.error(`Unable to find instrumentation target '${INSTRUMENTATION_TARGET}': ${(pmError || {}).message}`);\n      if (pmOutput) {\n        log.debug('Available targets:');\n        for (const line of pmOutput.split('\\n')) {\n          log.debug(`    ${line.replace('instrumentation:', '')}`);\n        }\n      }\n    }\n  }\n\n  async startSession (caps) {\n    await this.cleanupAutomationLeftovers();\n    if (caps.skipServerInstallation) {\n      log.info(`'skipServerInstallation' is set. Attempting to use UIAutomator2 server from the device`);\n    } else {\n      log.info(`Starting UIAutomator2 server ${serverVersion}`);\n      log.info(`Using UIAutomator2 server from '${apkPath}' and test from '${testApkPath}'`);\n    }\n\n    const timeout = caps.uiautomator2ServerLaunchTimeout || SERVER_LAUNCH_TIMEOUT;\n    const timer = new timing.Timer().start();\n    let retries = 0;\n    const maxRetries = 2;\n    const delayBetweenRetries = 3000;\n    while (retries < maxRetries) {\n      log.info(`Waiting up to ${timeout}ms for UiAutomator2 to be online...`);\n      this.jwproxy.didInstrumentationExit = false;\n      await this.startInstrumentationProcess();\n      if (!this.jwproxy.didInstrumentationExit) {\n        try {\n          await waitForCondition(async () => {\n            try {\n              await this.jwproxy.command('/status', 'GET');\n              return true;\n            } catch (err) {\n              // short circuit to retry or fail fast\n              return this.jwproxy.didInstrumentationExit;\n            }\n          }, {\n            waitMs: timeout,\n            intervalMs: 1000,\n          });\n        } catch (err) {\n          log.errorAndThrow(`The instrumentation process cannot be initialized within ${timeout}ms timeout. `\n            + 'Make sure the application under test does not crash and investigate the logcat output. '\n            + `You could also try to increase the value of 'uiautomator2ServerLaunchTimeout' capability`);\n        }\n      }\n      if (!this.jwproxy.didInstrumentationExit) {\n        break;\n      }\n\n      retries++;\n      if (retries >= maxRetries) {\n        log.errorAndThrow('The instrumentation process cannot be initialized. '\n          + 'Make sure the application under test does not crash and investigate the logcat output.');\n      }\n      log.warn(`The instrumentation process has been unexpectedly terminated. `\n        + `Retrying UiAutomator2 startup (#${retries} of ${maxRetries - 1})`);\n      await this.cleanupAutomationLeftovers(true);\n      await B.delay(delayBetweenRetries);\n    }\n\n    log.debug(`The initialization of the instrumentation process took `\n      + `${timer.getDuration().asMilliSeconds.toFixed(0)}ms`);\n    await this.jwproxy.command('/session', 'POST', {\n      capabilities: {\n        firstMatch: [caps],\n        alwaysMatch: {},\n      }\n    });\n  }\n\n  async startInstrumentationProcess () {\n    const cmd = ['am', 'instrument', '-w'];\n    if (this.disableWindowAnimation) {\n      cmd.push('--no-window-animation');\n    }\n    if (_.isBoolean(this.disableSuppressAccessibilityService)) {\n      cmd.push('-e', 'DISABLE_SUPPRESS_ACCESSIBILITY_SERVICES', this.disableSuppressAccessibilityService);\n    }\n    // Disable Google analytics to prevent possible fatal exception\n    cmd.push('-e', 'disableAnalytics', true);\n    cmd.push(INSTRUMENTATION_TARGET);\n    const instrumentationProcess = this.adb.createSubProcess(['shell', ...cmd]);\n    instrumentationProcess.on('output', (stdout, stderr) => {\n      const output = _.trim(stdout || stderr);\n      if (output) {\n        instrumentationLogger.debug(output);\n      }\n    });\n    instrumentationProcess.on('exit', (code) => {\n      instrumentationLogger.debug(`The process has exited with code ${code}`);\n      this.jwproxy.didInstrumentationExit = true;\n    });\n    await instrumentationProcess.start(0);\n  }\n\n  async deleteSession () {\n    log.debug('Deleting UiAutomator2 server session');\n    // rely on jwproxy's intelligence to know what we're talking about and\n    // delete the current session\n    try {\n      await this.jwproxy.command('/', 'DELETE');\n    } catch (err) {\n      log.warn(`Did not get confirmation UiAutomator2 deleteSession worked; ` +\n          `Error was: ${err}`);\n    }\n  }\n\n  async cleanupAutomationLeftovers (strictCleanup = false) {\n    log.debug(`Performing ${strictCleanup ? 'strict' : 'shallow'} cleanup of automation leftovers`);\n\n    try {\n      const {value} = (await axios({\n        url: `http://${this.host}:${this.systemPort}/wd/hub/sessions`,\n        timeout: 500,\n      })).data;\n      const activeSessionIds = value.map(({id}) => id).filter(Boolean);\n      if (activeSessionIds.length) {\n        log.debug(`The following obsolete sessions are still running: ${JSON.stringify(activeSessionIds)}`);\n        log.debug(`Cleaning up ${util.pluralize('obsolete session', activeSessionIds.length, true)}`);\n        await B.all(activeSessionIds\n          .map((id) => axios.delete(`http://${this.host}:${this.systemPort}/wd/hub/session/${id}`))\n        );\n        // Let all sessions to be properly terminated before continuing\n        await B.delay(1000);\n      } else {\n        log.debug('No obsolete sessions have been detected');\n      }\n    } catch (e) {\n      log.debug(`No obsolete sessions have been detected (${e.message})`);\n    }\n\n    try {\n      await this.adb.forceStop(SERVER_TEST_PACKAGE_ID);\n    } catch (ignore) {}\n    if (!strictCleanup) {\n      return;\n    }\n    // https://github.com/appium/appium/issues/10749\n    try {\n      await this.adb.killProcessesByName('uiautomator');\n    } catch (ignore) {}\n  }\n}\n\nexport { UiAutomator2Server, INSTRUMENTATION_TARGET, SERVER_PACKAGE_ID, SERVER_TEST_PACKAGE_ID };\nexport default UiAutomator2Server;\n"],"file":"lib/uiautomator2.js","sourceRoot":"../.."}
391
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/uiautomator2.js"],"names":["REQD_PARAMS","SERVER_LAUNCH_TIMEOUT","SERVER_INSTALL_RETRIES","SERVICES_LAUNCH_TIMEOUT","SERVER_PACKAGE_ID","SERVER_TEST_PACKAGE_ID","INSTRUMENTATION_TARGET","instrumentationLogger","logger","getLogger","UIA2Proxy","JWProxy","proxyCommand","url","method","body","didInstrumentationExit","errors","InvalidContextError","UiAutomator2Server","constructor","opts","req","util","hasValue","Error","disableSuppressAccessibilityService","proxyOpts","server","host","port","systemPort","keepAlive","readTimeout","timeout","jwproxy","proxyReqRes","bind","command","installServerApk","installTimeout","tmpRoot","tempDir","openDir","packageInfosMapper","appPath","appId","helpers","isWriteable","log","info","dstPath","path","resolve","basename","fs","copyFile","packagesInfo","B","all","map","apkPath","testApkPath","shouldUninstallServerPackages","shouldInstallServerPackages","isAppInstalled","adb","checkApkCert","signApp","appState","getApplicationInstallState","debug","APP_INSTALL_STATE","OLDER_VERSION_INSTALLED","NEWER_VERSION_INSTALLED","includes","NOT_INSTALLED","uninstallApk","err","warn","message","install","noIncremental","replace","timeoutCapName","rimraf","verifyServicesAvailability","isPmServiceAvailable","pmOutput","pmError","shell","e","waitMs","intervalMs","error","line","split","startSession","caps","cleanupAutomationLeftovers","skipServerInstallation","serverVersion","uiautomator2ServerLaunchTimeout","timer","timing","Timer","start","retries","maxRetries","delayBetweenRetries","startInstrumentationProcess","errorAndThrow","delay","getDuration","asMilliSeconds","toFixed","capabilities","firstMatch","alwaysMatch","cmd","disableWindowAnimation","push","_","isBoolean","instrumentationProcess","createSubProcess","on","stdout","stderr","output","trim","code","deleteSession","strictCleanup","value","data","activeSessionIds","id","filter","Boolean","length","JSON","stringify","pluralize","axios","delete","forceStop","ignore","killProcessesByName"],"mappings":"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","sourcesContent":["import _ from 'lodash';\nimport { JWProxy, errors } from '@appium/base-driver';\nimport { waitForCondition } from 'asyncbox';\nimport log from './logger';\nimport {\n  SERVER_APK_PATH as apkPath,\n  TEST_APK_PATH as testApkPath,\n  version as serverVersion\n} from 'appium-uiautomator2-server';\nimport {\n  util, logger, tempDir, fs, timing\n} from '@appium/support';\nimport B from 'bluebird';\nimport helpers from './helpers';\nimport axios from 'axios';\nimport path from 'path';\n\nconst REQD_PARAMS = ['adb', 'tmpDir', 'host', 'systemPort', 'devicePort', 'disableWindowAnimation'];\nconst SERVER_LAUNCH_TIMEOUT = 30000;\nconst SERVER_INSTALL_RETRIES = 20;\nconst SERVICES_LAUNCH_TIMEOUT = 30000;\nconst SERVER_PACKAGE_ID = 'io.appium.uiautomator2.server';\nconst SERVER_TEST_PACKAGE_ID = `${SERVER_PACKAGE_ID}.test`;\nconst INSTRUMENTATION_TARGET = `${SERVER_TEST_PACKAGE_ID}/androidx.test.runner.AndroidJUnitRunner`;\nconst instrumentationLogger = logger.getLogger('Instrumentation');\n\nclass UIA2Proxy extends JWProxy {\n  async proxyCommand (url, method, body = null) {\n    if (this.didInstrumentationExit) {\n      throw new errors.InvalidContextError(\n        `'${method} ${url}' cannot be proxied to UiAutomator2 server because ` +\n        'the instrumentation process is not running (probably crashed). ' +\n        'Check the server log and/or the logcat output for more details');\n    }\n    return await super.proxyCommand(url, method, body);\n  }\n}\n\nclass UiAutomator2Server {\n  constructor (opts = {}) {\n    for (let req of REQD_PARAMS) {\n      if (!opts || !util.hasValue(opts[req])) {\n        throw new Error(`Option '${req}' is required!`);\n      }\n      this[req] = opts[req];\n    }\n    this.disableSuppressAccessibilityService = opts.disableSuppressAccessibilityService;\n    const proxyOpts = {\n      server: this.host,\n      port: this.systemPort,\n      keepAlive: true,\n    };\n    if (opts.readTimeout && opts.readTimeout > 0) {\n      proxyOpts.timeout = opts.readTimeout;\n    }\n    this.jwproxy = new UIA2Proxy(proxyOpts);\n    this.proxyReqRes = this.jwproxy.proxyReqRes.bind(this.jwproxy);\n    this.proxyCommand = this.jwproxy.command.bind(this.jwproxy);\n    this.jwproxy.didInstrumentationExit = false;\n  }\n\n  /**\n   * Installs the apks on to the device or emulator.\n   *\n   * @param {number} installTimeout - Installation timeout\n   */\n  async installServerApk (installTimeout = SERVER_INSTALL_RETRIES * 1000) {\n    const tmpRoot = await tempDir.openDir();\n    const packageInfosMapper = async ({appPath, appId}) => {\n      if (await helpers.isWriteable(appPath)) {\n        return { appPath, appId };\n      }\n\n      log.info(`Server package at '${appPath}' is not writeable. ` +\n        `Will copy it into the temporary location at '${tmpRoot}' as a workaround. ` +\n        `Consider making this file writeable manually in order to improve the performance of session startup.`);\n      const dstPath = path.resolve(tmpRoot, path.basename(appPath));\n      await fs.copyFile(appPath, dstPath);\n      return {\n        appPath: dstPath,\n        appId,\n      };\n    };\n\n    try {\n      const packagesInfo = await B.all(B.map([\n        {\n          appPath: apkPath,\n          appId: SERVER_PACKAGE_ID,\n        }, {\n          appPath: testApkPath,\n          appId: SERVER_TEST_PACKAGE_ID,\n        },\n      ], packageInfosMapper));\n\n      let shouldUninstallServerPackages = false;\n      let shouldInstallServerPackages = false;\n      for (const {appId, appPath} of packagesInfo) {\n        if (appId === SERVER_TEST_PACKAGE_ID) {\n          const isAppInstalled = await this.adb.isAppInstalled(appId);\n\n          // There is no point in getting the state for test server,\n          // since it does not contain version info\n          if (!await this.adb.checkApkCert(appPath, appId)) {\n            await helpers.signApp(this.adb, appPath);\n            shouldUninstallServerPackages = shouldUninstallServerPackages || isAppInstalled;\n            shouldInstallServerPackages = true;\n          }\n\n          if (!isAppInstalled) {\n            shouldInstallServerPackages = true;\n          }\n          continue;\n        }\n\n        const appState = await this.adb.getApplicationInstallState(appPath, appId);\n        log.debug(`${appId} installation state: ${appState}`);\n        if (await this.adb.checkApkCert(appPath, appId)) {\n          shouldUninstallServerPackages = shouldUninstallServerPackages || [\n            this.adb.APP_INSTALL_STATE.OLDER_VERSION_INSTALLED,\n            this.adb.APP_INSTALL_STATE.NEWER_VERSION_INSTALLED,\n          ].includes(appState);\n        } else {\n          await helpers.signApp(this.adb, appPath);\n          shouldUninstallServerPackages = shouldUninstallServerPackages || ![\n            this.adb.APP_INSTALL_STATE.NOT_INSTALLED,\n          ].includes(appState);\n        }\n        shouldInstallServerPackages = shouldInstallServerPackages || shouldUninstallServerPackages || [\n          this.adb.APP_INSTALL_STATE.NOT_INSTALLED,\n        ].includes(appState);\n      }\n      log.info(`Server packages are ${shouldInstallServerPackages ? '' : 'not '}going to be (re)installed`);\n      if (shouldInstallServerPackages && shouldUninstallServerPackages) {\n        log.info('Full packages reinstall is going to be performed');\n      }\n      for (const {appId, appPath} of packagesInfo) {\n        if (shouldUninstallServerPackages) {\n          try {\n            await this.adb.uninstallApk(appId);\n          } catch (err) {\n            log.warn(`Error uninstalling '${appId}': ${err.message}`);\n          }\n        }\n        if (shouldInstallServerPackages) {\n          await this.adb.install(appPath, {\n            noIncremental: true,\n            replace: true,\n            timeout: installTimeout,\n            timeoutCapName: 'uiautomator2ServerInstallTimeout'\n          });\n        }\n      }\n    } finally {\n      await fs.rimraf(tmpRoot);\n    }\n\n    await this.verifyServicesAvailability();\n  }\n\n  async verifyServicesAvailability () {\n    log.debug(`Waiting up to ${SERVICES_LAUNCH_TIMEOUT}ms for services to be available`);\n    let isPmServiceAvailable = false;\n    let pmOutput = '';\n    let pmError = null;\n    try {\n      await waitForCondition(async () => {\n        if (!isPmServiceAvailable) {\n          pmError = null;\n          pmOutput = '';\n          try {\n            pmOutput = await this.adb.shell(['pm', 'list', 'instrumentation']);\n          } catch (e) {\n            pmError = e;\n          }\n          if (pmOutput.includes('Could not access the Package Manager')) {\n            pmError = new Error(`Problem running Package Manager: ${pmOutput}`);\n            pmOutput = ''; // remove output, so it is not printed below\n          } else if (pmOutput.includes(INSTRUMENTATION_TARGET)) {\n            pmOutput = ''; // remove output, so it is not printed below\n            log.debug(`Instrumentation target '${INSTRUMENTATION_TARGET}' is available`);\n            // eslint-disable-next-line require-atomic-updates\n            isPmServiceAvailable = true;\n          } else if (!pmError) {\n            pmError = new Error('The instrumentation target is not listed by Package Manager');\n          }\n        }\n        return isPmServiceAvailable;\n      }, {\n        waitMs: SERVICES_LAUNCH_TIMEOUT,\n        intervalMs: 1000,\n      });\n    } catch (err) {\n      log.error(`Unable to find instrumentation target '${INSTRUMENTATION_TARGET}': ${(pmError || {}).message}`);\n      if (pmOutput) {\n        log.debug('Available targets:');\n        for (const line of pmOutput.split('\\n')) {\n          log.debug(`    ${line.replace('instrumentation:', '')}`);\n        }\n      }\n    }\n  }\n\n  async startSession (caps) {\n    await this.cleanupAutomationLeftovers();\n    if (caps.skipServerInstallation) {\n      log.info(`'skipServerInstallation' is set. Attempting to use UIAutomator2 server from the device`);\n    } else {\n      log.info(`Starting UIAutomator2 server ${serverVersion}`);\n      log.info(`Using UIAutomator2 server from '${apkPath}' and test from '${testApkPath}'`);\n    }\n\n    const timeout = caps.uiautomator2ServerLaunchTimeout || SERVER_LAUNCH_TIMEOUT;\n    const timer = new timing.Timer().start();\n    let retries = 0;\n    const maxRetries = 2;\n    const delayBetweenRetries = 3000;\n    while (retries < maxRetries) {\n      log.info(`Waiting up to ${timeout}ms for UiAutomator2 to be online...`);\n      this.jwproxy.didInstrumentationExit = false;\n      await this.startInstrumentationProcess();\n      if (!this.jwproxy.didInstrumentationExit) {\n        try {\n          await waitForCondition(async () => {\n            try {\n              await this.jwproxy.command('/status', 'GET');\n              return true;\n            } catch (err) {\n              // short circuit to retry or fail fast\n              return this.jwproxy.didInstrumentationExit;\n            }\n          }, {\n            waitMs: timeout,\n            intervalMs: 1000,\n          });\n        } catch (err) {\n          log.errorAndThrow(`The instrumentation process cannot be initialized within ${timeout}ms timeout. `\n            + 'Make sure the application under test does not crash and investigate the logcat output. '\n            + `You could also try to increase the value of 'uiautomator2ServerLaunchTimeout' capability`);\n        }\n      }\n      if (!this.jwproxy.didInstrumentationExit) {\n        break;\n      }\n\n      retries++;\n      if (retries >= maxRetries) {\n        log.errorAndThrow('The instrumentation process cannot be initialized. '\n          + 'Make sure the application under test does not crash and investigate the logcat output.');\n      }\n      log.warn(`The instrumentation process has been unexpectedly terminated. `\n        + `Retrying UiAutomator2 startup (#${retries} of ${maxRetries - 1})`);\n      await this.cleanupAutomationLeftovers(true);\n      await B.delay(delayBetweenRetries);\n    }\n\n    log.debug(`The initialization of the instrumentation process took `\n      + `${timer.getDuration().asMilliSeconds.toFixed(0)}ms`);\n    await this.jwproxy.command('/session', 'POST', {\n      capabilities: {\n        firstMatch: [caps],\n        alwaysMatch: {},\n      }\n    });\n  }\n\n  async startInstrumentationProcess () {\n    const cmd = ['am', 'instrument', '-w'];\n    if (this.disableWindowAnimation) {\n      cmd.push('--no-window-animation');\n    }\n    if (_.isBoolean(this.disableSuppressAccessibilityService)) {\n      cmd.push('-e', 'DISABLE_SUPPRESS_ACCESSIBILITY_SERVICES', this.disableSuppressAccessibilityService);\n    }\n    // Disable Google analytics to prevent possible fatal exception\n    cmd.push('-e', 'disableAnalytics', true);\n    cmd.push(INSTRUMENTATION_TARGET);\n    const instrumentationProcess = this.adb.createSubProcess(['shell', ...cmd]);\n    instrumentationProcess.on('output', (stdout, stderr) => {\n      const output = _.trim(stdout || stderr);\n      if (output) {\n        instrumentationLogger.debug(output);\n      }\n    });\n    instrumentationProcess.on('exit', (code) => {\n      instrumentationLogger.debug(`The process has exited with code ${code}`);\n      this.jwproxy.didInstrumentationExit = true;\n    });\n    await instrumentationProcess.start(0);\n  }\n\n  async deleteSession () {\n    log.debug('Deleting UiAutomator2 server session');\n    // rely on jwproxy's intelligence to know what we're talking about and\n    // delete the current session\n    try {\n      await this.jwproxy.command('/', 'DELETE');\n    } catch (err) {\n      log.warn(`Did not get confirmation UiAutomator2 deleteSession worked; ` +\n          `Error was: ${err}`);\n    }\n  }\n\n  async cleanupAutomationLeftovers (strictCleanup = false) {\n    log.debug(`Performing ${strictCleanup ? 'strict' : 'shallow'} cleanup of automation leftovers`);\n\n    try {\n      const {value} = (await axios({\n        url: `http://${this.host}:${this.systemPort}/wd/hub/sessions`,\n        timeout: 500,\n      })).data;\n      const activeSessionIds = value.map(({id}) => id).filter(Boolean);\n      if (activeSessionIds.length) {\n        log.debug(`The following obsolete sessions are still running: ${JSON.stringify(activeSessionIds)}`);\n        log.debug(`Cleaning up ${util.pluralize('obsolete session', activeSessionIds.length, true)}`);\n        await B.all(activeSessionIds\n          .map((id) => axios.delete(`http://${this.host}:${this.systemPort}/wd/hub/session/${id}`))\n        );\n        // Let all sessions to be properly terminated before continuing\n        await B.delay(1000);\n      } else {\n        log.debug('No obsolete sessions have been detected');\n      }\n    } catch (e) {\n      log.debug(`No obsolete sessions have been detected (${e.message})`);\n    }\n\n    try {\n      await this.adb.forceStop(SERVER_TEST_PACKAGE_ID);\n    } catch (ignore) {}\n    if (!strictCleanup) {\n      return;\n    }\n    // https://github.com/appium/appium/issues/10749\n    try {\n      await this.adb.killProcessesByName('uiautomator');\n    } catch (ignore) {}\n  }\n}\n\nexport { UiAutomator2Server, INSTRUMENTATION_TARGET, SERVER_PACKAGE_ID, SERVER_TEST_PACKAGE_ID };\nexport default UiAutomator2Server;\n"],"file":"lib/uiautomator2.js","sourceRoot":"../.."}
package/lib/.DS_Store ADDED
Binary file
@@ -1,7 +1,7 @@
1
1
  import log from '../logger';
2
2
  import _ from 'lodash';
3
- import { util } from 'appium-support';
4
- import { PROTOCOLS, W3C_ELEMENT_KEY } from 'appium-base-driver';
3
+ import { util } from '@appium/support';
4
+ import { PROTOCOLS, W3C_ELEMENT_KEY } from '@appium/base-driver';
5
5
 
6
6
  let commands = {}, helpers = {}, extensions = {};
7
7
 
@@ -1,6 +1,6 @@
1
1
  import CssConverter from '../css-converter';
2
2
 
3
- let helpers = {}, extensions = {};
3
+ const helpers = {};
4
4
 
5
5
  // we override the xpath search for this first-visible-child selector, which
6
6
  // looks like /*[@firstVisible="true"]
@@ -24,15 +24,11 @@ helpers.doFindElementOrEls = async function (params) {
24
24
  }
25
25
  if (params.strategy === 'css selector') {
26
26
  params.strategy = '-android uiautomator';
27
- params.selector = CssConverter.toUiAutomatorSelector(params.selector);
28
- }
29
- if (params.multiple) {
30
- return await this.uiautomator2.jwproxy.command(`/elements`, 'POST', params);
31
- } else {
32
- return await this.uiautomator2.jwproxy.command(`/element`, 'POST', params);
27
+ params.selector = new CssConverter(params.selector, this.opts.appPackage)
28
+ .toUiAutomatorSelector();
33
29
  }
30
+ return await this.uiautomator2.jwproxy.command(`/element${params.multiple ? 's' : ''}`, 'POST', params);
34
31
  };
35
32
 
36
- Object.assign(extensions, helpers);
37
33
  export { helpers };
38
- export default extensions;
34
+ export default helpers;
@@ -1,8 +1,8 @@
1
1
  import _ from 'lodash';
2
2
  import log from '../logger';
3
3
  import B from 'bluebird';
4
- import { errors, BASEDRIVER_HANDLED_SETTINGS } from 'appium-base-driver';
5
- import { fs, tempDir } from 'appium-support';
4
+ import { errors, BASEDRIVER_HANDLED_SETTINGS } from '@appium/base-driver';
5
+ import { fs, tempDir } from '@appium/support';
6
6
  import { APK_EXTENSION } from '../extensions';
7
7
 
8
8
  let extensions = {},
@@ -170,6 +170,8 @@ extensions.executeMobile = async function (mobileCommand, opts = {}) {
170
170
  installMultipleApks: 'mobileInstallMultipleApks',
171
171
 
172
172
  unlock: 'mobileUnlock',
173
+
174
+ refreshGpsCache: 'mobileRefreshGpsCache',
173
175
  };
174
176
 
175
177
  if (!_.has(mobileCommandsMapping, mobileCommand)) {
@@ -1,6 +1,6 @@
1
- import { util } from 'appium-support';
1
+ import { util } from '@appium/support';
2
2
  import _ from 'lodash';
3
- import { errors } from 'appium-base-driver';
3
+ import { errors } from '@appium/base-driver';
4
4
 
5
5
  const commands = {};
6
6
 
@@ -1,4 +1,4 @@
1
- import { imageUtil } from 'appium-support';
1
+ import { imageUtil } from '@appium/support';
2
2
 
3
3
 
4
4
  let extensions = {}, commands = {};