appium-chromedriver 4.28.0 → 5.0.2

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.
@@ -11,11 +11,11 @@ require("source-map-support/register");
11
11
 
12
12
  var _events = _interopRequireDefault(require("events"));
13
13
 
14
- var _appiumBaseDriver = require("appium-base-driver");
14
+ var _baseDriver = require("@appium/base-driver");
15
15
 
16
16
  var _child_process = _interopRequireDefault(require("child_process"));
17
17
 
18
- var _appiumSupport = require("appium-support");
18
+ var _support = require("@appium/support");
19
19
 
20
20
  var _asyncbox = require("asyncbox");
21
21
 
@@ -37,7 +37,7 @@ var _storageClient = _interopRequireDefault(require("./storage-client"));
37
37
 
38
38
  var _protocolHelpers = require("./protocol-helpers");
39
39
 
40
- const log = _appiumSupport.logger.getLogger('Chromedriver');
40
+ const log = _support.logger.getLogger('Chromedriver');
41
41
 
42
42
  const NEW_CD_VERSION_FORMAT_MAJOR_VERSION = 73;
43
43
  const DEFAULT_HOST = '127.0.0.1';
@@ -81,7 +81,7 @@ class Chromedriver extends _events.default.EventEmitter {
81
81
  this.bundleId = bundleId;
82
82
  this.executableVerified = false;
83
83
  this.state = Chromedriver.STATE_STOPPED;
84
- this.jwproxy = new _appiumBaseDriver.JWProxy({
84
+ this.jwproxy = new _baseDriver.JWProxy({
85
85
  server: this.proxyHost,
86
86
  port: this.proxyPort
87
87
  });
@@ -93,7 +93,7 @@ class Chromedriver extends _events.default.EventEmitter {
93
93
  }) : null;
94
94
  this.details = details;
95
95
  this.capabilities = {};
96
- this.desiredProtocol = _appiumBaseDriver.PROTOCOLS.MJSONWP;
96
+ this.desiredProtocol = _baseDriver.PROTOCOLS.MJSONWP;
97
97
  }
98
98
 
99
99
  async getDriversMapping() {
@@ -102,12 +102,12 @@ class Chromedriver extends _events.default.EventEmitter {
102
102
  if (this.mappingPath) {
103
103
  log.debug(`Attempting to use Chromedriver->Chrome mapping from '${this.mappingPath}'`);
104
104
 
105
- if (!(await _appiumSupport.fs.exists(this.mappingPath))) {
105
+ if (!(await _support.fs.exists(this.mappingPath))) {
106
106
  log.warn(`No file found at '${this.mappingPath}'`);
107
107
  log.info('Defaulting to the static Chromedriver->Chrome mapping');
108
108
  } else {
109
109
  try {
110
- mapping = JSON.parse(await _appiumSupport.fs.readFile(this.mappingPath, 'utf8'));
110
+ mapping = JSON.parse(await _support.fs.readFile(this.mappingPath, 'utf8'));
111
111
  } catch (err) {
112
112
  log.warn(`Error parsing mapping from '${this.mappingPath}': ${err.message}`);
113
113
  log.info('Defaulting to the static Chromedriver->Chrome mapping');
@@ -131,8 +131,8 @@ class Chromedriver extends _events.default.EventEmitter {
131
131
  }
132
132
 
133
133
  async getChromedrivers(mapping) {
134
- const executables = await _appiumSupport.fs.glob(`${this.executableDir}/*`);
135
- log.debug(`Found ${_appiumSupport.util.pluralize('executable', executables.length, true)} ` + `in '${this.executableDir}'`);
134
+ const executables = await _support.fs.glob(`${this.executableDir}/*`);
135
+ log.debug(`Found ${_support.util.pluralize('executable', executables.length, true)} ` + `in '${this.executableDir}'`);
136
136
  const cds = (await (0, _asyncbox.asyncmap)(executables, async function mapChromedriver(executable) {
137
137
  const logError = ({
138
138
  message,
@@ -283,9 +283,9 @@ class Chromedriver extends _events.default.EventEmitter {
283
283
  async updateDriversMapping(newMapping) {
284
284
  let shouldUpdateStaticMapping = true;
285
285
 
286
- if (await _appiumSupport.fs.exists(this.mappingPath)) {
286
+ if (await _support.fs.exists(this.mappingPath)) {
287
287
  try {
288
- await _appiumSupport.fs.writeFile(this.mappingPath, JSON.stringify(newMapping, null, 2), 'utf8');
288
+ await _support.fs.writeFile(this.mappingPath, JSON.stringify(newMapping, null, 2), 'utf8');
289
289
  shouldUpdateStaticMapping = false;
290
290
  } catch (e) {
291
291
  log.warn(`Cannot store the updated chromedrivers mapping into '${this.mappingPath}'. ` + `This may reduce the performance of further executions. Original error: ${e.message}`);
@@ -357,7 +357,7 @@ class Chromedriver extends _events.default.EventEmitter {
357
357
  }
358
358
 
359
359
  if (!_lodash.default.isEmpty(missingVersions)) {
360
- log.info(`Found ${_appiumSupport.util.pluralize('Chromedriver', _lodash.default.size(missingVersions), true)}, ` + `which ${_lodash.default.size(missingVersions) === 1 ? 'is' : 'are'} missing in the list of known versions: ` + JSON.stringify(missingVersions));
360
+ log.info(`Found ${_support.util.pluralize('Chromedriver', _lodash.default.size(missingVersions), true)}, ` + `which ${_lodash.default.size(missingVersions) === 1 ? 'is' : 'are'} missing in the list of known versions: ` + JSON.stringify(missingVersions));
361
361
  await this.updateDriversMapping(Object.assign(mapping, missingVersions));
362
362
  }
363
363
 
@@ -420,7 +420,7 @@ class Chromedriver extends _events.default.EventEmitter {
420
420
  }
421
421
 
422
422
  const binPath = matchingDrivers[0].executable;
423
- log.debug(`Found ${_appiumSupport.util.pluralize('executable', matchingDrivers.length, true)} ` + `capable of automating Chrome '${chromeVersion}'.\nChoosing the most recent, '${binPath}'.`);
423
+ log.debug(`Found ${_support.util.pluralize('executable', matchingDrivers.length, true)} ` + `capable of automating Chrome '${chromeVersion}'.\nChoosing the most recent, '${binPath}'.`);
424
424
  log.debug('If a specific version is required, specify it with the `chromedriverExecutable`' + 'desired capability.');
425
425
  return binPath;
426
426
  } while (true);
@@ -433,7 +433,7 @@ class Chromedriver extends _events.default.EventEmitter {
433
433
  this.chromedriver = this.useSystemExecutable ? await (0, _utils.getChromedriverBinaryPath)() : await this.getCompatibleChromedriver();
434
434
  }
435
435
 
436
- if (!(await _appiumSupport.fs.exists(this.chromedriver))) {
436
+ if (!(await _support.fs.exists(this.chromedriver))) {
437
437
  throw new Error(`Trying to use a chromedriver binary at the path ` + `${this.chromedriver}, but it doesn't exist!`);
438
438
  }
439
439
 
@@ -445,18 +445,18 @@ class Chromedriver extends _events.default.EventEmitter {
445
445
  const coercedVersion = _semver.default.coerce(cdVersion);
446
446
 
447
447
  if (!coercedVersion || coercedVersion.major < MIN_CD_VERSION_WITH_W3C_SUPPORT) {
448
- log.debug(`Chromedriver v. ${cdVersion} does not fully support ${_appiumBaseDriver.PROTOCOLS.W3C} protocol. ` + `Defaulting to ${_appiumBaseDriver.PROTOCOLS.MJSONWP}`);
448
+ log.debug(`Chromedriver v. ${cdVersion} does not fully support ${_baseDriver.PROTOCOLS.W3C} protocol. ` + `Defaulting to ${_baseDriver.PROTOCOLS.MJSONWP}`);
449
449
  return;
450
450
  }
451
451
 
452
452
  const chromeOptions = (0, _protocolHelpers.getCapValue)(this.capabilities, 'chromeOptions', {});
453
453
 
454
454
  if (chromeOptions.w3c === false) {
455
- log.info(`Chromedriver v. ${cdVersion} supports ${_appiumBaseDriver.PROTOCOLS.W3C} protocol, ` + `but ${_appiumBaseDriver.PROTOCOLS.MJSONWP} one has been explicitly requested`);
455
+ log.info(`Chromedriver v. ${cdVersion} supports ${_baseDriver.PROTOCOLS.W3C} protocol, ` + `but ${_baseDriver.PROTOCOLS.MJSONWP} one has been explicitly requested`);
456
456
  return;
457
457
  }
458
458
 
459
- this.desiredProtocol = _appiumBaseDriver.PROTOCOLS.W3C;
459
+ this.desiredProtocol = _baseDriver.PROTOCOLS.W3C;
460
460
  this.capabilities = (0, _protocolHelpers.toW3cCapNames)(this.capabilities);
461
461
  }
462
462
 
@@ -472,7 +472,7 @@ class Chromedriver extends _events.default.EventEmitter {
472
472
  this.changeState(Chromedriver.STATE_STARTING);
473
473
  }
474
474
 
475
- const args = ['--url-base=wd/hub', `--port=${this.proxyPort}`];
475
+ const args = [`--port=${this.proxyPort}`];
476
476
 
477
477
  if (this.adb && this.adb.adbPort) {
478
478
  args.push(`--adb-port=${this.adb.adbPort}`);
@@ -617,7 +617,7 @@ class Chromedriver extends _events.default.EventEmitter {
617
617
  }
618
618
 
619
619
  async startSession() {
620
- const sessionCaps = this.desiredProtocol === _appiumBaseDriver.PROTOCOLS.W3C ? {
620
+ const sessionCaps = this.desiredProtocol === _baseDriver.PROTOCOLS.W3C ? {
621
621
  capabilities: {
622
622
  alwaysMatch: this.capabilities
623
623
  }
@@ -634,15 +634,20 @@ class Chromedriver extends _events.default.EventEmitter {
634
634
  this.changeState(Chromedriver.STATE_STOPPING);
635
635
  }
636
636
 
637
- try {
638
- await this.jwproxy.command('', 'DELETE');
639
- await this.proc.stop('SIGTERM', 20000);
640
-
641
- if (emitStates) {
642
- this.changeState(Chromedriver.STATE_STOPPED);
637
+ const runSafeStep = async f => {
638
+ try {
639
+ return await f();
640
+ } catch (e) {
641
+ log.warn(e.message);
642
+ log.debug(e.stack);
643
643
  }
644
- } catch (e) {
645
- log.error(e);
644
+ };
645
+
646
+ await runSafeStep(() => this.jwproxy.command('', 'DELETE'));
647
+ await runSafeStep(() => this.proc.stop('SIGTERM', 20000));
648
+
649
+ if (emitStates) {
650
+ this.changeState(Chromedriver.STATE_STOPPED);
646
651
  }
647
652
  }
648
653
 
@@ -663,7 +668,7 @@ class Chromedriver extends _events.default.EventEmitter {
663
668
  }
664
669
 
665
670
  async killAll() {
666
- let cmd = _appiumSupport.system.isWindows() ? `wmic process where "commandline like '%chromedriver.exe%--port=${this.proxyPort}%'" delete` : `pkill -15 -f "${this.chromedriver}.*--port=${this.proxyPort}"`;
671
+ let cmd = _support.system.isWindows() ? `wmic process where "commandline like '%chromedriver.exe%--port=${this.proxyPort}%'" delete` : `pkill -15 -f "${this.chromedriver}.*--port=${this.proxyPort}"`;
667
672
  log.debug(`Killing any old chromedrivers, running: ${cmd}`);
668
673
 
669
674
  try {
@@ -724,4 +729,4 @@ var _default = Chromedriver;
724
729
  exports.default = _default;require('source-map-support').install();
725
730
 
726
731
 
727
- //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/chromedriver.js"],"names":["log","logger","getLogger","NEW_CD_VERSION_FORMAT_MAJOR_VERSION","DEFAULT_HOST","MIN_CD_VERSION_WITH_W3C_SUPPORT","DEFAULT_PORT","CHROME_BUNDLE_ID","WEBVIEW_SHELL_BUNDLE_ID","WEBVIEW_BUNDLE_IDS","CHROMEDRIVER_TUTORIAL","VERSION_PATTERN","CD_VERSION_TIMEOUT","Chromedriver","events","EventEmitter","constructor","args","host","port","useSystemExecutable","executable","executableDir","bundleId","mappingPath","cmdArgs","adb","verbose","logPath","disableBuildCheck","details","isAutodownloadEnabled","proxyHost","proxyPort","proc","chromedriver","executableVerified","state","STATE_STOPPED","jwproxy","JWProxy","server","storageClient","ChromedriverStorageClient","chromedriverDir","capabilities","desiredProtocol","PROTOCOLS","MJSONWP","getDriversMapping","mapping","_","cloneDeep","CHROMEDRIVER_CHROME_MAPPING","debug","fs","exists","warn","info","JSON","parse","readFile","err","message","cdVersion","chromeVersion","toPairs","coercedVersion","semver","coerce","version","getChromedrivers","executables","glob","util","pluralize","length","cds","mapChromedriver","logError","stdout","stderr","errMsg","path","basename","timeout","includes","match","exec","minChromeVersion","major","minor","filter","cd","sort","a","b","isEmpty","getChromeVersion","Browser","versionMatch","apiLevel","getApiLevel","updateDriversMapping","newMapping","shouldUpdateStaticMapping","writeFile","stringify","e","Object","assign","getCompatibleChromedriver","values","didStorageSync","syncChromedrivers","retrievedMapping","retrieveMapping","driverKeys","syncDrivers","minBrowserVersion","synchronizedDriversMapping","reduce","acc","x","missingVersions","coercedVer","size","errorAndThrow","matchingDrivers","minChromeVersionS","gte","CD_CDN","stack","autodownloadSuggestion","Error","binPath","initChromedriverPath","syncProtocol","W3C","chromeOptions","w3c","start","caps","emitStartingState","loggingPrefs","browser","changeState","STATE_STARTING","adbPort","push","isArray","startDetector","startsWith","processIsAlive","webviewVersion","killAll","SubProcess","on","out","line","trim","split","error","code","signal","STATE_STOPPING","STATE_RESTARTING","msg","join","waitForOnline","startSession","emit","EVENT_ERROR","stop","versionsSupportedByDriver","sessionId","STATE_ONLINE","restart","chromedriverStopped","getStatus","command","sessionCaps","alwaysMatch","desiredCapabilities","emitStates","EVENT_CHANGED","sendCommand","url","method","body","proxyReq","req","res","proxyReqRes","cmd","system","isWindows","B","promisify","cp","udidIndex","defaultArgs","findIndex","item","udid","conn","getForwardList","params","removePortForward","replace","hasWorkingWebview"],"mappings":"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","sourcesContent":["// transpile:main\n\nimport events from 'events';\nimport { JWProxy, PROTOCOLS } from 'appium-base-driver';\nimport cp from 'child_process';\nimport { system, fs, logger, util } from 'appium-support';\nimport { retryInterval, asyncmap } from 'asyncbox';\nimport { SubProcess, exec } from 'teen_process';\nimport B from 'bluebird';\nimport {\n  getChromeVersion, getChromedriverDir, CHROMEDRIVER_CHROME_MAPPING,\n  getChromedriverBinaryPath, CD_CDN,\n} from './utils';\nimport semver from 'semver';\nimport _ from 'lodash';\nimport path from 'path';\nimport compareVersions from 'compare-versions';\nimport ChromedriverStorageClient from './storage-client';\nimport { toW3cCapNames, getCapValue } from './protocol-helpers';\n\n\nconst log = logger.getLogger('Chromedriver');\n\nconst NEW_CD_VERSION_FORMAT_MAJOR_VERSION = 73;\nconst DEFAULT_HOST = '127.0.0.1';\nconst MIN_CD_VERSION_WITH_W3C_SUPPORT = 75;\nconst DEFAULT_PORT = 9515;\nconst CHROME_BUNDLE_ID = 'com.android.chrome';\nconst WEBVIEW_SHELL_BUNDLE_ID = 'org.chromium.webview_shell';\nconst WEBVIEW_BUNDLE_IDS = [\n  'com.google.android.webview',\n  'com.android.webview',\n];\nconst CHROMEDRIVER_TUTORIAL = 'https://github.com/appium/appium/blob/master/docs/en/writing-running-appium/web/chromedriver.md';\nconst VERSION_PATTERN = /([\\d.]+)/;\n\nconst CD_VERSION_TIMEOUT = 5000;\n\nclass Chromedriver extends events.EventEmitter {\n  constructor (args = {}) {\n    super();\n\n    const {\n      host = DEFAULT_HOST,\n      port = DEFAULT_PORT,\n      useSystemExecutable = false,\n      executable,\n      executableDir = getChromedriverDir(),\n      bundleId,\n      mappingPath,\n      cmdArgs,\n      adb,\n      verbose,\n      logPath,\n      disableBuildCheck,\n      details,\n      isAutodownloadEnabled = false,\n    } = args;\n\n    this.proxyHost = host;\n    this.proxyPort = port;\n    this.adb = adb;\n    this.cmdArgs = cmdArgs;\n    this.proc = null;\n    this.useSystemExecutable = useSystemExecutable;\n    this.chromedriver = executable;\n    this.executableDir = executableDir;\n    this.mappingPath = mappingPath;\n    this.bundleId = bundleId;\n    this.executableVerified = false;\n    this.state = Chromedriver.STATE_STOPPED;\n    this.jwproxy = new JWProxy({server: this.proxyHost, port: this.proxyPort});\n    this.verbose = verbose;\n    this.logPath = logPath;\n    this.disableBuildCheck = !!disableBuildCheck;\n    this.storageClient = isAutodownloadEnabled\n      ? new ChromedriverStorageClient({ chromedriverDir: this.executableDir })\n      : null;\n    this.details = details;\n    this.capabilities = {};\n    this.desiredProtocol = PROTOCOLS.MJSONWP;\n  }\n\n  async getDriversMapping () {\n    let mapping = _.cloneDeep(CHROMEDRIVER_CHROME_MAPPING);\n    if (this.mappingPath) {\n      log.debug(`Attempting to use Chromedriver->Chrome mapping from '${this.mappingPath}'`);\n      if (!await fs.exists(this.mappingPath)) {\n        log.warn(`No file found at '${this.mappingPath}'`);\n        log.info('Defaulting to the static Chromedriver->Chrome mapping');\n      } else {\n        try {\n          mapping = JSON.parse(await fs.readFile(this.mappingPath, 'utf8'));\n        } catch (err) {\n          log.warn(`Error parsing mapping from '${this.mappingPath}': ${err.message}`);\n          log.info('Defaulting to the static Chromedriver->Chrome mapping');\n        }\n      }\n    } else {\n      log.debug('Using the static Chromedriver->Chrome mapping');\n    }\n\n    // make sure that the values for minimum chrome version are semver compliant\n    for (const [cdVersion, chromeVersion] of _.toPairs(mapping)) {\n      const coercedVersion = semver.coerce(chromeVersion);\n      if (coercedVersion) {\n        mapping[cdVersion] = coercedVersion.version;\n      } else {\n        log.info(`'${chromeVersion}' is not a valid version number. Skipping it`);\n      }\n    }\n    return mapping;\n  }\n\n  async getChromedrivers (mapping) {\n    // go through the versions available\n    const executables = await fs.glob(`${this.executableDir}/*`);\n    log.debug(`Found ${util.pluralize('executable', executables.length, true)} ` +\n      `in '${this.executableDir}'`);\n    const cds = (await asyncmap(executables, async function mapChromedriver (executable) {\n      const logError = ({message, stdout = null, stderr = null}) => {\n        let errMsg = `Cannot retrieve version number from '${path.basename(executable)}' Chromedriver binary. ` +\n          `Make sure it returns a valid version string in response to '--version' command line argument. ${message}`;\n        if (stdout) {\n          errMsg += `\\nStdout: ${stdout}`;\n        }\n        if (stderr) {\n          errMsg += `\\nStderr: ${stderr}`;\n        }\n        log.warn(errMsg);\n        return null;\n      };\n\n      let stdout;\n      let stderr;\n      try {\n        ({stdout, stderr} = await exec(executable, ['--version'], {\n          timeout: CD_VERSION_TIMEOUT,\n        }));\n      } catch (err) {\n        if (!(err.message || '').includes('timed out') && !(err.stdout || '').includes('Starting ChromeDriver')) {\n          return logError(err);\n        }\n\n        // if this has timed out, it has actually started Chromedriver,\n        // in which case there will also be the version string in the output\n        stdout = err.stdout;\n      }\n\n      const match = /ChromeDriver\\s+\\(?v?([\\d.]+)\\)?/i.exec(stdout); // https://regex101.com/r/zpj5wA/1\n      if (!match) {\n        return logError({message: 'Cannot parse the version string', stdout, stderr});\n      }\n      let version = match[1];\n      let minChromeVersion = mapping[version];\n      const coercedVersion = semver.coerce(version);\n      if (coercedVersion) {\n        // before 2019-03-06 versions were of the form major.minor\n        if (coercedVersion.major < NEW_CD_VERSION_FORMAT_MAJOR_VERSION) {\n          version = `${coercedVersion.major}.${coercedVersion.minor}`;\n          minChromeVersion = mapping[version];\n        }\n        if (!minChromeVersion && coercedVersion.major >= NEW_CD_VERSION_FORMAT_MAJOR_VERSION) {\n          // Assume the major Chrome version is the same as the corresponding driver major version\n          minChromeVersion = `${coercedVersion.major}`;\n        }\n      }\n      return {\n        executable,\n        version,\n        minChromeVersion,\n      };\n    }))\n      .filter((cd) => !!cd)\n      .sort((a, b) => compareVersions(b.version, a.version));\n    if (_.isEmpty(cds)) {\n      log.info(`No Chromedrivers were found in '${this.executableDir}'`);\n      return cds;\n    }\n    log.debug(`The following Chromedriver executables were found:`);\n    for (const cd of cds) {\n      log.debug(`    '${cd.executable}' (version '${cd.version}', minimum Chrome version '${cd.minChromeVersion ? cd.minChromeVersion : 'Unknown'}')`);\n    }\n    return cds;\n  }\n\n  async getChromeVersion () {\n    // Try to retrieve the version from `details` property if it is set\n    // The `info` item must contain the output of /json/version CDP command\n    // where `Browser` field looks like `Chrome/72.0.3601.0``\n    if (this.details?.info) {\n      log.debug(`Browser version in the supplied details: ${this.details?.info?.Browser}`);\n    }\n    const versionMatch = VERSION_PATTERN.exec(this.details?.info?.Browser);\n    if (versionMatch) {\n      const coercedVersion = semver.coerce(versionMatch[1]);\n      if (coercedVersion) {\n        return coercedVersion;\n      }\n    }\n\n    let chromeVersion;\n\n    // in case of WebView Browser Tester, simply try to find the underlying webview\n    if (this.bundleId === WEBVIEW_SHELL_BUNDLE_ID) {\n      for (const bundleId of WEBVIEW_BUNDLE_IDS) {\n        chromeVersion = await getChromeVersion(this.adb, bundleId);\n        if (chromeVersion) {\n          this.bundleId = bundleId;\n          return semver.coerce(chromeVersion);\n        }\n      }\n      return null;\n    }\n\n    // on Android 7-9 webviews are backed by the main Chrome, not the system webview\n    if (this.adb) {\n      const apiLevel = await this.adb.getApiLevel();\n      if (apiLevel >= 24 && apiLevel <= 28 &&\n          [WEBVIEW_SHELL_BUNDLE_ID, ...WEBVIEW_BUNDLE_IDS].includes(this.bundleId)) {\n        this.bundleId = CHROME_BUNDLE_ID;\n      }\n    }\n\n    // try out webviews when no bundle id is sent in\n    if (!this.bundleId) {\n      // default to the generic Chrome bundle\n      this.bundleId = CHROME_BUNDLE_ID;\n\n      // we have a webview of some sort, so try to find the bundle version\n      for (const bundleId of WEBVIEW_BUNDLE_IDS) {\n        chromeVersion = await getChromeVersion(this.adb, bundleId);\n        if (chromeVersion) {\n          this.bundleId = bundleId;\n          break;\n        }\n      }\n    }\n\n    // if we do not have a chrome version, it must not be a webview\n    if (!chromeVersion) {\n      chromeVersion = await getChromeVersion(this.adb, this.bundleId);\n    }\n\n    // make sure it is semver, so later checks won't fail\n    return chromeVersion ? semver.coerce(chromeVersion) : null;\n  }\n\n  async updateDriversMapping (newMapping) {\n    let shouldUpdateStaticMapping = true;\n    if (await fs.exists(this.mappingPath)) {\n      try {\n        await fs.writeFile(this.mappingPath, JSON.stringify(newMapping, null, 2), 'utf8');\n        shouldUpdateStaticMapping = false;\n      } catch (e) {\n        log.warn(`Cannot store the updated chromedrivers mapping into '${this.mappingPath}'. ` +\n          `This may reduce the performance of further executions. Original error: ${e.message}`);\n      }\n    }\n    if (shouldUpdateStaticMapping) {\n      Object.assign(CHROMEDRIVER_CHROME_MAPPING, newMapping);\n    }\n  }\n\n  async getCompatibleChromedriver () {\n    if (!this.adb) {\n      return await getChromedriverBinaryPath();\n    }\n\n    const mapping = await this.getDriversMapping();\n    if (!_.isEmpty(mapping)) {\n      log.debug(`The most recent known Chrome version: ${_.values(mapping)[0]}`);\n    }\n\n    let didStorageSync = false;\n    const syncChromedrivers = async (chromeVersion) => {\n      didStorageSync = true;\n      const retrievedMapping = await this.storageClient.retrieveMapping();\n      log.debug('Got chromedrivers mapping from the storage: ' +\n        JSON.stringify(retrievedMapping, null, 2));\n      const driverKeys = await this.storageClient.syncDrivers({\n        minBrowserVersion: chromeVersion.major,\n      });\n      if (_.isEmpty(driverKeys)) {\n        return false;\n      }\n      const synchronizedDriversMapping = driverKeys.reduce((acc, x) => {\n        const {version, minBrowserVersion} = retrievedMapping[x];\n        acc[version] = minBrowserVersion;\n        return acc;\n      }, {});\n      Object.assign(mapping, synchronizedDriversMapping);\n      await this.updateDriversMapping(mapping);\n      return true;\n    };\n\n    do {\n      const cds = await this.getChromedrivers(mapping);\n\n      const missingVersions = {};\n      for (const {version, minChromeVersion} of cds) {\n        if (!minChromeVersion || mapping[version]) {\n          continue;\n        }\n        const coercedVer = semver.coerce(version);\n        if (!coercedVer || coercedVer.major < NEW_CD_VERSION_FORMAT_MAJOR_VERSION) {\n          continue;\n        }\n\n        missingVersions[version] = minChromeVersion;\n      }\n      if (!_.isEmpty(missingVersions)) {\n        log.info(`Found ${util.pluralize('Chromedriver', _.size(missingVersions), true)}, ` +\n          `which ${_.size(missingVersions) === 1 ? 'is' : 'are'} missing in the list of known versions: ` +\n          JSON.stringify(missingVersions));\n        await this.updateDriversMapping(Object.assign(mapping, missingVersions));\n      }\n\n      if (this.disableBuildCheck) {\n        if (_.isEmpty(cds)) {\n          log.errorAndThrow(`There must be at least one Chromedriver executable available for use if ` +\n            `'chromedriverDisableBuildCheck' capability is set to 'true'`);\n        }\n        const {version, executable} = cds[0];\n        log.warn(`Chrome build check disabled. Using most recent Chromedriver version (${version}, at '${executable}')`);\n        log.warn(`If this is wrong, set 'chromedriverDisableBuildCheck' capability to 'false'`);\n        return executable;\n      }\n\n      const chromeVersion = await this.getChromeVersion();\n      if (!chromeVersion) {\n        // unable to get the chrome version\n        if (_.isEmpty(cds)) {\n          log.errorAndThrow(`There must be at least one Chromedriver executable available for use if ` +\n            `the current Chrome version cannot be determined`);\n        }\n        const {version, executable} = cds[0];\n        log.warn(`Unable to discover Chrome version. Using Chromedriver ${version} at '${executable}'`);\n        return executable;\n      }\n      log.debug(`Found Chrome bundle '${this.bundleId}' version '${chromeVersion}'`);\n\n      const matchingDrivers = cds.filter(({minChromeVersion}) => {\n        const minChromeVersionS = minChromeVersion && semver.coerce(minChromeVersion);\n        if (!minChromeVersionS) {\n          return false;\n        }\n\n        return chromeVersion.major > NEW_CD_VERSION_FORMAT_MAJOR_VERSION\n          ? minChromeVersionS.major === chromeVersion.major\n          : semver.gte(chromeVersion, minChromeVersionS);\n      });\n      if (_.isEmpty(matchingDrivers)) {\n        if (this.storageClient && !didStorageSync) {\n          try {\n            if (await syncChromedrivers(chromeVersion)) {\n              continue;\n            }\n          } catch (e) {\n            log.warn(`Cannot synchronize local chromedrivers with the remote storage at ${CD_CDN}: ` +\n              e.message);\n            log.debug(e.stack);\n          }\n        }\n        const autodownloadSuggestion =\n          'You could also try to enable automated chromedrivers download server feature';\n        throw new Error(`No Chromedriver found that can automate Chrome '${chromeVersion}'. ` +\n          (!this.storageClient ? `${autodownloadSuggestion}. ` : '') +\n          `See ${CHROMEDRIVER_TUTORIAL} for more details`);\n      }\n\n      const binPath = matchingDrivers[0].executable;\n      log.debug(`Found ${util.pluralize('executable', matchingDrivers.length, true)} ` +\n        `capable of automating Chrome '${chromeVersion}'.\\nChoosing the most recent, '${binPath}'.`);\n      log.debug('If a specific version is required, specify it with the `chromedriverExecutable`' +\n        'desired capability.');\n      return binPath;\n    // eslint-disable-next-line no-constant-condition\n    } while (true);\n  }\n\n  async initChromedriverPath () {\n    if (this.executableVerified) return; //eslint-disable-line curly\n\n    // the executable might be set (if passed in)\n    // or we might want to use the basic one installed with this driver\n    // or we want to figure out the best one\n    if (!this.chromedriver) {\n      this.chromedriver = this.useSystemExecutable\n        ? await getChromedriverBinaryPath()\n        : await this.getCompatibleChromedriver();\n    }\n\n    if (!await fs.exists(this.chromedriver)) {\n      throw new Error(`Trying to use a chromedriver binary at the path ` +\n                      `${this.chromedriver}, but it doesn't exist!`);\n    }\n    this.executableVerified = true;\n    log.info(`Set chromedriver binary as: ${this.chromedriver}`);\n  }\n\n  syncProtocol (cdVersion = null) {\n    const coercedVersion = semver.coerce(cdVersion);\n    if (!coercedVersion || coercedVersion.major < MIN_CD_VERSION_WITH_W3C_SUPPORT) {\n      log.debug(`Chromedriver v. ${cdVersion} does not fully support ${PROTOCOLS.W3C} protocol. ` +\n        `Defaulting to ${PROTOCOLS.MJSONWP}`);\n      return;\n    }\n    const chromeOptions = getCapValue(this.capabilities, 'chromeOptions', {});\n    if (chromeOptions.w3c === false) {\n      log.info(`Chromedriver v. ${cdVersion} supports ${PROTOCOLS.W3C} protocol, ` +\n        `but ${PROTOCOLS.MJSONWP} one has been explicitly requested`);\n      return;\n    }\n    this.desiredProtocol = PROTOCOLS.W3C;\n    // given caps might not be properly prefixed\n    // so we try to fix them in order to properly init\n    // the new W3C session\n    this.capabilities = toW3cCapNames(this.capabilities);\n  }\n\n  async start (caps, emitStartingState = true) {\n    this.capabilities = _.cloneDeep(caps);\n\n    // set the logging preferences to ALL the console logs\n    this.capabilities.loggingPrefs = _.cloneDeep(getCapValue(caps, 'loggingPrefs', {}));\n    if (_.isEmpty(this.capabilities.loggingPrefs.browser)) {\n      this.capabilities.loggingPrefs.browser = 'ALL';\n    }\n\n    if (emitStartingState) {\n      this.changeState(Chromedriver.STATE_STARTING);\n    }\n\n    const args = ['--url-base=wd/hub', `--port=${this.proxyPort}`];\n    if (this.adb && this.adb.adbPort) {\n      args.push(`--adb-port=${this.adb.adbPort}`);\n    }\n    if (_.isArray(this.cmdArgs)) {\n      args.push(...this.cmdArgs);\n    }\n    if (this.logPath) {\n      args.push(`--log-path=${this.logPath}`);\n    }\n    if (this.disableBuildCheck) {\n      args.push('--disable-build-check');\n    }\n    args.push('--verbose');\n    // what are the process stdout/stderr conditions wherein we know that\n    // the process has started to our satisfaction?\n    const startDetector = (stdout) => stdout.startsWith('Starting ');\n\n    let processIsAlive = false;\n    let webviewVersion;\n    try {\n      await this.initChromedriverPath();\n      await this.killAll();\n\n      // set up our subprocess object\n      this.proc = new SubProcess(this.chromedriver, args);\n      processIsAlive = true;\n\n      // handle log output\n      this.proc.on('output', (stdout, stderr) => {\n        // if the cd output is not printed, find the chrome version and print\n        // will get a response like\n        //   DevTools response: {\n        //      \"Android-Package\": \"io.appium.sampleapp\",\n        //      \"Browser\": \"Chrome/55.0.2883.91\",\n        //      \"Protocol-Version\": \"1.2\",\n        //      \"User-Agent\": \"...\",\n        //      \"WebKit-Version\": \"537.36\"\n        //   }\n        const out = stdout + stderr;\n        let match = /\"Browser\": \"(.*)\"/.exec(out);\n        if (match) {\n          webviewVersion = match[1];\n          log.debug(`Webview version: '${webviewVersion}'`);\n        }\n\n        // also print chromedriver version to logs\n        // will output something like\n        //  Starting ChromeDriver 2.33.506106 (8a06c39c4582fbfbab6966dbb1c38a9173bfb1a2) on port 9515\n        match = /Starting ChromeDriver ([.\\d]+)/.exec(out);\n        if (match) {\n          log.debug(`Chromedriver version: '${match[1]}'`);\n          this.syncProtocol(match[1]);\n        }\n\n        // give the output if it is requested\n        if (this.verbose) {\n          for (let line of (stdout || '').trim().split('\\n')) {\n            if (!line.trim().length) continue; // eslint-disable-line curly\n            log.debug(`[STDOUT] ${line}`);\n          }\n          for (let line of (stderr || '').trim().split('\\n')) {\n            if (!line.trim().length) continue; // eslint-disable-line curly\n            log.error(`[STDERR] ${line}`);\n          }\n        }\n      });\n\n      // handle out-of-bound exit by simply emitting a stopped state\n      this.proc.on('exit', (code, signal) => {\n        processIsAlive = false;\n        if (this.state !== Chromedriver.STATE_STOPPED &&\n            this.state !== Chromedriver.STATE_STOPPING &&\n            this.state !== Chromedriver.STATE_RESTARTING) {\n          let msg = `Chromedriver exited unexpectedly with code ${code}, ` +\n                    `signal ${signal}`;\n          log.error(msg);\n          this.changeState(Chromedriver.STATE_STOPPED);\n        }\n      });\n      log.info(`Spawning chromedriver with: ${this.chromedriver} ` +\n               `${args.join(' ')}`);\n      // start subproc and wait for startDetector\n      await this.proc.start(startDetector);\n      await this.waitForOnline();\n      await this.startSession();\n    } catch (e) {\n      log.debug(e);\n      this.emit(Chromedriver.EVENT_ERROR, e);\n      // just because we had an error doesn't mean the chromedriver process\n      // finished; we should clean up if necessary\n      if (processIsAlive) {\n        await this.proc.stop();\n      }\n\n      let message = '';\n      // often the user's Chrome version is not supported by the version of Chromedriver\n      if (e.message.includes('Chrome version must be')) {\n        message += 'Unable to automate Chrome version because it is not supported by this version of Chromedriver.\\n';\n        if (webviewVersion) {\n          message += `Chrome version on the device: ${webviewVersion}\\n`;\n        }\n        const versionsSupportedByDriver = /Chrome version must be (.+)/.exec(e.message)?.[1] || '';\n        if (versionsSupportedByDriver) {\n          message += `Chromedriver supports Chrome version(s): ${versionsSupportedByDriver}\\n`;\n        }\n        message += `Visit '${CHROMEDRIVER_TUTORIAL}' to troubleshoot the problem.\\n`;\n      }\n\n      message += e.message;\n      log.errorAndThrow(message);\n    }\n  }\n\n  sessionId () {\n    if (this.state !== Chromedriver.STATE_ONLINE) {\n      return null;\n    }\n\n    return this.jwproxy.sessionId;\n  }\n\n  async restart () {\n    log.info('Restarting chromedriver');\n    if (this.state !== Chromedriver.STATE_ONLINE) {\n      throw new Error(\"Can't restart when we're not online\");\n    }\n    this.changeState(Chromedriver.STATE_RESTARTING);\n    await this.stop(false);\n    await this.start(this.capabilities, false);\n  }\n\n  async waitForOnline () {\n    // we need to make sure that CD hasn't crashed\n    let chromedriverStopped = false;\n    await retryInterval(20, 200, async () => {\n      if (this.state === Chromedriver.STATE_STOPPED) {\n        // we are either stopped or stopping, so something went wrong\n        chromedriverStopped = true;\n        return;\n      }\n      await this.getStatus();\n    });\n    if (chromedriverStopped) {\n      throw new Error('ChromeDriver crashed during startup.');\n    }\n  }\n\n  async getStatus () {\n    return await this.jwproxy.command('/status', 'GET');\n  }\n\n  async startSession () {\n    const sessionCaps = this.desiredProtocol === PROTOCOLS.W3C\n      ? {capabilities: {alwaysMatch: this.capabilities}}\n      : {desiredCapabilities: this.capabilities};\n    log.info(`Starting ${this.desiredProtocol} Chromedriver session with capabilities: ` +\n      JSON.stringify(sessionCaps, null, 2));\n    await this.jwproxy.command('/session', 'POST', sessionCaps);\n    this.changeState(Chromedriver.STATE_ONLINE);\n  }\n\n  async stop (emitStates = true) {\n    if (emitStates) {\n      this.changeState(Chromedriver.STATE_STOPPING);\n    }\n    try {\n      await this.jwproxy.command('', 'DELETE');\n      await this.proc.stop('SIGTERM', 20000);\n      if (emitStates) {\n        this.changeState(Chromedriver.STATE_STOPPED);\n      }\n    } catch (e) {\n      log.error(e);\n    }\n  }\n\n  changeState (state) {\n    this.state = state;\n    log.debug(`Changed state to '${state}'`);\n    this.emit(Chromedriver.EVENT_CHANGED, {state});\n  }\n\n  async sendCommand (url, method, body) {\n    return await this.jwproxy.command(url, method, body);\n  }\n\n  async proxyReq (req, res) {\n    return await this.jwproxy.proxyReqRes(req, res);\n  }\n\n  async killAll () {\n    let cmd = system.isWindows()\n      ? `wmic process where \"commandline like '%chromedriver.exe%--port=${this.proxyPort}%'\" delete`\n      : `pkill -15 -f \"${this.chromedriver}.*--port=${this.proxyPort}\"`;\n    log.debug(`Killing any old chromedrivers, running: ${cmd}`);\n    try {\n      await (B.promisify(cp.exec))(cmd);\n      log.debug('Successfully cleaned up old chromedrivers');\n    } catch (err) {\n      log.warn('No old chromedrivers seem to exist');\n    }\n\n    if (this.adb) {\n      const udidIndex = this.adb.executable.defaultArgs.findIndex((item) => item === '-s');\n      const udid = udidIndex > -1 ? this.adb.executable.defaultArgs[udidIndex + 1] : null;\n\n      if (udid) {\n        log.debug(`Cleaning this device's adb forwarded port socket connections: ${udid}`);\n      } else {\n        log.debug(`Cleaning any old adb forwarded port socket connections`);\n      }\n\n      try {\n        for (let conn of await this.adb.getForwardList()) {\n          // chromedriver will ask ADB to forward a port like \"deviceId tcp:port localabstract:webview_devtools_remote_port\"\n          if (!(conn.includes('webview_devtools') && (!udid || conn.includes(udid)))) {\n            continue;\n          }\n\n          let params = conn.split(/\\s+/);\n          if (params.length > 1) {\n            await this.adb.removePortForward(params[1].replace(/[\\D]*/, ''));\n          }\n        }\n      } catch (err) {\n        log.warn(`Unable to clean forwarded ports. Error: '${err.message}'. Continuing.`);\n      }\n    }\n  }\n\n  async hasWorkingWebview () {\n    // sometimes chromedriver stops automating webviews. this method runs a\n    // simple command to determine our state, and responds accordingly\n    try {\n      await this.jwproxy.command('/url', 'GET');\n      return true;\n    } catch (e) {\n      return false;\n    }\n  }\n}\n\nChromedriver.EVENT_ERROR = 'chromedriver_error';\nChromedriver.EVENT_CHANGED = 'stateChanged';\nChromedriver.STATE_STOPPED = 'stopped';\nChromedriver.STATE_STARTING = 'starting';\nChromedriver.STATE_ONLINE = 'online';\nChromedriver.STATE_STOPPING = 'stopping';\nChromedriver.STATE_RESTARTING = 'restarting';\n\nexport { Chromedriver };\nexport default Chromedriver;\n"],"file":"lib/chromedriver.js","sourceRoot":"../.."}
732
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/chromedriver.js"],"names":["log","logger","getLogger","NEW_CD_VERSION_FORMAT_MAJOR_VERSION","DEFAULT_HOST","MIN_CD_VERSION_WITH_W3C_SUPPORT","DEFAULT_PORT","CHROME_BUNDLE_ID","WEBVIEW_SHELL_BUNDLE_ID","WEBVIEW_BUNDLE_IDS","CHROMEDRIVER_TUTORIAL","VERSION_PATTERN","CD_VERSION_TIMEOUT","Chromedriver","events","EventEmitter","constructor","args","host","port","useSystemExecutable","executable","executableDir","bundleId","mappingPath","cmdArgs","adb","verbose","logPath","disableBuildCheck","details","isAutodownloadEnabled","proxyHost","proxyPort","proc","chromedriver","executableVerified","state","STATE_STOPPED","jwproxy","JWProxy","server","storageClient","ChromedriverStorageClient","chromedriverDir","capabilities","desiredProtocol","PROTOCOLS","MJSONWP","getDriversMapping","mapping","_","cloneDeep","CHROMEDRIVER_CHROME_MAPPING","debug","fs","exists","warn","info","JSON","parse","readFile","err","message","cdVersion","chromeVersion","toPairs","coercedVersion","semver","coerce","version","getChromedrivers","executables","glob","util","pluralize","length","cds","mapChromedriver","logError","stdout","stderr","errMsg","path","basename","timeout","includes","match","exec","minChromeVersion","major","minor","filter","cd","sort","a","b","isEmpty","getChromeVersion","Browser","versionMatch","apiLevel","getApiLevel","updateDriversMapping","newMapping","shouldUpdateStaticMapping","writeFile","stringify","e","Object","assign","getCompatibleChromedriver","values","didStorageSync","syncChromedrivers","retrievedMapping","retrieveMapping","driverKeys","syncDrivers","minBrowserVersion","synchronizedDriversMapping","reduce","acc","x","missingVersions","coercedVer","size","errorAndThrow","matchingDrivers","minChromeVersionS","gte","CD_CDN","stack","autodownloadSuggestion","Error","binPath","initChromedriverPath","syncProtocol","W3C","chromeOptions","w3c","start","caps","emitStartingState","loggingPrefs","browser","changeState","STATE_STARTING","adbPort","push","isArray","startDetector","startsWith","processIsAlive","webviewVersion","killAll","SubProcess","on","out","line","trim","split","error","code","signal","STATE_STOPPING","STATE_RESTARTING","msg","join","waitForOnline","startSession","emit","EVENT_ERROR","stop","versionsSupportedByDriver","sessionId","STATE_ONLINE","restart","chromedriverStopped","getStatus","command","sessionCaps","alwaysMatch","desiredCapabilities","emitStates","runSafeStep","f","EVENT_CHANGED","sendCommand","url","method","body","proxyReq","req","res","proxyReqRes","cmd","system","isWindows","B","promisify","cp","udidIndex","defaultArgs","findIndex","item","udid","conn","getForwardList","params","removePortForward","replace","hasWorkingWebview"],"mappings":"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","sourcesContent":["// transpile:main\n\nimport events from 'events';\nimport { JWProxy, PROTOCOLS } from '@appium/base-driver';\nimport cp from 'child_process';\nimport { system, fs, logger, util } from '@appium/support';\nimport { retryInterval, asyncmap } from 'asyncbox';\nimport { SubProcess, exec } from 'teen_process';\nimport B from 'bluebird';\nimport {\n  getChromeVersion, getChromedriverDir, CHROMEDRIVER_CHROME_MAPPING,\n  getChromedriverBinaryPath, CD_CDN,\n} from './utils';\nimport semver from 'semver';\nimport _ from 'lodash';\nimport path from 'path';\nimport compareVersions from 'compare-versions';\nimport ChromedriverStorageClient from './storage-client';\nimport { toW3cCapNames, getCapValue } from './protocol-helpers';\n\n\nconst log = logger.getLogger('Chromedriver');\n\nconst NEW_CD_VERSION_FORMAT_MAJOR_VERSION = 73;\nconst DEFAULT_HOST = '127.0.0.1';\nconst MIN_CD_VERSION_WITH_W3C_SUPPORT = 75;\nconst DEFAULT_PORT = 9515;\nconst CHROME_BUNDLE_ID = 'com.android.chrome';\nconst WEBVIEW_SHELL_BUNDLE_ID = 'org.chromium.webview_shell';\nconst WEBVIEW_BUNDLE_IDS = [\n  'com.google.android.webview',\n  'com.android.webview',\n];\nconst CHROMEDRIVER_TUTORIAL = 'https://github.com/appium/appium/blob/master/docs/en/writing-running-appium/web/chromedriver.md';\nconst VERSION_PATTERN = /([\\d.]+)/;\n\nconst CD_VERSION_TIMEOUT = 5000;\n\nclass Chromedriver extends events.EventEmitter {\n  constructor (args = {}) {\n    super();\n\n    const {\n      host = DEFAULT_HOST,\n      port = DEFAULT_PORT,\n      useSystemExecutable = false,\n      executable,\n      executableDir = getChromedriverDir(),\n      bundleId,\n      mappingPath,\n      cmdArgs,\n      adb,\n      verbose,\n      logPath,\n      disableBuildCheck,\n      details,\n      isAutodownloadEnabled = false,\n    } = args;\n\n    this.proxyHost = host;\n    this.proxyPort = port;\n    this.adb = adb;\n    this.cmdArgs = cmdArgs;\n    this.proc = null;\n    this.useSystemExecutable = useSystemExecutable;\n    this.chromedriver = executable;\n    this.executableDir = executableDir;\n    this.mappingPath = mappingPath;\n    this.bundleId = bundleId;\n    this.executableVerified = false;\n    this.state = Chromedriver.STATE_STOPPED;\n    this.jwproxy = new JWProxy({\n      server: this.proxyHost,\n      port: this.proxyPort\n    });\n    this.verbose = verbose;\n    this.logPath = logPath;\n    this.disableBuildCheck = !!disableBuildCheck;\n    this.storageClient = isAutodownloadEnabled\n      ? new ChromedriverStorageClient({ chromedriverDir: this.executableDir })\n      : null;\n    this.details = details;\n    this.capabilities = {};\n    this.desiredProtocol = PROTOCOLS.MJSONWP;\n  }\n\n  async getDriversMapping () {\n    let mapping = _.cloneDeep(CHROMEDRIVER_CHROME_MAPPING);\n    if (this.mappingPath) {\n      log.debug(`Attempting to use Chromedriver->Chrome mapping from '${this.mappingPath}'`);\n      if (!await fs.exists(this.mappingPath)) {\n        log.warn(`No file found at '${this.mappingPath}'`);\n        log.info('Defaulting to the static Chromedriver->Chrome mapping');\n      } else {\n        try {\n          mapping = JSON.parse(await fs.readFile(this.mappingPath, 'utf8'));\n        } catch (err) {\n          log.warn(`Error parsing mapping from '${this.mappingPath}': ${err.message}`);\n          log.info('Defaulting to the static Chromedriver->Chrome mapping');\n        }\n      }\n    } else {\n      log.debug('Using the static Chromedriver->Chrome mapping');\n    }\n\n    // make sure that the values for minimum chrome version are semver compliant\n    for (const [cdVersion, chromeVersion] of _.toPairs(mapping)) {\n      const coercedVersion = semver.coerce(chromeVersion);\n      if (coercedVersion) {\n        mapping[cdVersion] = coercedVersion.version;\n      } else {\n        log.info(`'${chromeVersion}' is not a valid version number. Skipping it`);\n      }\n    }\n    return mapping;\n  }\n\n  async getChromedrivers (mapping) {\n    // go through the versions available\n    const executables = await fs.glob(`${this.executableDir}/*`);\n    log.debug(`Found ${util.pluralize('executable', executables.length, true)} ` +\n      `in '${this.executableDir}'`);\n    const cds = (await asyncmap(executables, async function mapChromedriver (executable) {\n      const logError = ({message, stdout = null, stderr = null}) => {\n        let errMsg = `Cannot retrieve version number from '${path.basename(executable)}' Chromedriver binary. ` +\n          `Make sure it returns a valid version string in response to '--version' command line argument. ${message}`;\n        if (stdout) {\n          errMsg += `\\nStdout: ${stdout}`;\n        }\n        if (stderr) {\n          errMsg += `\\nStderr: ${stderr}`;\n        }\n        log.warn(errMsg);\n        return null;\n      };\n\n      let stdout;\n      let stderr;\n      try {\n        ({stdout, stderr} = await exec(executable, ['--version'], {\n          timeout: CD_VERSION_TIMEOUT,\n        }));\n      } catch (err) {\n        if (!(err.message || '').includes('timed out') && !(err.stdout || '').includes('Starting ChromeDriver')) {\n          return logError(err);\n        }\n\n        // if this has timed out, it has actually started Chromedriver,\n        // in which case there will also be the version string in the output\n        stdout = err.stdout;\n      }\n\n      const match = /ChromeDriver\\s+\\(?v?([\\d.]+)\\)?/i.exec(stdout); // https://regex101.com/r/zpj5wA/1\n      if (!match) {\n        return logError({message: 'Cannot parse the version string', stdout, stderr});\n      }\n      let version = match[1];\n      let minChromeVersion = mapping[version];\n      const coercedVersion = semver.coerce(version);\n      if (coercedVersion) {\n        // before 2019-03-06 versions were of the form major.minor\n        if (coercedVersion.major < NEW_CD_VERSION_FORMAT_MAJOR_VERSION) {\n          version = `${coercedVersion.major}.${coercedVersion.minor}`;\n          minChromeVersion = mapping[version];\n        }\n        if (!minChromeVersion && coercedVersion.major >= NEW_CD_VERSION_FORMAT_MAJOR_VERSION) {\n          // Assume the major Chrome version is the same as the corresponding driver major version\n          minChromeVersion = `${coercedVersion.major}`;\n        }\n      }\n      return {\n        executable,\n        version,\n        minChromeVersion,\n      };\n    }))\n      .filter((cd) => !!cd)\n      .sort((a, b) => compareVersions(b.version, a.version));\n    if (_.isEmpty(cds)) {\n      log.info(`No Chromedrivers were found in '${this.executableDir}'`);\n      return cds;\n    }\n    log.debug(`The following Chromedriver executables were found:`);\n    for (const cd of cds) {\n      log.debug(`    '${cd.executable}' (version '${cd.version}', minimum Chrome version '${cd.minChromeVersion ? cd.minChromeVersion : 'Unknown'}')`);\n    }\n    return cds;\n  }\n\n  async getChromeVersion () {\n    // Try to retrieve the version from `details` property if it is set\n    // The `info` item must contain the output of /json/version CDP command\n    // where `Browser` field looks like `Chrome/72.0.3601.0``\n    if (this.details?.info) {\n      log.debug(`Browser version in the supplied details: ${this.details?.info?.Browser}`);\n    }\n    const versionMatch = VERSION_PATTERN.exec(this.details?.info?.Browser);\n    if (versionMatch) {\n      const coercedVersion = semver.coerce(versionMatch[1]);\n      if (coercedVersion) {\n        return coercedVersion;\n      }\n    }\n\n    let chromeVersion;\n\n    // in case of WebView Browser Tester, simply try to find the underlying webview\n    if (this.bundleId === WEBVIEW_SHELL_BUNDLE_ID) {\n      for (const bundleId of WEBVIEW_BUNDLE_IDS) {\n        chromeVersion = await getChromeVersion(this.adb, bundleId);\n        if (chromeVersion) {\n          this.bundleId = bundleId;\n          return semver.coerce(chromeVersion);\n        }\n      }\n      return null;\n    }\n\n    // on Android 7-9 webviews are backed by the main Chrome, not the system webview\n    if (this.adb) {\n      const apiLevel = await this.adb.getApiLevel();\n      if (apiLevel >= 24 && apiLevel <= 28 &&\n          [WEBVIEW_SHELL_BUNDLE_ID, ...WEBVIEW_BUNDLE_IDS].includes(this.bundleId)) {\n        this.bundleId = CHROME_BUNDLE_ID;\n      }\n    }\n\n    // try out webviews when no bundle id is sent in\n    if (!this.bundleId) {\n      // default to the generic Chrome bundle\n      this.bundleId = CHROME_BUNDLE_ID;\n\n      // we have a webview of some sort, so try to find the bundle version\n      for (const bundleId of WEBVIEW_BUNDLE_IDS) {\n        chromeVersion = await getChromeVersion(this.adb, bundleId);\n        if (chromeVersion) {\n          this.bundleId = bundleId;\n          break;\n        }\n      }\n    }\n\n    // if we do not have a chrome version, it must not be a webview\n    if (!chromeVersion) {\n      chromeVersion = await getChromeVersion(this.adb, this.bundleId);\n    }\n\n    // make sure it is semver, so later checks won't fail\n    return chromeVersion ? semver.coerce(chromeVersion) : null;\n  }\n\n  async updateDriversMapping (newMapping) {\n    let shouldUpdateStaticMapping = true;\n    if (await fs.exists(this.mappingPath)) {\n      try {\n        await fs.writeFile(this.mappingPath, JSON.stringify(newMapping, null, 2), 'utf8');\n        shouldUpdateStaticMapping = false;\n      } catch (e) {\n        log.warn(`Cannot store the updated chromedrivers mapping into '${this.mappingPath}'. ` +\n          `This may reduce the performance of further executions. Original error: ${e.message}`);\n      }\n    }\n    if (shouldUpdateStaticMapping) {\n      Object.assign(CHROMEDRIVER_CHROME_MAPPING, newMapping);\n    }\n  }\n\n  async getCompatibleChromedriver () {\n    if (!this.adb) {\n      return await getChromedriverBinaryPath();\n    }\n\n    const mapping = await this.getDriversMapping();\n    if (!_.isEmpty(mapping)) {\n      log.debug(`The most recent known Chrome version: ${_.values(mapping)[0]}`);\n    }\n\n    let didStorageSync = false;\n    const syncChromedrivers = async (chromeVersion) => {\n      didStorageSync = true;\n      const retrievedMapping = await this.storageClient.retrieveMapping();\n      log.debug('Got chromedrivers mapping from the storage: ' +\n        JSON.stringify(retrievedMapping, null, 2));\n      const driverKeys = await this.storageClient.syncDrivers({\n        minBrowserVersion: chromeVersion.major,\n      });\n      if (_.isEmpty(driverKeys)) {\n        return false;\n      }\n      const synchronizedDriversMapping = driverKeys.reduce((acc, x) => {\n        const {version, minBrowserVersion} = retrievedMapping[x];\n        acc[version] = minBrowserVersion;\n        return acc;\n      }, {});\n      Object.assign(mapping, synchronizedDriversMapping);\n      await this.updateDriversMapping(mapping);\n      return true;\n    };\n\n    do {\n      const cds = await this.getChromedrivers(mapping);\n\n      const missingVersions = {};\n      for (const {version, minChromeVersion} of cds) {\n        if (!minChromeVersion || mapping[version]) {\n          continue;\n        }\n        const coercedVer = semver.coerce(version);\n        if (!coercedVer || coercedVer.major < NEW_CD_VERSION_FORMAT_MAJOR_VERSION) {\n          continue;\n        }\n\n        missingVersions[version] = minChromeVersion;\n      }\n      if (!_.isEmpty(missingVersions)) {\n        log.info(`Found ${util.pluralize('Chromedriver', _.size(missingVersions), true)}, ` +\n          `which ${_.size(missingVersions) === 1 ? 'is' : 'are'} missing in the list of known versions: ` +\n          JSON.stringify(missingVersions));\n        await this.updateDriversMapping(Object.assign(mapping, missingVersions));\n      }\n\n      if (this.disableBuildCheck) {\n        if (_.isEmpty(cds)) {\n          log.errorAndThrow(`There must be at least one Chromedriver executable available for use if ` +\n            `'chromedriverDisableBuildCheck' capability is set to 'true'`);\n        }\n        const {version, executable} = cds[0];\n        log.warn(`Chrome build check disabled. Using most recent Chromedriver version (${version}, at '${executable}')`);\n        log.warn(`If this is wrong, set 'chromedriverDisableBuildCheck' capability to 'false'`);\n        return executable;\n      }\n\n      const chromeVersion = await this.getChromeVersion();\n      if (!chromeVersion) {\n        // unable to get the chrome version\n        if (_.isEmpty(cds)) {\n          log.errorAndThrow(`There must be at least one Chromedriver executable available for use if ` +\n            `the current Chrome version cannot be determined`);\n        }\n        const {version, executable} = cds[0];\n        log.warn(`Unable to discover Chrome version. Using Chromedriver ${version} at '${executable}'`);\n        return executable;\n      }\n      log.debug(`Found Chrome bundle '${this.bundleId}' version '${chromeVersion}'`);\n\n      const matchingDrivers = cds.filter(({minChromeVersion}) => {\n        const minChromeVersionS = minChromeVersion && semver.coerce(minChromeVersion);\n        if (!minChromeVersionS) {\n          return false;\n        }\n\n        return chromeVersion.major > NEW_CD_VERSION_FORMAT_MAJOR_VERSION\n          ? minChromeVersionS.major === chromeVersion.major\n          : semver.gte(chromeVersion, minChromeVersionS);\n      });\n      if (_.isEmpty(matchingDrivers)) {\n        if (this.storageClient && !didStorageSync) {\n          try {\n            if (await syncChromedrivers(chromeVersion)) {\n              continue;\n            }\n          } catch (e) {\n            log.warn(`Cannot synchronize local chromedrivers with the remote storage at ${CD_CDN}: ` +\n              e.message);\n            log.debug(e.stack);\n          }\n        }\n        const autodownloadSuggestion =\n          'You could also try to enable automated chromedrivers download server feature';\n        throw new Error(`No Chromedriver found that can automate Chrome '${chromeVersion}'. ` +\n          (!this.storageClient ? `${autodownloadSuggestion}. ` : '') +\n          `See ${CHROMEDRIVER_TUTORIAL} for more details`);\n      }\n\n      const binPath = matchingDrivers[0].executable;\n      log.debug(`Found ${util.pluralize('executable', matchingDrivers.length, true)} ` +\n        `capable of automating Chrome '${chromeVersion}'.\\nChoosing the most recent, '${binPath}'.`);\n      log.debug('If a specific version is required, specify it with the `chromedriverExecutable`' +\n        'desired capability.');\n      return binPath;\n    // eslint-disable-next-line no-constant-condition\n    } while (true);\n  }\n\n  async initChromedriverPath () {\n    if (this.executableVerified) return; //eslint-disable-line curly\n\n    // the executable might be set (if passed in)\n    // or we might want to use the basic one installed with this driver\n    // or we want to figure out the best one\n    if (!this.chromedriver) {\n      this.chromedriver = this.useSystemExecutable\n        ? await getChromedriverBinaryPath()\n        : await this.getCompatibleChromedriver();\n    }\n\n    if (!await fs.exists(this.chromedriver)) {\n      throw new Error(`Trying to use a chromedriver binary at the path ` +\n                      `${this.chromedriver}, but it doesn't exist!`);\n    }\n    this.executableVerified = true;\n    log.info(`Set chromedriver binary as: ${this.chromedriver}`);\n  }\n\n  syncProtocol (cdVersion = null) {\n    const coercedVersion = semver.coerce(cdVersion);\n    if (!coercedVersion || coercedVersion.major < MIN_CD_VERSION_WITH_W3C_SUPPORT) {\n      log.debug(`Chromedriver v. ${cdVersion} does not fully support ${PROTOCOLS.W3C} protocol. ` +\n        `Defaulting to ${PROTOCOLS.MJSONWP}`);\n      return;\n    }\n    const chromeOptions = getCapValue(this.capabilities, 'chromeOptions', {});\n    if (chromeOptions.w3c === false) {\n      log.info(`Chromedriver v. ${cdVersion} supports ${PROTOCOLS.W3C} protocol, ` +\n        `but ${PROTOCOLS.MJSONWP} one has been explicitly requested`);\n      return;\n    }\n    this.desiredProtocol = PROTOCOLS.W3C;\n    // given caps might not be properly prefixed\n    // so we try to fix them in order to properly init\n    // the new W3C session\n    this.capabilities = toW3cCapNames(this.capabilities);\n  }\n\n  async start (caps, emitStartingState = true) {\n    this.capabilities = _.cloneDeep(caps);\n\n    // set the logging preferences to ALL the console logs\n    this.capabilities.loggingPrefs = _.cloneDeep(getCapValue(caps, 'loggingPrefs', {}));\n    if (_.isEmpty(this.capabilities.loggingPrefs.browser)) {\n      this.capabilities.loggingPrefs.browser = 'ALL';\n    }\n\n    if (emitStartingState) {\n      this.changeState(Chromedriver.STATE_STARTING);\n    }\n\n    const args = [`--port=${this.proxyPort}`];\n    if (this.adb && this.adb.adbPort) {\n      args.push(`--adb-port=${this.adb.adbPort}`);\n    }\n    if (_.isArray(this.cmdArgs)) {\n      args.push(...this.cmdArgs);\n    }\n    if (this.logPath) {\n      args.push(`--log-path=${this.logPath}`);\n    }\n    if (this.disableBuildCheck) {\n      args.push('--disable-build-check');\n    }\n    args.push('--verbose');\n    // what are the process stdout/stderr conditions wherein we know that\n    // the process has started to our satisfaction?\n    const startDetector = (stdout) => stdout.startsWith('Starting ');\n\n    let processIsAlive = false;\n    let webviewVersion;\n    try {\n      await this.initChromedriverPath();\n      await this.killAll();\n\n      // set up our subprocess object\n      this.proc = new SubProcess(this.chromedriver, args);\n      processIsAlive = true;\n\n      // handle log output\n      this.proc.on('output', (stdout, stderr) => {\n        // if the cd output is not printed, find the chrome version and print\n        // will get a response like\n        //   DevTools response: {\n        //      \"Android-Package\": \"io.appium.sampleapp\",\n        //      \"Browser\": \"Chrome/55.0.2883.91\",\n        //      \"Protocol-Version\": \"1.2\",\n        //      \"User-Agent\": \"...\",\n        //      \"WebKit-Version\": \"537.36\"\n        //   }\n        const out = stdout + stderr;\n        let match = /\"Browser\": \"(.*)\"/.exec(out);\n        if (match) {\n          webviewVersion = match[1];\n          log.debug(`Webview version: '${webviewVersion}'`);\n        }\n\n        // also print chromedriver version to logs\n        // will output something like\n        //  Starting ChromeDriver 2.33.506106 (8a06c39c4582fbfbab6966dbb1c38a9173bfb1a2) on port 9515\n        match = /Starting ChromeDriver ([.\\d]+)/.exec(out);\n        if (match) {\n          log.debug(`Chromedriver version: '${match[1]}'`);\n          this.syncProtocol(match[1]);\n        }\n\n        // give the output if it is requested\n        if (this.verbose) {\n          for (let line of (stdout || '').trim().split('\\n')) {\n            if (!line.trim().length) continue; // eslint-disable-line curly\n            log.debug(`[STDOUT] ${line}`);\n          }\n          for (let line of (stderr || '').trim().split('\\n')) {\n            if (!line.trim().length) continue; // eslint-disable-line curly\n            log.error(`[STDERR] ${line}`);\n          }\n        }\n      });\n\n      // handle out-of-bound exit by simply emitting a stopped state\n      this.proc.on('exit', (code, signal) => {\n        processIsAlive = false;\n        if (this.state !== Chromedriver.STATE_STOPPED &&\n            this.state !== Chromedriver.STATE_STOPPING &&\n            this.state !== Chromedriver.STATE_RESTARTING) {\n          let msg = `Chromedriver exited unexpectedly with code ${code}, ` +\n                    `signal ${signal}`;\n          log.error(msg);\n          this.changeState(Chromedriver.STATE_STOPPED);\n        }\n      });\n      log.info(`Spawning chromedriver with: ${this.chromedriver} ` +\n               `${args.join(' ')}`);\n      // start subproc and wait for startDetector\n      await this.proc.start(startDetector);\n      await this.waitForOnline();\n      await this.startSession();\n    } catch (e) {\n      log.debug(e);\n      this.emit(Chromedriver.EVENT_ERROR, e);\n      // just because we had an error doesn't mean the chromedriver process\n      // finished; we should clean up if necessary\n      if (processIsAlive) {\n        await this.proc.stop();\n      }\n\n      let message = '';\n      // often the user's Chrome version is not supported by the version of Chromedriver\n      if (e.message.includes('Chrome version must be')) {\n        message += 'Unable to automate Chrome version because it is not supported by this version of Chromedriver.\\n';\n        if (webviewVersion) {\n          message += `Chrome version on the device: ${webviewVersion}\\n`;\n        }\n        const versionsSupportedByDriver = /Chrome version must be (.+)/.exec(e.message)?.[1] || '';\n        if (versionsSupportedByDriver) {\n          message += `Chromedriver supports Chrome version(s): ${versionsSupportedByDriver}\\n`;\n        }\n        message += `Visit '${CHROMEDRIVER_TUTORIAL}' to troubleshoot the problem.\\n`;\n      }\n\n      message += e.message;\n      log.errorAndThrow(message);\n    }\n  }\n\n  sessionId () {\n    if (this.state !== Chromedriver.STATE_ONLINE) {\n      return null;\n    }\n\n    return this.jwproxy.sessionId;\n  }\n\n  async restart () {\n    log.info('Restarting chromedriver');\n    if (this.state !== Chromedriver.STATE_ONLINE) {\n      throw new Error(\"Can't restart when we're not online\");\n    }\n    this.changeState(Chromedriver.STATE_RESTARTING);\n    await this.stop(false);\n    await this.start(this.capabilities, false);\n  }\n\n  async waitForOnline () {\n    // we need to make sure that CD hasn't crashed\n    let chromedriverStopped = false;\n    await retryInterval(20, 200, async () => {\n      if (this.state === Chromedriver.STATE_STOPPED) {\n        // we are either stopped or stopping, so something went wrong\n        chromedriverStopped = true;\n        return;\n      }\n      await this.getStatus();\n    });\n    if (chromedriverStopped) {\n      throw new Error('ChromeDriver crashed during startup.');\n    }\n  }\n\n  async getStatus () {\n    return await this.jwproxy.command('/status', 'GET');\n  }\n\n  async startSession () {\n    const sessionCaps = this.desiredProtocol === PROTOCOLS.W3C\n      ? {capabilities: {alwaysMatch: this.capabilities}}\n      : {desiredCapabilities: this.capabilities};\n    log.info(`Starting ${this.desiredProtocol} Chromedriver session with capabilities: ` +\n      JSON.stringify(sessionCaps, null, 2));\n    await this.jwproxy.command('/session', 'POST', sessionCaps);\n    this.changeState(Chromedriver.STATE_ONLINE);\n  }\n\n  async stop (emitStates = true) {\n    if (emitStates) {\n      this.changeState(Chromedriver.STATE_STOPPING);\n    }\n    const runSafeStep = async (f) => {\n      try {\n        return await f();\n      } catch (e) {\n        log.warn(e.message);\n        log.debug(e.stack);\n      }\n    };\n    await runSafeStep(() => this.jwproxy.command('', 'DELETE'));\n    await runSafeStep(() => this.proc.stop('SIGTERM', 20000));\n    if (emitStates) {\n      this.changeState(Chromedriver.STATE_STOPPED);\n    }\n  }\n\n  changeState (state) {\n    this.state = state;\n    log.debug(`Changed state to '${state}'`);\n    this.emit(Chromedriver.EVENT_CHANGED, {state});\n  }\n\n  async sendCommand (url, method, body) {\n    return await this.jwproxy.command(url, method, body);\n  }\n\n  async proxyReq (req, res) {\n    return await this.jwproxy.proxyReqRes(req, res);\n  }\n\n  async killAll () {\n    let cmd = system.isWindows()\n      ? `wmic process where \"commandline like '%chromedriver.exe%--port=${this.proxyPort}%'\" delete`\n      : `pkill -15 -f \"${this.chromedriver}.*--port=${this.proxyPort}\"`;\n    log.debug(`Killing any old chromedrivers, running: ${cmd}`);\n    try {\n      await (B.promisify(cp.exec))(cmd);\n      log.debug('Successfully cleaned up old chromedrivers');\n    } catch (err) {\n      log.warn('No old chromedrivers seem to exist');\n    }\n\n    if (this.adb) {\n      const udidIndex = this.adb.executable.defaultArgs.findIndex((item) => item === '-s');\n      const udid = udidIndex > -1 ? this.adb.executable.defaultArgs[udidIndex + 1] : null;\n\n      if (udid) {\n        log.debug(`Cleaning this device's adb forwarded port socket connections: ${udid}`);\n      } else {\n        log.debug(`Cleaning any old adb forwarded port socket connections`);\n      }\n\n      try {\n        for (let conn of await this.adb.getForwardList()) {\n          // chromedriver will ask ADB to forward a port like \"deviceId tcp:port localabstract:webview_devtools_remote_port\"\n          if (!(conn.includes('webview_devtools') && (!udid || conn.includes(udid)))) {\n            continue;\n          }\n\n          let params = conn.split(/\\s+/);\n          if (params.length > 1) {\n            await this.adb.removePortForward(params[1].replace(/[\\D]*/, ''));\n          }\n        }\n      } catch (err) {\n        log.warn(`Unable to clean forwarded ports. Error: '${err.message}'. Continuing.`);\n      }\n    }\n  }\n\n  async hasWorkingWebview () {\n    // sometimes chromedriver stops automating webviews. this method runs a\n    // simple command to determine our state, and responds accordingly\n    try {\n      await this.jwproxy.command('/url', 'GET');\n      return true;\n    } catch (e) {\n      return false;\n    }\n  }\n}\n\nChromedriver.EVENT_ERROR = 'chromedriver_error';\nChromedriver.EVENT_CHANGED = 'stateChanged';\nChromedriver.STATE_STOPPED = 'stopped';\nChromedriver.STATE_STARTING = 'starting';\nChromedriver.STATE_ONLINE = 'online';\nChromedriver.STATE_STOPPING = 'stopping';\nChromedriver.STATE_RESTARTING = 'restarting';\n\nexport { Chromedriver };\nexport default Chromedriver;\n"],"file":"lib/chromedriver.js","sourceRoot":"../.."}
@@ -10,7 +10,7 @@ exports.install = install;
10
10
 
11
11
  require("source-map-support/register");
12
12
 
13
- var _appiumSupport = require("appium-support");
13
+ var _support = require("@appium/support");
14
14
 
15
15
  var _storageClient = _interopRequireDefault(require("./storage-client"));
16
16
 
@@ -31,8 +31,8 @@ async function formatCdVersion(ver) {
31
31
  async function prepareChromedriverDir(platformName) {
32
32
  const chromedriverDir = (0, _utils.getChromedriverDir)(platformName);
33
33
 
34
- if (!(await _appiumSupport.fs.exists(chromedriverDir))) {
35
- await (0, _appiumSupport.mkdirp)(chromedriverDir);
34
+ if (!(await _support.fs.exists(chromedriverDir))) {
35
+ await (0, _support.mkdirp)(chromedriverDir);
36
36
  }
37
37
 
38
38
  return chromedriverDir;
@@ -54,4 +54,4 @@ async function doInstall() {
54
54
  }require('source-map-support').install();
55
55
 
56
56
 
57
- //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImxpYi9pbnN0YWxsLmpzIl0sIm5hbWVzIjpbIkRPV05MT0FEX1RJTUVPVVRfTVMiLCJMQVRFU1RfVkVSU0lPTiIsImZvcm1hdENkVmVyc2lvbiIsInZlciIsIkNEX0NETiIsImFjY2VwdCIsInRpbWVvdXQiLCJ0cmltIiwicHJlcGFyZUNocm9tZWRyaXZlckRpciIsInBsYXRmb3JtTmFtZSIsImNocm9tZWRyaXZlckRpciIsImZzIiwiZXhpc3RzIiwiaW5zdGFsbCIsIm9zSW5mbyIsImNsaWVudCIsIkNocm9tZWRyaXZlclN0b3JhZ2VDbGllbnQiLCJuYW1lIiwic3luY0RyaXZlcnMiLCJ2ZXJzaW9ucyIsIkNEX1ZFUiIsImRvSW5zdGFsbCJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7O0FBQUE7O0FBQ0E7O0FBQ0E7O0FBS0EsTUFBTUEsbUJBQW1CLEdBQUcsS0FBSyxJQUFqQztBQUNBLE1BQU1DLGNBQWMsR0FBRyxRQUF2Qjs7QUFFQSxlQUFlQyxlQUFmLENBQWdDQyxHQUFoQyxFQUFxQztBQUNuQyxTQUFPQSxHQUFHLEtBQUtGLGNBQVIsR0FDSCxDQUFDLE1BQU0seUJBQWMsR0FBRUcsYUFBTyxpQkFBdkIsRUFBeUM7QUFDaEQsa0JBQWMsUUFEa0M7QUFFaERDLElBQUFBLE1BQU0sRUFBRTtBQUZ3QyxHQUF6QyxFQUdOO0FBQUVDLElBQUFBLE9BQU8sRUFBRU47QUFBWCxHQUhNLENBQVAsRUFHb0NPLElBSHBDLEVBREcsR0FLSEosR0FMSjtBQU1EOztBQUVELGVBQWVLLHNCQUFmLENBQXVDQyxZQUF2QyxFQUFxRDtBQUNuRCxRQUFNQyxlQUFlLEdBQUcsK0JBQW1CRCxZQUFuQixDQUF4Qjs7QUFDQSxNQUFJLEVBQUMsTUFBTUUsa0JBQUdDLE1BQUgsQ0FBVUYsZUFBVixDQUFQLENBQUosRUFBdUM7QUFDckMsVUFBTSwyQkFBT0EsZUFBUCxDQUFOO0FBQ0Q7O0FBQ0QsU0FBT0EsZUFBUDtBQUNEOztBQUVELGVBQWVHLE9BQWYsR0FBMEI7QUFDeEIsUUFBTUMsTUFBTSxHQUFHLE1BQU0sdUJBQXJCO0FBQ0EsUUFBTUMsTUFBTSxHQUFHLElBQUlDLHNCQUFKLENBQThCO0FBQzNDTixJQUFBQSxlQUFlLEVBQUUsTUFBTUYsc0JBQXNCLENBQUNNLE1BQU0sQ0FBQ0csSUFBUjtBQURGLEdBQTlCLENBQWY7QUFHQSxRQUFNRixNQUFNLENBQUNHLFdBQVAsQ0FBbUI7QUFDdkJKLElBQUFBLE1BRHVCO0FBRXZCSyxJQUFBQSxRQUFRLEVBQUUsQ0FBQyxNQUFNakIsZUFBZSxDQUFDa0IsYUFBRCxDQUF0QjtBQUZhLEdBQW5CLENBQU47QUFJRDs7QUFFRCxlQUFlQyxTQUFmLEdBQTRCO0FBQzFCLFFBQU1SLE9BQU8sRUFBYjtBQUNEIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgZnMsIG1rZGlycCB9IGZyb20gJ2FwcGl1bS1zdXBwb3J0JztcbmltcG9ydCBDaHJvbWVkcml2ZXJTdG9yYWdlQ2xpZW50IGZyb20gJy4vc3RvcmFnZS1jbGllbnQnO1xuaW1wb3J0IHtcbiAgQ0RfQ0ROLCBDRF9WRVIsIHJldHJpZXZlRGF0YSwgZ2V0T3NJbmZvLCBnZXRDaHJvbWVkcml2ZXJEaXIsXG59IGZyb20gJy4vdXRpbHMnO1xuXG5cbmNvbnN0IERPV05MT0FEX1RJTUVPVVRfTVMgPSAxNSAqIDEwMDA7XG5jb25zdCBMQVRFU1RfVkVSU0lPTiA9ICdMQVRFU1QnO1xuXG5hc3luYyBmdW5jdGlvbiBmb3JtYXRDZFZlcnNpb24gKHZlcikge1xuICByZXR1cm4gdmVyID09PSBMQVRFU1RfVkVSU0lPTlxuICAgID8gKGF3YWl0IHJldHJpZXZlRGF0YShgJHtDRF9DRE59L0xBVEVTVF9SRUxFQVNFYCwge1xuICAgICAgJ3VzZXItYWdlbnQnOiAnYXBwaXVtJyxcbiAgICAgIGFjY2VwdDogJyovKicsXG4gICAgfSwgeyB0aW1lb3V0OiBET1dOTE9BRF9USU1FT1VUX01TIH0pKS50cmltKClcbiAgICA6IHZlcjtcbn1cblxuYXN5bmMgZnVuY3Rpb24gcHJlcGFyZUNocm9tZWRyaXZlckRpciAocGxhdGZvcm1OYW1lKSB7XG4gIGNvbnN0IGNocm9tZWRyaXZlckRpciA9IGdldENocm9tZWRyaXZlckRpcihwbGF0Zm9ybU5hbWUpO1xuICBpZiAoIWF3YWl0IGZzLmV4aXN0cyhjaHJvbWVkcml2ZXJEaXIpKSB7XG4gICAgYXdhaXQgbWtkaXJwKGNocm9tZWRyaXZlckRpcik7XG4gIH1cbiAgcmV0dXJuIGNocm9tZWRyaXZlckRpcjtcbn1cblxuYXN5bmMgZnVuY3Rpb24gaW5zdGFsbCAoKSB7XG4gIGNvbnN0IG9zSW5mbyA9IGF3YWl0IGdldE9zSW5mbygpO1xuICBjb25zdCBjbGllbnQgPSBuZXcgQ2hyb21lZHJpdmVyU3RvcmFnZUNsaWVudCh7XG4gICAgY2hyb21lZHJpdmVyRGlyOiBhd2FpdCBwcmVwYXJlQ2hyb21lZHJpdmVyRGlyKG9zSW5mby5uYW1lKSxcbiAgfSk7XG4gIGF3YWl0IGNsaWVudC5zeW5jRHJpdmVycyh7XG4gICAgb3NJbmZvLFxuICAgIHZlcnNpb25zOiBbYXdhaXQgZm9ybWF0Q2RWZXJzaW9uKENEX1ZFUildLFxuICB9KTtcbn1cblxuYXN5bmMgZnVuY3Rpb24gZG9JbnN0YWxsICgpIHtcbiAgYXdhaXQgaW5zdGFsbCgpO1xufVxuXG5leHBvcnQgeyBpbnN0YWxsLCBkb0luc3RhbGwgfTtcbiJdLCJmaWxlIjoibGliL2luc3RhbGwuanMiLCJzb3VyY2VSb290IjoiLi4vLi4ifQ==
57
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImxpYi9pbnN0YWxsLmpzIl0sIm5hbWVzIjpbIkRPV05MT0FEX1RJTUVPVVRfTVMiLCJMQVRFU1RfVkVSU0lPTiIsImZvcm1hdENkVmVyc2lvbiIsInZlciIsIkNEX0NETiIsImFjY2VwdCIsInRpbWVvdXQiLCJ0cmltIiwicHJlcGFyZUNocm9tZWRyaXZlckRpciIsInBsYXRmb3JtTmFtZSIsImNocm9tZWRyaXZlckRpciIsImZzIiwiZXhpc3RzIiwiaW5zdGFsbCIsIm9zSW5mbyIsImNsaWVudCIsIkNocm9tZWRyaXZlclN0b3JhZ2VDbGllbnQiLCJuYW1lIiwic3luY0RyaXZlcnMiLCJ2ZXJzaW9ucyIsIkNEX1ZFUiIsImRvSW5zdGFsbCJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7O0FBQUE7O0FBQ0E7O0FBQ0E7O0FBS0EsTUFBTUEsbUJBQW1CLEdBQUcsS0FBSyxJQUFqQztBQUNBLE1BQU1DLGNBQWMsR0FBRyxRQUF2Qjs7QUFFQSxlQUFlQyxlQUFmLENBQWdDQyxHQUFoQyxFQUFxQztBQUNuQyxTQUFPQSxHQUFHLEtBQUtGLGNBQVIsR0FDSCxDQUFDLE1BQU0seUJBQWMsR0FBRUcsYUFBTyxpQkFBdkIsRUFBeUM7QUFDaEQsa0JBQWMsUUFEa0M7QUFFaERDLElBQUFBLE1BQU0sRUFBRTtBQUZ3QyxHQUF6QyxFQUdOO0FBQUVDLElBQUFBLE9BQU8sRUFBRU47QUFBWCxHQUhNLENBQVAsRUFHb0NPLElBSHBDLEVBREcsR0FLSEosR0FMSjtBQU1EOztBQUVELGVBQWVLLHNCQUFmLENBQXVDQyxZQUF2QyxFQUFxRDtBQUNuRCxRQUFNQyxlQUFlLEdBQUcsK0JBQW1CRCxZQUFuQixDQUF4Qjs7QUFDQSxNQUFJLEVBQUMsTUFBTUUsWUFBR0MsTUFBSCxDQUFVRixlQUFWLENBQVAsQ0FBSixFQUF1QztBQUNyQyxVQUFNLHFCQUFPQSxlQUFQLENBQU47QUFDRDs7QUFDRCxTQUFPQSxlQUFQO0FBQ0Q7O0FBRUQsZUFBZUcsT0FBZixHQUEwQjtBQUN4QixRQUFNQyxNQUFNLEdBQUcsTUFBTSx1QkFBckI7QUFDQSxRQUFNQyxNQUFNLEdBQUcsSUFBSUMsc0JBQUosQ0FBOEI7QUFDM0NOLElBQUFBLGVBQWUsRUFBRSxNQUFNRixzQkFBc0IsQ0FBQ00sTUFBTSxDQUFDRyxJQUFSO0FBREYsR0FBOUIsQ0FBZjtBQUdBLFFBQU1GLE1BQU0sQ0FBQ0csV0FBUCxDQUFtQjtBQUN2QkosSUFBQUEsTUFEdUI7QUFFdkJLLElBQUFBLFFBQVEsRUFBRSxDQUFDLE1BQU1qQixlQUFlLENBQUNrQixhQUFELENBQXRCO0FBRmEsR0FBbkIsQ0FBTjtBQUlEOztBQUVELGVBQWVDLFNBQWYsR0FBNEI7QUFDMUIsUUFBTVIsT0FBTyxFQUFiO0FBQ0QiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBmcywgbWtkaXJwIH0gZnJvbSAnQGFwcGl1bS9zdXBwb3J0JztcbmltcG9ydCBDaHJvbWVkcml2ZXJTdG9yYWdlQ2xpZW50IGZyb20gJy4vc3RvcmFnZS1jbGllbnQnO1xuaW1wb3J0IHtcbiAgQ0RfQ0ROLCBDRF9WRVIsIHJldHJpZXZlRGF0YSwgZ2V0T3NJbmZvLCBnZXRDaHJvbWVkcml2ZXJEaXIsXG59IGZyb20gJy4vdXRpbHMnO1xuXG5cbmNvbnN0IERPV05MT0FEX1RJTUVPVVRfTVMgPSAxNSAqIDEwMDA7XG5jb25zdCBMQVRFU1RfVkVSU0lPTiA9ICdMQVRFU1QnO1xuXG5hc3luYyBmdW5jdGlvbiBmb3JtYXRDZFZlcnNpb24gKHZlcikge1xuICByZXR1cm4gdmVyID09PSBMQVRFU1RfVkVSU0lPTlxuICAgID8gKGF3YWl0IHJldHJpZXZlRGF0YShgJHtDRF9DRE59L0xBVEVTVF9SRUxFQVNFYCwge1xuICAgICAgJ3VzZXItYWdlbnQnOiAnYXBwaXVtJyxcbiAgICAgIGFjY2VwdDogJyovKicsXG4gICAgfSwgeyB0aW1lb3V0OiBET1dOTE9BRF9USU1FT1VUX01TIH0pKS50cmltKClcbiAgICA6IHZlcjtcbn1cblxuYXN5bmMgZnVuY3Rpb24gcHJlcGFyZUNocm9tZWRyaXZlckRpciAocGxhdGZvcm1OYW1lKSB7XG4gIGNvbnN0IGNocm9tZWRyaXZlckRpciA9IGdldENocm9tZWRyaXZlckRpcihwbGF0Zm9ybU5hbWUpO1xuICBpZiAoIWF3YWl0IGZzLmV4aXN0cyhjaHJvbWVkcml2ZXJEaXIpKSB7XG4gICAgYXdhaXQgbWtkaXJwKGNocm9tZWRyaXZlckRpcik7XG4gIH1cbiAgcmV0dXJuIGNocm9tZWRyaXZlckRpcjtcbn1cblxuYXN5bmMgZnVuY3Rpb24gaW5zdGFsbCAoKSB7XG4gIGNvbnN0IG9zSW5mbyA9IGF3YWl0IGdldE9zSW5mbygpO1xuICBjb25zdCBjbGllbnQgPSBuZXcgQ2hyb21lZHJpdmVyU3RvcmFnZUNsaWVudCh7XG4gICAgY2hyb21lZHJpdmVyRGlyOiBhd2FpdCBwcmVwYXJlQ2hyb21lZHJpdmVyRGlyKG9zSW5mby5uYW1lKSxcbiAgfSk7XG4gIGF3YWl0IGNsaWVudC5zeW5jRHJpdmVycyh7XG4gICAgb3NJbmZvLFxuICAgIHZlcnNpb25zOiBbYXdhaXQgZm9ybWF0Q2RWZXJzaW9uKENEX1ZFUildLFxuICB9KTtcbn1cblxuYXN5bmMgZnVuY3Rpb24gZG9JbnN0YWxsICgpIHtcbiAgYXdhaXQgaW5zdGFsbCgpO1xufVxuXG5leHBvcnQgeyBpbnN0YWxsLCBkb0luc3RhbGwgfTtcbiJdLCJmaWxlIjoibGliL2luc3RhbGwuanMiLCJzb3VyY2VSb290IjoiLi4vLi4ifQ==
@@ -12,12 +12,12 @@ require("source-map-support/register");
12
12
 
13
13
  var _lodash = _interopRequireDefault(require("lodash"));
14
14
 
15
- var _appiumBaseDriver = require("appium-base-driver");
15
+ var _baseDriver = require("@appium/base-driver");
16
16
 
17
17
  const W3C_PREFIX = 'goog:';
18
18
 
19
19
  function toW3cCapName(capName) {
20
- return _lodash.default.isString(capName) && !capName.includes(':') && !(0, _appiumBaseDriver.isStandardCap)(capName) ? `${W3C_PREFIX}${capName}` : capName;
20
+ return _lodash.default.isString(capName) && !capName.includes(':') && !(0, _baseDriver.isStandardCap)(capName) ? `${W3C_PREFIX}${capName}` : capName;
21
21
  }
22
22
 
23
23
  function getCapValue(allCaps = {}, rawCapName, defaultValue) {
@@ -38,4 +38,4 @@ function toW3cCapNames(originalCaps = {}) {
38
38
  }require('source-map-support').install();
39
39
 
40
40
 
41
- //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImxpYi9wcm90b2NvbC1oZWxwZXJzLmpzIl0sIm5hbWVzIjpbIlczQ19QUkVGSVgiLCJ0b1czY0NhcE5hbWUiLCJjYXBOYW1lIiwiXyIsImlzU3RyaW5nIiwiaW5jbHVkZXMiLCJnZXRDYXBWYWx1ZSIsImFsbENhcHMiLCJyYXdDYXBOYW1lIiwiZGVmYXVsdFZhbHVlIiwiY2FwVmFsdWUiLCJ0b1BhaXJzIiwidG9XM2NDYXBOYW1lcyIsIm9yaWdpbmFsQ2FwcyIsInJlZHVjZSIsImFjYyIsInZhbHVlIiwia2V5Il0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7QUFBQTs7QUFDQTs7QUFFQSxNQUFNQSxVQUFVLEdBQUcsT0FBbkI7O0FBRUEsU0FBU0MsWUFBVCxDQUF1QkMsT0FBdkIsRUFBZ0M7QUFDOUIsU0FBUUMsZ0JBQUVDLFFBQUYsQ0FBV0YsT0FBWCxLQUF1QixDQUFDQSxPQUFPLENBQUNHLFFBQVIsQ0FBaUIsR0FBakIsQ0FBeEIsSUFBaUQsQ0FBQyxxQ0FBY0gsT0FBZCxDQUFuRCxHQUNGLEdBQUVGLFVBQVcsR0FBRUUsT0FBUSxFQURyQixHQUVIQSxPQUZKO0FBR0Q7O0FBRUQsU0FBU0ksV0FBVCxDQUFzQkMsT0FBTyxHQUFHLEVBQWhDLEVBQW9DQyxVQUFwQyxFQUFnREMsWUFBaEQsRUFBOEQ7QUFDNUQsT0FBSyxNQUFNLENBQUNQLE9BQUQsRUFBVVEsUUFBVixDQUFYLElBQWtDUCxnQkFBRVEsT0FBRixDQUFVSixPQUFWLENBQWxDLEVBQXNEO0FBQ3BELFFBQUlOLFlBQVksQ0FBQ0MsT0FBRCxDQUFaLEtBQTBCRCxZQUFZLENBQUNPLFVBQUQsQ0FBMUMsRUFBd0Q7QUFDdEQsYUFBT0UsUUFBUDtBQUNEO0FBQ0Y7O0FBQ0QsU0FBT0QsWUFBUDtBQUNEOztBQUVELFNBQVNHLGFBQVQsQ0FBd0JDLFlBQVksR0FBRyxFQUF2QyxFQUEyQztBQUN6QyxTQUFPVixnQkFBRVcsTUFBRixDQUFTRCxZQUFULEVBQXVCLENBQUNFLEdBQUQsRUFBTUMsS0FBTixFQUFhQyxHQUFiLEtBQXFCO0FBQ2pERixJQUFBQSxHQUFHLENBQUNkLFlBQVksQ0FBQ2dCLEdBQUQsQ0FBYixDQUFILEdBQXlCRCxLQUF6QjtBQUNBLFdBQU9ELEdBQVA7QUFDRCxHQUhNLEVBR0osRUFISSxDQUFQO0FBSUQiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgXyBmcm9tICdsb2Rhc2gnO1xuaW1wb3J0IHsgaXNTdGFuZGFyZENhcCB9IGZyb20gJ2FwcGl1bS1iYXNlLWRyaXZlcic7XG5cbmNvbnN0IFczQ19QUkVGSVggPSAnZ29vZzonO1xuXG5mdW5jdGlvbiB0b1czY0NhcE5hbWUgKGNhcE5hbWUpIHtcbiAgcmV0dXJuIChfLmlzU3RyaW5nKGNhcE5hbWUpICYmICFjYXBOYW1lLmluY2x1ZGVzKCc6JykgJiYgIWlzU3RhbmRhcmRDYXAoY2FwTmFtZSkpXG4gICAgPyBgJHtXM0NfUFJFRklYfSR7Y2FwTmFtZX1gXG4gICAgOiBjYXBOYW1lO1xufVxuXG5mdW5jdGlvbiBnZXRDYXBWYWx1ZSAoYWxsQ2FwcyA9IHt9LCByYXdDYXBOYW1lLCBkZWZhdWx0VmFsdWUpIHtcbiAgZm9yIChjb25zdCBbY2FwTmFtZSwgY2FwVmFsdWVdIG9mIF8udG9QYWlycyhhbGxDYXBzKSkge1xuICAgIGlmICh0b1czY0NhcE5hbWUoY2FwTmFtZSkgPT09IHRvVzNjQ2FwTmFtZShyYXdDYXBOYW1lKSkge1xuICAgICAgcmV0dXJuIGNhcFZhbHVlO1xuICAgIH1cbiAgfVxuICByZXR1cm4gZGVmYXVsdFZhbHVlO1xufVxuXG5mdW5jdGlvbiB0b1czY0NhcE5hbWVzIChvcmlnaW5hbENhcHMgPSB7fSkge1xuICByZXR1cm4gXy5yZWR1Y2Uob3JpZ2luYWxDYXBzLCAoYWNjLCB2YWx1ZSwga2V5KSA9PiB7XG4gICAgYWNjW3RvVzNjQ2FwTmFtZShrZXkpXSA9IHZhbHVlO1xuICAgIHJldHVybiBhY2M7XG4gIH0sIHt9KTtcbn1cblxuZXhwb3J0IHsgdG9XM2NDYXBOYW1lcywgZ2V0Q2FwVmFsdWUgfTtcbiJdLCJmaWxlIjoibGliL3Byb3RvY29sLWhlbHBlcnMuanMiLCJzb3VyY2VSb290IjoiLi4vLi4ifQ==
41
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImxpYi9wcm90b2NvbC1oZWxwZXJzLmpzIl0sIm5hbWVzIjpbIlczQ19QUkVGSVgiLCJ0b1czY0NhcE5hbWUiLCJjYXBOYW1lIiwiXyIsImlzU3RyaW5nIiwiaW5jbHVkZXMiLCJnZXRDYXBWYWx1ZSIsImFsbENhcHMiLCJyYXdDYXBOYW1lIiwiZGVmYXVsdFZhbHVlIiwiY2FwVmFsdWUiLCJ0b1BhaXJzIiwidG9XM2NDYXBOYW1lcyIsIm9yaWdpbmFsQ2FwcyIsInJlZHVjZSIsImFjYyIsInZhbHVlIiwia2V5Il0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7QUFBQTs7QUFDQTs7QUFFQSxNQUFNQSxVQUFVLEdBQUcsT0FBbkI7O0FBRUEsU0FBU0MsWUFBVCxDQUF1QkMsT0FBdkIsRUFBZ0M7QUFDOUIsU0FBUUMsZ0JBQUVDLFFBQUYsQ0FBV0YsT0FBWCxLQUF1QixDQUFDQSxPQUFPLENBQUNHLFFBQVIsQ0FBaUIsR0FBakIsQ0FBeEIsSUFBaUQsQ0FBQywrQkFBY0gsT0FBZCxDQUFuRCxHQUNGLEdBQUVGLFVBQVcsR0FBRUUsT0FBUSxFQURyQixHQUVIQSxPQUZKO0FBR0Q7O0FBRUQsU0FBU0ksV0FBVCxDQUFzQkMsT0FBTyxHQUFHLEVBQWhDLEVBQW9DQyxVQUFwQyxFQUFnREMsWUFBaEQsRUFBOEQ7QUFDNUQsT0FBSyxNQUFNLENBQUNQLE9BQUQsRUFBVVEsUUFBVixDQUFYLElBQWtDUCxnQkFBRVEsT0FBRixDQUFVSixPQUFWLENBQWxDLEVBQXNEO0FBQ3BELFFBQUlOLFlBQVksQ0FBQ0MsT0FBRCxDQUFaLEtBQTBCRCxZQUFZLENBQUNPLFVBQUQsQ0FBMUMsRUFBd0Q7QUFDdEQsYUFBT0UsUUFBUDtBQUNEO0FBQ0Y7O0FBQ0QsU0FBT0QsWUFBUDtBQUNEOztBQUVELFNBQVNHLGFBQVQsQ0FBd0JDLFlBQVksR0FBRyxFQUF2QyxFQUEyQztBQUN6QyxTQUFPVixnQkFBRVcsTUFBRixDQUFTRCxZQUFULEVBQXVCLENBQUNFLEdBQUQsRUFBTUMsS0FBTixFQUFhQyxHQUFiLEtBQXFCO0FBQ2pERixJQUFBQSxHQUFHLENBQUNkLFlBQVksQ0FBQ2dCLEdBQUQsQ0FBYixDQUFILEdBQXlCRCxLQUF6QjtBQUNBLFdBQU9ELEdBQVA7QUFDRCxHQUhNLEVBR0osRUFISSxDQUFQO0FBSUQiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgXyBmcm9tICdsb2Rhc2gnO1xuaW1wb3J0IHsgaXNTdGFuZGFyZENhcCB9IGZyb20gJ0BhcHBpdW0vYmFzZS1kcml2ZXInO1xuXG5jb25zdCBXM0NfUFJFRklYID0gJ2dvb2c6JztcblxuZnVuY3Rpb24gdG9XM2NDYXBOYW1lIChjYXBOYW1lKSB7XG4gIHJldHVybiAoXy5pc1N0cmluZyhjYXBOYW1lKSAmJiAhY2FwTmFtZS5pbmNsdWRlcygnOicpICYmICFpc1N0YW5kYXJkQ2FwKGNhcE5hbWUpKVxuICAgID8gYCR7VzNDX1BSRUZJWH0ke2NhcE5hbWV9YFxuICAgIDogY2FwTmFtZTtcbn1cblxuZnVuY3Rpb24gZ2V0Q2FwVmFsdWUgKGFsbENhcHMgPSB7fSwgcmF3Q2FwTmFtZSwgZGVmYXVsdFZhbHVlKSB7XG4gIGZvciAoY29uc3QgW2NhcE5hbWUsIGNhcFZhbHVlXSBvZiBfLnRvUGFpcnMoYWxsQ2FwcykpIHtcbiAgICBpZiAodG9XM2NDYXBOYW1lKGNhcE5hbWUpID09PSB0b1czY0NhcE5hbWUocmF3Q2FwTmFtZSkpIHtcbiAgICAgIHJldHVybiBjYXBWYWx1ZTtcbiAgICB9XG4gIH1cbiAgcmV0dXJuIGRlZmF1bHRWYWx1ZTtcbn1cblxuZnVuY3Rpb24gdG9XM2NDYXBOYW1lcyAob3JpZ2luYWxDYXBzID0ge30pIHtcbiAgcmV0dXJuIF8ucmVkdWNlKG9yaWdpbmFsQ2FwcywgKGFjYywgdmFsdWUsIGtleSkgPT4ge1xuICAgIGFjY1t0b1czY0NhcE5hbWUoa2V5KV0gPSB2YWx1ZTtcbiAgICByZXR1cm4gYWNjO1xuICB9LCB7fSk7XG59XG5cbmV4cG9ydCB7IHRvVzNjQ2FwTmFtZXMsIGdldENhcFZhbHVlIH07XG4iXSwiZmlsZSI6ImxpYi9wcm90b2NvbC1oZWxwZXJzLmpzIiwic291cmNlUm9vdCI6Ii4uLy4uIn0=
@@ -21,15 +21,15 @@ var _bluebird = _interopRequireDefault(require("bluebird"));
21
21
 
22
22
  var _path = _interopRequireDefault(require("path"));
23
23
 
24
- var _appiumSupport = require("appium-support");
24
+ var _support = require("@appium/support");
25
25
 
26
26
  const TIMEOUT_MS = 15000;
27
27
  const MAX_PARALLEL_DOWNLOADS = 5;
28
28
 
29
- const log = _appiumSupport.logger.getLogger('ChromedriverStorageClient');
29
+ const log = _support.logger.getLogger('ChromedriverStorageClient');
30
30
 
31
31
  async function isCrcOk(src, checksum) {
32
- const md5 = await _appiumSupport.fs.hash(src, 'md5');
32
+ const md5 = await _support.fs.hash(src, 'md5');
33
33
  return _lodash.default.toLower(md5) === _lodash.default.toLower(checksum);
34
34
  }
35
35
 
@@ -70,7 +70,7 @@ function findChildNode(parent, childName = null, text = null) {
70
70
  }
71
71
 
72
72
  function extractNodeText(node) {
73
- return !node || !node.firstChild || !_appiumSupport.util.hasValue(node.firstChild.nodeValue) ? null : node.firstChild.nodeValue;
73
+ return !node || !node.firstChild || !_support.util.hasValue(node.firstChild.nodeValue) ? null : node.firstChild.nodeValue;
74
74
  }
75
75
 
76
76
  class ChromedriverStorageClient {
@@ -190,22 +190,22 @@ class ChromedriverStorageClient {
190
190
  }
191
191
 
192
192
  async unzipDriver(src, dst) {
193
- const tmpRoot = await _appiumSupport.tempDir.openDir();
193
+ const tmpRoot = await _support.tempDir.openDir();
194
194
 
195
195
  try {
196
- await _appiumSupport.zip.extractAllTo(src, tmpRoot);
197
- const chromedriverPath = await _appiumSupport.fs.walkDir(tmpRoot, true, (itemPath, isDirectory) => !isDirectory && _lodash.default.toLower(_path.default.parse(itemPath).name) === 'chromedriver');
196
+ await _support.zip.extractAllTo(src, tmpRoot);
197
+ const chromedriverPath = await _support.fs.walkDir(tmpRoot, true, (itemPath, isDirectory) => !isDirectory && _lodash.default.toLower(_path.default.parse(itemPath).name) === 'chromedriver');
198
198
 
199
199
  if (!chromedriverPath) {
200
200
  throw new Error('The archive was unzipped properly, but we could not find any chromedriver executable');
201
201
  }
202
202
 
203
203
  log.debug(`Moving the extracted '${_path.default.basename(chromedriverPath)}' to '${dst}'`);
204
- await _appiumSupport.fs.mv(chromedriverPath, dst, {
204
+ await _support.fs.mv(chromedriverPath, dst, {
205
205
  mkdirp: true
206
206
  });
207
207
  } finally {
208
- await _appiumSupport.fs.rimraf(tmpRoot);
208
+ await _support.fs.rimraf(tmpRoot);
209
209
  }
210
210
  }
211
211
 
@@ -220,7 +220,7 @@ class ChromedriverStorageClient {
220
220
  if (!_lodash.default.isEmpty(versions)) {
221
221
  log.debug(`Selecting chromedrivers whose versions match to ${versions}`);
222
222
  driversToSync = driversToSync.filter(cdName => versions.includes(`${this.mapping[cdName].version}`));
223
- log.debug(`Got ${_appiumSupport.util.pluralize('item', driversToSync.length, true)}`);
223
+ log.debug(`Got ${_support.util.pluralize('item', driversToSync.length, true)}`);
224
224
 
225
225
  if (_lodash.default.isEmpty(driversToSync)) {
226
226
  return [];
@@ -241,13 +241,13 @@ class ChromedriverStorageClient {
241
241
  }
242
242
 
243
243
  driversToSync = driversToSync.filter(cdName => `${this.mapping[cdName].minBrowserVersion}` === `${closestMatchedVersionNumber > 0 ? closestMatchedVersionNumber : minBrowserVersionInt}`);
244
- log.debug(`Got ${_appiumSupport.util.pluralize('item', driversToSync.length, true)}`);
244
+ log.debug(`Got ${_support.util.pluralize('item', driversToSync.length, true)}`);
245
245
 
246
246
  if (_lodash.default.isEmpty(driversToSync)) {
247
247
  return [];
248
248
  }
249
249
 
250
- log.debug(`Will select candidate ${_appiumSupport.util.pluralize('driver', driversToSync.length)} ` + `versioned as '${_lodash.default.uniq(driversToSync.map(cdName => this.mapping[cdName].version))}'`);
250
+ log.debug(`Will select candidate ${_support.util.pluralize('driver', driversToSync.length)} ` + `versioned as '${_lodash.default.uniq(driversToSync.map(cdName => this.mapping[cdName].version))}'`);
251
251
  }
252
252
 
253
253
  if (!_lodash.default.isEmpty(osInfo)) {
@@ -268,7 +268,7 @@ class ChromedriverStorageClient {
268
268
  log.debug(`Selecting chromedrivers whose platform matches to ${name}${arch}`);
269
269
  const platformRe = new RegExp(`(\\b|_)${name}${arch}\\b`);
270
270
  driversToSync = driversToSync.filter(cdName => platformRe.test(cdName));
271
- log.debug(`Got ${_appiumSupport.util.pluralize('item', driversToSync.length, true)}`);
271
+ log.debug(`Got ${_support.util.pluralize('item', driversToSync.length, true)}`);
272
272
  }
273
273
 
274
274
  return driversToSync;
@@ -286,7 +286,7 @@ class ChromedriverStorageClient {
286
286
  log.debug(`Retrieving '${url}' to '${archivePath}'`);
287
287
 
288
288
  try {
289
- await _appiumSupport.net.downloadFile(url, archivePath, {
289
+ await _support.net.downloadFile(url, archivePath, {
290
290
  isMetered: false,
291
291
  timeout: TIMEOUT_MS
292
292
  });
@@ -312,13 +312,13 @@ class ChromedriverStorageClient {
312
312
  return false;
313
313
  }
314
314
 
315
- const fileName = `${_path.default.parse(url).name}_v${version}` + (_appiumSupport.system.isWindows() ? '.exe' : '');
315
+ const fileName = `${_path.default.parse(url).name}_v${version}` + (_support.system.isWindows() ? '.exe' : '');
316
316
 
317
317
  const targetPath = _path.default.resolve(this.chromedriverDir, fileName);
318
318
 
319
319
  try {
320
320
  await this.unzipDriver(archivePath, targetPath);
321
- await _appiumSupport.fs.chmod(targetPath, 0o755);
321
+ await _support.fs.chmod(targetPath, 0o755);
322
322
  log.debug(`Permissions of the file '${targetPath}' have been changed to 755`);
323
323
  } catch (e) {
324
324
  if (isStrict) {
@@ -350,10 +350,10 @@ class ChromedriverStorageClient {
350
350
  return [];
351
351
  }
352
352
 
353
- log.debug(`Got ${_appiumSupport.util.pluralize('driver', driversToSync.length, true)} to sync: ` + JSON.stringify(driversToSync, null, 2));
353
+ log.debug(`Got ${_support.util.pluralize('driver', driversToSync.length, true)} to sync: ` + JSON.stringify(driversToSync, null, 2));
354
354
  const synchronizedDrivers = [];
355
355
  const promises = [];
356
- const archivesRoot = await _appiumSupport.tempDir.openDir();
356
+ const archivesRoot = await _support.tempDir.openDir();
357
357
 
358
358
  try {
359
359
  for (const [idx, driverKey] of driversToSync.entries()) {
@@ -370,11 +370,11 @@ class ChromedriverStorageClient {
370
370
 
371
371
  await _bluebird.default.all(promises);
372
372
  } finally {
373
- await _appiumSupport.fs.rimraf(archivesRoot);
373
+ await _support.fs.rimraf(archivesRoot);
374
374
  }
375
375
 
376
376
  if (!_lodash.default.isEmpty(synchronizedDrivers)) {
377
- log.info(`Successfully synchronized ` + `${_appiumSupport.util.pluralize('chromedriver', synchronizedDrivers.length, true)}`);
377
+ log.info(`Successfully synchronized ` + `${_support.util.pluralize('chromedriver', synchronizedDrivers.length, true)}`);
378
378
  } else {
379
379
  log.info(`No chromedrivers were synchronized`);
380
380
  }
@@ -388,4 +388,4 @@ var _default = ChromedriverStorageClient;
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/storage-client.js"],"names":["TIMEOUT_MS","MAX_PARALLEL_DOWNLOADS","log","logger","getLogger","isCrcOk","src","checksum","md5","fs","hash","_","toLower","findChildNode","parent","childName","text","hasChildNodes","childNodeIdx","childNodes","length","childNode","localName","childText","extractNodeText","node","firstChild","util","hasValue","nodeValue","ChromedriverStorageClient","constructor","args","chromedriverDir","timeout","mapping","parseNotes","content","result","versionMatch","exec","version","minBrowserVersionMatch","minBrowserVersion","retrieveAdditionalDriverInfo","driverKey","notesUrl","infoDict","notes","accept","debug","parseStorageXml","doc","shouldParseNotes","driverNodes","xpath","select","isEmpty","promises","driverNode","key","includes","etag","cdInfo","url","CD_CDN","trim","first","split","notesPath","isNotesPresent","reduce","acc","info","push","B","all","size","retrieveMapping","xml","DOMParser","parseFromString","cloneDeep","unzipDriver","dst","tmpRoot","tempDir","openDir","zip","extractAllTo","chromedriverPath","walkDir","itemPath","isDirectory","path","parse","name","Error","basename","mv","mkdirp","rimraf","selectMatchingDrivers","osInfo","opts","versions","driversToSync","keys","filter","cdName","pluralize","isNaN","minBrowserVersionInt","parseInt","closestMatchedVersionNumber","currentMinBrowserVersion","uniq","map","arch","hardwareName","X64","some","X86","OS","mac","M1_ARCH_SUFFIX","platformRe","RegExp","test","retrieveDriver","index","archivesRoot","isStrict","archivePath","resolve","net","downloadFile","isMetered","e","msg","message","error","fileName","system","isWindows","targetPath","chmod","syncDrivers","JSON","stringify","synchronizedDrivers","idx","entries"],"mappings":"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","sourcesContent":["import {\n  getChromedriverDir, CD_CDN, retrieveData, getOsInfo,\n  OS, X64, X86, M1_ARCH_SUFFIX,\n} from './utils';\nimport _ from 'lodash';\nimport xpath from 'xpath';\nimport { DOMParser } from '@xmldom/xmldom';\nimport B from 'bluebird';\nimport path from 'path';\nimport { system, fs, logger, tempDir, zip, util, net } from 'appium-support';\n\n\nconst TIMEOUT_MS = 15000;\nconst MAX_PARALLEL_DOWNLOADS = 5;\n\nconst log = logger.getLogger('ChromedriverStorageClient');\n\n\nasync function isCrcOk (src, checksum) {\n  const md5 = await fs.hash(src, 'md5');\n  return _.toLower(md5) === _.toLower(checksum);\n}\n\nfunction findChildNode (parent, childName = null, text = null) {\n  if (!childName && !text) {\n    return null;\n  }\n  if (!parent.hasChildNodes()) {\n    return null;\n  }\n\n  for (let childNodeIdx = 0; childNodeIdx < parent.childNodes.length; childNodeIdx++) {\n    const childNode = parent.childNodes[childNodeIdx];\n    if (childName && !text && childName === childNode.localName) {\n      return childNode;\n    }\n    if (text) {\n      const childText = extractNodeText(childNode);\n      if (!childText) {\n        continue;\n      }\n      if (childName && childName === childNode.localName && text === childText) {\n        return childNode;\n      }\n      if (!childName && text === childText) {\n        return childNode;\n      }\n    }\n  }\n  return null;\n}\n\nfunction extractNodeText (node) {\n  return (!node || !node.firstChild || !util.hasValue(node.firstChild.nodeValue))\n    ? null\n    : node.firstChild.nodeValue;\n}\n\n\nclass ChromedriverStorageClient {\n  constructor (args = {}) {\n    const {\n      chromedriverDir = getChromedriverDir(),\n      timeout = TIMEOUT_MS,\n    } = args;\n    this.chromedriverDir = chromedriverDir;\n    this.timeout = timeout;\n    this.mapping = {};\n  }\n\n  /**\n   * @typedef {Object} AdditionalDriverDetails\n   * @property {?string} version - Chromedriver version\n   * or `null` if it cannot be found\n   * @property {?string} minBrowserVersion - The minimum browser version\n   * supported by chromedriver or `null` if it cannot be found\n   */\n\n  /**\n   * Gets additional chromedriver details from chromedriver\n   * release notes\n   *\n   * @param {string} content - Release notes of the corresponding chromedriver\n   * @returns {AdditionalDriverDetails}\n   */\n  parseNotes (content) {\n    const result = {};\n    const versionMatch = /^\\s*[-]+ChromeDriver[\\D]+([\\d.]+)/im.exec(content);\n    if (versionMatch) {\n      result.version = versionMatch[1];\n    }\n    const minBrowserVersionMatch = /^\\s*Supports Chrome[\\D]+(\\d+)/im.exec(content);\n    if (minBrowserVersionMatch) {\n      result.minBrowserVersion = minBrowserVersionMatch[1];\n    }\n    return result;\n  }\n\n  /**\n   * Downloads chromedriver release notes and puts them\n   * into the dictionary argument\n   *\n   * @param {string} driverKey - Driver version plus archive name\n   * @param {string} notesUrl - The URL of chromedriver notes\n   * @param {Object} infoDict - The dictionary containing driver info.\n   * The method call mutates by merging `AdditionalDriverDetails`\n   * @throws {Error} if the release notes cannot be downloaded\n   */\n  async retrieveAdditionalDriverInfo (driverKey, notesUrl, infoDict) {\n    const notes = await retrieveData(notesUrl, {\n      'user-agent': 'appium',\n      accept: '*/*',\n    }, { timeout: this.timeout });\n    const { minBrowserVersion } = this.parseNotes(notes);\n    if (!minBrowserVersion) {\n      log.debug(`The driver '${driverKey}' does not contain valid release notes at ${notesUrl}. ` +\n        `Skipping it`);\n      return;\n    }\n    infoDict.minBrowserVersion = minBrowserVersion;\n  }\n\n  /**\n   * Parses chromedriver storage XML and stores\n   * the parsed results into `this.mapping`\n   *\n   * @param {DOMDocument} doc - The DOM representation\n   * of the chromedriver storage XML\n   * @param {boolean} shouldParseNotes [true] - If set to `true`\n   * then additional drivers information is going to be parsed\n   * and assigned to `this.mapping`\n   */\n  async parseStorageXml (doc, shouldParseNotes = true) {\n    const driverNodes = xpath.select(`//*[local-name(.)='Contents']`, doc);\n    log.debug(`Parsed ${driverNodes.length} entries from storage XML`);\n    if (_.isEmpty(driverNodes)) {\n      return;\n    }\n\n    const promises = [];\n    for (const driverNode of driverNodes) {\n      const key = extractNodeText(findChildNode(driverNode, 'Key'));\n      if (!_.includes(key, '/chromedriver_')) {\n        continue;\n      }\n\n      const etag = extractNodeText(findChildNode(driverNode, 'ETag'));\n      if (!etag) {\n        log.debug(`The entry '${key}' does not contain the checksum. Skipping it`);\n        continue;\n      }\n\n      const cdInfo = {\n        url: `${CD_CDN}/${key}`,\n        etag: _.trim(etag, '\"'),\n        version: _.first(key.split('/')),\n      };\n      this.mapping[key] = cdInfo;\n\n      const notesPath = `${cdInfo.version}/notes.txt`;\n      const isNotesPresent = !!driverNodes\n        .reduce((acc, node) => acc || findChildNode(node, 'Key', notesPath), false);\n      if (!isNotesPresent) {\n        cdInfo.minBrowserVersion = null;\n        if (shouldParseNotes) {\n          log.info(`The entry '${key}' does not contain any notes. Skipping it`);\n        }\n        continue;\n      } else if (!shouldParseNotes) {\n        continue;\n      }\n\n      promises.push(this.retrieveAdditionalDriverInfo(key, `${CD_CDN}/${notesPath}`, cdInfo));\n      if (promises.length % MAX_PARALLEL_DOWNLOADS === 0) {\n        await B.all(promises);\n      }\n    }\n    await B.all(promises);\n    log.info(`The total count of entries in the mapping: ${_.size(this.mapping)}`);\n  }\n\n  /**\n   * @typedef {Object} DriverDetails\n   * @property {string} url - The full url to the corresponding driver in\n   * the remote storage\n   * @property {string} etag - The CRC of the driver archive\n   * @property {string} version - Chromedriver version\n   */\n\n  /**\n   * @typedef {Object} ChromedriversMapping\n   * @property {DriverDetails} - The keys are unique driver identifiers\n   * (version/archive name). The corresponding values have `DriverDetails`\n   * containing chromedriver details\n   */\n\n  /**\n   * Retrieves chromedriver mapping from the storage\n   *\n   * @param {boolean} shouldParseNotes [true] - if set to `true`\n   * then additional chromedrivers info is going to be retrieved and\n   * parsed from release notes\n   * @returns {ChromedriversMapping}\n   */\n  async retrieveMapping (shouldParseNotes = true) {\n    const xml = await retrieveData(CD_CDN, {\n      'user-agent': 'appium',\n      accept: 'application/xml, */*',\n    }, { timeout: this.timeout });\n    const doc = new DOMParser().parseFromString(xml);\n    await this.parseStorageXml(doc, shouldParseNotes);\n    return _.cloneDeep(this.mapping);\n  }\n\n  /**\n   * Extracts downloaded chromedriver archive\n   * into the given destination\n   *\n   * @param {string} src - The source archive path\n   * @param {string} dst - The destination chromedriver path\n   */\n  async unzipDriver (src, dst) {\n    const tmpRoot = await tempDir.openDir();\n    try {\n      await zip.extractAllTo(src, tmpRoot);\n      const chromedriverPath = await fs.walkDir(tmpRoot, true, (itemPath, isDirectory) =>\n        !isDirectory && _.toLower(path.parse(itemPath).name) === 'chromedriver');\n      if (!chromedriverPath) {\n        throw new Error('The archive was unzipped properly, but we could not find any chromedriver executable');\n      }\n      log.debug(`Moving the extracted '${path.basename(chromedriverPath)}' to '${dst}'`);\n      await fs.mv(chromedriverPath, dst, {\n        mkdirp: true\n      });\n    } finally {\n      await fs.rimraf(tmpRoot);\n    }\n  }\n\n  /**\n   * @typedef {Object} OSInfo\n   * @property {string} name - The name of the host OS\n   * Can be either `mac`, `windows` or `linux`\n   * @property {string} arch - The architecture of the host OD.\n   * Can be either `32` or `64`\n   * @property {?string} hardwareName - The output of `uname -m` command\n   * on linux and mac systems. `null` on Windows\n   */\n\n  /**\n   * Filters `this.mapping` to only select matching\n   * chromedriver entries by operating system information\n   * and/or additional synchronization options (if provided)\n   *\n   * @param {?OSInfo} osInfo\n   * @param {?SyncOptions} opts\n   * @returns {Array<String>} The list of filtered chromedriver\n   * entry names (version/archive name)\n   */\n  selectMatchingDrivers (osInfo, opts = {}) {\n    const {\n      minBrowserVersion,\n      versions = [],\n    } = opts;\n    let driversToSync = _.keys(this.mapping);\n\n    if (!_.isEmpty(versions)) {\n      // Handle only selected versions if requested\n      log.debug(`Selecting chromedrivers whose versions match to ${versions}`);\n      driversToSync = driversToSync\n        .filter((cdName) => versions.includes(`${this.mapping[cdName].version}`));\n\n      log.debug(`Got ${util.pluralize('item', driversToSync.length, true)}`);\n      if (_.isEmpty(driversToSync)) {\n        return [];\n      }\n    }\n\n    if (!isNaN(minBrowserVersion)) {\n      // Only select drivers that support the current browser whose major version number equals to `minBrowserVersion`\n      const minBrowserVersionInt = parseInt(minBrowserVersion, 10);\n      log.debug(`Selecting chromedrivers whose minimum supported browser version matches to ${minBrowserVersionInt}`);\n      let closestMatchedVersionNumber = 0;\n      // Select the newest available and compatible chromedriver\n      for (const cdName of driversToSync) {\n        const currentMinBrowserVersion = parseInt(this.mapping[cdName].minBrowserVersion, 10);\n        if (!isNaN(currentMinBrowserVersion)\n            && currentMinBrowserVersion <= minBrowserVersionInt\n            && closestMatchedVersionNumber < currentMinBrowserVersion) {\n          closestMatchedVersionNumber = currentMinBrowserVersion;\n        }\n      }\n      driversToSync = driversToSync.filter((cdName) => `${this.mapping[cdName].minBrowserVersion}` ===\n        `${closestMatchedVersionNumber > 0 ? closestMatchedVersionNumber : minBrowserVersionInt}`);\n\n      log.debug(`Got ${util.pluralize('item', driversToSync.length, true)}`);\n      if (_.isEmpty(driversToSync)) {\n        return [];\n      }\n      log.debug(`Will select candidate ${util.pluralize('driver', driversToSync.length)} ` +\n        `versioned as '${_.uniq(driversToSync.map((cdName) => this.mapping[cdName].version))}'`);\n    }\n\n    if (!_.isEmpty(osInfo)) {\n      // Filter out drivers for unsupported system architectures\n      let {name, arch, hardwareName} = osInfo;\n      if (arch === X64 && !driversToSync.some((cdName) => cdName.includes(`_${name}${X64}`))) {\n        // Fall back to x86 build if x64 one is not available for the given OS\n        arch = X86;\n      }\n      if (name === OS.mac && _.includes(hardwareName, 'arm')\n          && driversToSync.some((cdName) => cdName.includes(M1_ARCH_SUFFIX))) {\n        // prefer executable for M1 arch if present\n        arch += M1_ARCH_SUFFIX;\n      }\n      log.debug(`Selecting chromedrivers whose platform matches to ${name}${arch}`);\n      const platformRe = new RegExp(`(\\\\b|_)${name}${arch}\\\\b`);\n      driversToSync = driversToSync.filter((cdName) => platformRe.test(cdName));\n      log.debug(`Got ${util.pluralize('item', driversToSync.length, true)}`);\n    }\n\n    return driversToSync;\n  }\n\n  /**\n   * Retrieves the given chromedriver from the storage\n   * and unpacks it into `this.chromedriverDir` folder\n   *\n   * @param {number} index - The unique driver index\n   * @param {string} driverKey - The driver key in `this.mapping`\n   * @param {string} archivesRoot - The temporary folder path to extract\n   * downloaded archives to\n   * @param {boolean} isStrict [true] - Whether to throw an error (`true`)\n   * or return a boolean result if the driver retrieval process fails\n   * @throws {Error} if there was a failure while retrieving the driver\n   * and `isStrict` is set to `true`\n   * @returns {boolean} if `true` then the chromedriver is successfully\n   * downloaded and extracted.\n   */\n  async retrieveDriver (index, driverKey, archivesRoot, isStrict = false) {\n    const { url, etag, version } = this.mapping[driverKey];\n    const archivePath = path.resolve(archivesRoot, `${index}.zip`);\n    log.debug(`Retrieving '${url}' to '${archivePath}'`);\n    try {\n      await net.downloadFile(url, archivePath, {\n        isMetered: false,\n        timeout: TIMEOUT_MS\n      });\n    } catch (e) {\n      const msg = `Cannot download chromedriver archive. Original error: ${e.message}`;\n      if (isStrict) {\n        throw new Error(msg);\n      }\n      log.error(msg);\n      return false;\n    }\n    if (!await isCrcOk(archivePath, etag)) {\n      const msg = `The checksum for the downloaded chromedriver '${driverKey}' did not match`;\n      if (isStrict) {\n        throw new Error(msg);\n      }\n      log.error(msg);\n      return false;\n    }\n    const fileName = `${path.parse(url).name}_v${version}` +\n      (system.isWindows() ? '.exe' : '');\n    const targetPath = path.resolve(this.chromedriverDir, fileName);\n    try {\n      await this.unzipDriver(archivePath, targetPath);\n      await fs.chmod(targetPath, 0o755);\n      log.debug(`Permissions of the file '${targetPath}' have been changed to 755`);\n    } catch (e) {\n      if (isStrict) {\n        throw e;\n      }\n      log.error(e.message);\n      return false;\n    }\n    return true;\n  }\n\n  /**\n   * @typedef {Object} SyncOptions\n   * @property {Array<String>} versions - The list of chromedriver\n   * versions to sync. If empty (the default value) then all available\n   * chromedrivers are going to be downloaded and extracted\n   * @property {string|number} minBrowserVersion - The minumum supported\n   * Chrome version that downloaded chromedrivers should support. Can match\n   * multiple drivers.\n   * @property {?OSInfo} osInfo - System information used to filter out\n   * the list of the retrieved drivers. If not provided then the script\n   * will try to retrieve it.\n   */\n\n  /**\n   * Retrieves chromedrivers from the remote storage\n   * to the local file system\n   *\n   * @param {?SyncOptions} opts\n   * @throws {Error} if there was a problem while retrieving\n   * the drivers\n   * @returns {Array<String} The list of successfully synchronized driver keys\n   */\n  async syncDrivers (opts = {}) {\n    if (_.isEmpty(this.mapping)) {\n      await this.retrieveMapping(!!opts.minBrowserVersion);\n    }\n    if (_.isEmpty(this.mapping)) {\n      throw new Error('Cannot retrieve chromedrivers mapping from Google storage');\n    }\n\n    const driversToSync = this.selectMatchingDrivers(opts.osInfo ?? await getOsInfo(), opts);\n    if (_.isEmpty(driversToSync)) {\n      log.debug(`There are no drivers to sync. Exiting`);\n      return [];\n    }\n    log.debug(`Got ${util.pluralize('driver', driversToSync.length, true)} to sync: ` +\n      JSON.stringify(driversToSync, null, 2));\n\n    const synchronizedDrivers = [];\n    const promises = [];\n    const archivesRoot = await tempDir.openDir();\n    try {\n      for (const [idx, driverKey] of driversToSync.entries()) {\n        promises.push((async () => {\n          if (await this.retrieveDriver(idx, driverKey, archivesRoot, !_.isEmpty(opts))) {\n            synchronizedDrivers.push(driverKey);\n          }\n        })());\n\n        if (promises.length % MAX_PARALLEL_DOWNLOADS === 0) {\n          await B.all(promises);\n        }\n      }\n      await B.all(promises);\n    } finally {\n      await fs.rimraf(archivesRoot);\n    }\n    if (!_.isEmpty(synchronizedDrivers)) {\n      log.info(`Successfully synchronized ` +\n        `${util.pluralize('chromedriver', synchronizedDrivers.length, true)}`);\n    } else {\n      log.info(`No chromedrivers were synchronized`);\n    }\n    return synchronizedDrivers;\n  }\n}\n\n\nexport default ChromedriverStorageClient;\n"],"file":"lib/storage-client.js","sourceRoot":"../.."}
391
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/storage-client.js"],"names":["TIMEOUT_MS","MAX_PARALLEL_DOWNLOADS","log","logger","getLogger","isCrcOk","src","checksum","md5","fs","hash","_","toLower","findChildNode","parent","childName","text","hasChildNodes","childNodeIdx","childNodes","length","childNode","localName","childText","extractNodeText","node","firstChild","util","hasValue","nodeValue","ChromedriverStorageClient","constructor","args","chromedriverDir","timeout","mapping","parseNotes","content","result","versionMatch","exec","version","minBrowserVersionMatch","minBrowserVersion","retrieveAdditionalDriverInfo","driverKey","notesUrl","infoDict","notes","accept","debug","parseStorageXml","doc","shouldParseNotes","driverNodes","xpath","select","isEmpty","promises","driverNode","key","includes","etag","cdInfo","url","CD_CDN","trim","first","split","notesPath","isNotesPresent","reduce","acc","info","push","B","all","size","retrieveMapping","xml","DOMParser","parseFromString","cloneDeep","unzipDriver","dst","tmpRoot","tempDir","openDir","zip","extractAllTo","chromedriverPath","walkDir","itemPath","isDirectory","path","parse","name","Error","basename","mv","mkdirp","rimraf","selectMatchingDrivers","osInfo","opts","versions","driversToSync","keys","filter","cdName","pluralize","isNaN","minBrowserVersionInt","parseInt","closestMatchedVersionNumber","currentMinBrowserVersion","uniq","map","arch","hardwareName","X64","some","X86","OS","mac","M1_ARCH_SUFFIX","platformRe","RegExp","test","retrieveDriver","index","archivesRoot","isStrict","archivePath","resolve","net","downloadFile","isMetered","e","msg","message","error","fileName","system","isWindows","targetPath","chmod","syncDrivers","JSON","stringify","synchronizedDrivers","idx","entries"],"mappings":"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","sourcesContent":["import {\n  getChromedriverDir, CD_CDN, retrieveData, getOsInfo,\n  OS, X64, X86, M1_ARCH_SUFFIX,\n} from './utils';\nimport _ from 'lodash';\nimport xpath from 'xpath';\nimport { DOMParser } from '@xmldom/xmldom';\nimport B from 'bluebird';\nimport path from 'path';\nimport { system, fs, logger, tempDir, zip, util, net } from '@appium/support';\n\n\nconst TIMEOUT_MS = 15000;\nconst MAX_PARALLEL_DOWNLOADS = 5;\n\nconst log = logger.getLogger('ChromedriverStorageClient');\n\n\nasync function isCrcOk (src, checksum) {\n  const md5 = await fs.hash(src, 'md5');\n  return _.toLower(md5) === _.toLower(checksum);\n}\n\nfunction findChildNode (parent, childName = null, text = null) {\n  if (!childName && !text) {\n    return null;\n  }\n  if (!parent.hasChildNodes()) {\n    return null;\n  }\n\n  for (let childNodeIdx = 0; childNodeIdx < parent.childNodes.length; childNodeIdx++) {\n    const childNode = parent.childNodes[childNodeIdx];\n    if (childName && !text && childName === childNode.localName) {\n      return childNode;\n    }\n    if (text) {\n      const childText = extractNodeText(childNode);\n      if (!childText) {\n        continue;\n      }\n      if (childName && childName === childNode.localName && text === childText) {\n        return childNode;\n      }\n      if (!childName && text === childText) {\n        return childNode;\n      }\n    }\n  }\n  return null;\n}\n\nfunction extractNodeText (node) {\n  return (!node || !node.firstChild || !util.hasValue(node.firstChild.nodeValue))\n    ? null\n    : node.firstChild.nodeValue;\n}\n\n\nclass ChromedriverStorageClient {\n  constructor (args = {}) {\n    const {\n      chromedriverDir = getChromedriverDir(),\n      timeout = TIMEOUT_MS,\n    } = args;\n    this.chromedriverDir = chromedriverDir;\n    this.timeout = timeout;\n    this.mapping = {};\n  }\n\n  /**\n   * @typedef {Object} AdditionalDriverDetails\n   * @property {?string} version - Chromedriver version\n   * or `null` if it cannot be found\n   * @property {?string} minBrowserVersion - The minimum browser version\n   * supported by chromedriver or `null` if it cannot be found\n   */\n\n  /**\n   * Gets additional chromedriver details from chromedriver\n   * release notes\n   *\n   * @param {string} content - Release notes of the corresponding chromedriver\n   * @returns {AdditionalDriverDetails}\n   */\n  parseNotes (content) {\n    const result = {};\n    const versionMatch = /^\\s*[-]+ChromeDriver[\\D]+([\\d.]+)/im.exec(content);\n    if (versionMatch) {\n      result.version = versionMatch[1];\n    }\n    const minBrowserVersionMatch = /^\\s*Supports Chrome[\\D]+(\\d+)/im.exec(content);\n    if (minBrowserVersionMatch) {\n      result.minBrowserVersion = minBrowserVersionMatch[1];\n    }\n    return result;\n  }\n\n  /**\n   * Downloads chromedriver release notes and puts them\n   * into the dictionary argument\n   *\n   * @param {string} driverKey - Driver version plus archive name\n   * @param {string} notesUrl - The URL of chromedriver notes\n   * @param {Object} infoDict - The dictionary containing driver info.\n   * The method call mutates by merging `AdditionalDriverDetails`\n   * @throws {Error} if the release notes cannot be downloaded\n   */\n  async retrieveAdditionalDriverInfo (driverKey, notesUrl, infoDict) {\n    const notes = await retrieveData(notesUrl, {\n      'user-agent': 'appium',\n      accept: '*/*',\n    }, { timeout: this.timeout });\n    const { minBrowserVersion } = this.parseNotes(notes);\n    if (!minBrowserVersion) {\n      log.debug(`The driver '${driverKey}' does not contain valid release notes at ${notesUrl}. ` +\n        `Skipping it`);\n      return;\n    }\n    infoDict.minBrowserVersion = minBrowserVersion;\n  }\n\n  /**\n   * Parses chromedriver storage XML and stores\n   * the parsed results into `this.mapping`\n   *\n   * @param {DOMDocument} doc - The DOM representation\n   * of the chromedriver storage XML\n   * @param {boolean} shouldParseNotes [true] - If set to `true`\n   * then additional drivers information is going to be parsed\n   * and assigned to `this.mapping`\n   */\n  async parseStorageXml (doc, shouldParseNotes = true) {\n    const driverNodes = xpath.select(`//*[local-name(.)='Contents']`, doc);\n    log.debug(`Parsed ${driverNodes.length} entries from storage XML`);\n    if (_.isEmpty(driverNodes)) {\n      return;\n    }\n\n    const promises = [];\n    for (const driverNode of driverNodes) {\n      const key = extractNodeText(findChildNode(driverNode, 'Key'));\n      if (!_.includes(key, '/chromedriver_')) {\n        continue;\n      }\n\n      const etag = extractNodeText(findChildNode(driverNode, 'ETag'));\n      if (!etag) {\n        log.debug(`The entry '${key}' does not contain the checksum. Skipping it`);\n        continue;\n      }\n\n      const cdInfo = {\n        url: `${CD_CDN}/${key}`,\n        etag: _.trim(etag, '\"'),\n        version: _.first(key.split('/')),\n      };\n      this.mapping[key] = cdInfo;\n\n      const notesPath = `${cdInfo.version}/notes.txt`;\n      const isNotesPresent = !!driverNodes\n        .reduce((acc, node) => acc || findChildNode(node, 'Key', notesPath), false);\n      if (!isNotesPresent) {\n        cdInfo.minBrowserVersion = null;\n        if (shouldParseNotes) {\n          log.info(`The entry '${key}' does not contain any notes. Skipping it`);\n        }\n        continue;\n      } else if (!shouldParseNotes) {\n        continue;\n      }\n\n      promises.push(this.retrieveAdditionalDriverInfo(key, `${CD_CDN}/${notesPath}`, cdInfo));\n      if (promises.length % MAX_PARALLEL_DOWNLOADS === 0) {\n        await B.all(promises);\n      }\n    }\n    await B.all(promises);\n    log.info(`The total count of entries in the mapping: ${_.size(this.mapping)}`);\n  }\n\n  /**\n   * @typedef {Object} DriverDetails\n   * @property {string} url - The full url to the corresponding driver in\n   * the remote storage\n   * @property {string} etag - The CRC of the driver archive\n   * @property {string} version - Chromedriver version\n   */\n\n  /**\n   * @typedef {Object} ChromedriversMapping\n   * @property {DriverDetails} - The keys are unique driver identifiers\n   * (version/archive name). The corresponding values have `DriverDetails`\n   * containing chromedriver details\n   */\n\n  /**\n   * Retrieves chromedriver mapping from the storage\n   *\n   * @param {boolean} shouldParseNotes [true] - if set to `true`\n   * then additional chromedrivers info is going to be retrieved and\n   * parsed from release notes\n   * @returns {ChromedriversMapping}\n   */\n  async retrieveMapping (shouldParseNotes = true) {\n    const xml = await retrieveData(CD_CDN, {\n      'user-agent': 'appium',\n      accept: 'application/xml, */*',\n    }, { timeout: this.timeout });\n    const doc = new DOMParser().parseFromString(xml);\n    await this.parseStorageXml(doc, shouldParseNotes);\n    return _.cloneDeep(this.mapping);\n  }\n\n  /**\n   * Extracts downloaded chromedriver archive\n   * into the given destination\n   *\n   * @param {string} src - The source archive path\n   * @param {string} dst - The destination chromedriver path\n   */\n  async unzipDriver (src, dst) {\n    const tmpRoot = await tempDir.openDir();\n    try {\n      await zip.extractAllTo(src, tmpRoot);\n      const chromedriverPath = await fs.walkDir(tmpRoot, true, (itemPath, isDirectory) =>\n        !isDirectory && _.toLower(path.parse(itemPath).name) === 'chromedriver');\n      if (!chromedriverPath) {\n        throw new Error('The archive was unzipped properly, but we could not find any chromedriver executable');\n      }\n      log.debug(`Moving the extracted '${path.basename(chromedriverPath)}' to '${dst}'`);\n      await fs.mv(chromedriverPath, dst, {\n        mkdirp: true\n      });\n    } finally {\n      await fs.rimraf(tmpRoot);\n    }\n  }\n\n  /**\n   * @typedef {Object} OSInfo\n   * @property {string} name - The name of the host OS\n   * Can be either `mac`, `windows` or `linux`\n   * @property {string} arch - The architecture of the host OD.\n   * Can be either `32` or `64`\n   * @property {?string} hardwareName - The output of `uname -m` command\n   * on linux and mac systems. `null` on Windows\n   */\n\n  /**\n   * Filters `this.mapping` to only select matching\n   * chromedriver entries by operating system information\n   * and/or additional synchronization options (if provided)\n   *\n   * @param {?OSInfo} osInfo\n   * @param {?SyncOptions} opts\n   * @returns {Array<String>} The list of filtered chromedriver\n   * entry names (version/archive name)\n   */\n  selectMatchingDrivers (osInfo, opts = {}) {\n    const {\n      minBrowserVersion,\n      versions = [],\n    } = opts;\n    let driversToSync = _.keys(this.mapping);\n\n    if (!_.isEmpty(versions)) {\n      // Handle only selected versions if requested\n      log.debug(`Selecting chromedrivers whose versions match to ${versions}`);\n      driversToSync = driversToSync\n        .filter((cdName) => versions.includes(`${this.mapping[cdName].version}`));\n\n      log.debug(`Got ${util.pluralize('item', driversToSync.length, true)}`);\n      if (_.isEmpty(driversToSync)) {\n        return [];\n      }\n    }\n\n    if (!isNaN(minBrowserVersion)) {\n      // Only select drivers that support the current browser whose major version number equals to `minBrowserVersion`\n      const minBrowserVersionInt = parseInt(minBrowserVersion, 10);\n      log.debug(`Selecting chromedrivers whose minimum supported browser version matches to ${minBrowserVersionInt}`);\n      let closestMatchedVersionNumber = 0;\n      // Select the newest available and compatible chromedriver\n      for (const cdName of driversToSync) {\n        const currentMinBrowserVersion = parseInt(this.mapping[cdName].minBrowserVersion, 10);\n        if (!isNaN(currentMinBrowserVersion)\n            && currentMinBrowserVersion <= minBrowserVersionInt\n            && closestMatchedVersionNumber < currentMinBrowserVersion) {\n          closestMatchedVersionNumber = currentMinBrowserVersion;\n        }\n      }\n      driversToSync = driversToSync.filter((cdName) => `${this.mapping[cdName].minBrowserVersion}` ===\n        `${closestMatchedVersionNumber > 0 ? closestMatchedVersionNumber : minBrowserVersionInt}`);\n\n      log.debug(`Got ${util.pluralize('item', driversToSync.length, true)}`);\n      if (_.isEmpty(driversToSync)) {\n        return [];\n      }\n      log.debug(`Will select candidate ${util.pluralize('driver', driversToSync.length)} ` +\n        `versioned as '${_.uniq(driversToSync.map((cdName) => this.mapping[cdName].version))}'`);\n    }\n\n    if (!_.isEmpty(osInfo)) {\n      // Filter out drivers for unsupported system architectures\n      let {name, arch, hardwareName} = osInfo;\n      if (arch === X64 && !driversToSync.some((cdName) => cdName.includes(`_${name}${X64}`))) {\n        // Fall back to x86 build if x64 one is not available for the given OS\n        arch = X86;\n      }\n      if (name === OS.mac && _.includes(hardwareName, 'arm')\n          && driversToSync.some((cdName) => cdName.includes(M1_ARCH_SUFFIX))) {\n        // prefer executable for M1 arch if present\n        arch += M1_ARCH_SUFFIX;\n      }\n      log.debug(`Selecting chromedrivers whose platform matches to ${name}${arch}`);\n      const platformRe = new RegExp(`(\\\\b|_)${name}${arch}\\\\b`);\n      driversToSync = driversToSync.filter((cdName) => platformRe.test(cdName));\n      log.debug(`Got ${util.pluralize('item', driversToSync.length, true)}`);\n    }\n\n    return driversToSync;\n  }\n\n  /**\n   * Retrieves the given chromedriver from the storage\n   * and unpacks it into `this.chromedriverDir` folder\n   *\n   * @param {number} index - The unique driver index\n   * @param {string} driverKey - The driver key in `this.mapping`\n   * @param {string} archivesRoot - The temporary folder path to extract\n   * downloaded archives to\n   * @param {boolean} isStrict [true] - Whether to throw an error (`true`)\n   * or return a boolean result if the driver retrieval process fails\n   * @throws {Error} if there was a failure while retrieving the driver\n   * and `isStrict` is set to `true`\n   * @returns {boolean} if `true` then the chromedriver is successfully\n   * downloaded and extracted.\n   */\n  async retrieveDriver (index, driverKey, archivesRoot, isStrict = false) {\n    const { url, etag, version } = this.mapping[driverKey];\n    const archivePath = path.resolve(archivesRoot, `${index}.zip`);\n    log.debug(`Retrieving '${url}' to '${archivePath}'`);\n    try {\n      await net.downloadFile(url, archivePath, {\n        isMetered: false,\n        timeout: TIMEOUT_MS\n      });\n    } catch (e) {\n      const msg = `Cannot download chromedriver archive. Original error: ${e.message}`;\n      if (isStrict) {\n        throw new Error(msg);\n      }\n      log.error(msg);\n      return false;\n    }\n    if (!await isCrcOk(archivePath, etag)) {\n      const msg = `The checksum for the downloaded chromedriver '${driverKey}' did not match`;\n      if (isStrict) {\n        throw new Error(msg);\n      }\n      log.error(msg);\n      return false;\n    }\n    const fileName = `${path.parse(url).name}_v${version}` +\n      (system.isWindows() ? '.exe' : '');\n    const targetPath = path.resolve(this.chromedriverDir, fileName);\n    try {\n      await this.unzipDriver(archivePath, targetPath);\n      await fs.chmod(targetPath, 0o755);\n      log.debug(`Permissions of the file '${targetPath}' have been changed to 755`);\n    } catch (e) {\n      if (isStrict) {\n        throw e;\n      }\n      log.error(e.message);\n      return false;\n    }\n    return true;\n  }\n\n  /**\n   * @typedef {Object} SyncOptions\n   * @property {Array<String>} versions - The list of chromedriver\n   * versions to sync. If empty (the default value) then all available\n   * chromedrivers are going to be downloaded and extracted\n   * @property {string|number} minBrowserVersion - The minumum supported\n   * Chrome version that downloaded chromedrivers should support. Can match\n   * multiple drivers.\n   * @property {?OSInfo} osInfo - System information used to filter out\n   * the list of the retrieved drivers. If not provided then the script\n   * will try to retrieve it.\n   */\n\n  /**\n   * Retrieves chromedrivers from the remote storage\n   * to the local file system\n   *\n   * @param {?SyncOptions} opts\n   * @throws {Error} if there was a problem while retrieving\n   * the drivers\n   * @returns {Array<String} The list of successfully synchronized driver keys\n   */\n  async syncDrivers (opts = {}) {\n    if (_.isEmpty(this.mapping)) {\n      await this.retrieveMapping(!!opts.minBrowserVersion);\n    }\n    if (_.isEmpty(this.mapping)) {\n      throw new Error('Cannot retrieve chromedrivers mapping from Google storage');\n    }\n\n    const driversToSync = this.selectMatchingDrivers(opts.osInfo ?? await getOsInfo(), opts);\n    if (_.isEmpty(driversToSync)) {\n      log.debug(`There are no drivers to sync. Exiting`);\n      return [];\n    }\n    log.debug(`Got ${util.pluralize('driver', driversToSync.length, true)} to sync: ` +\n      JSON.stringify(driversToSync, null, 2));\n\n    const synchronizedDrivers = [];\n    const promises = [];\n    const archivesRoot = await tempDir.openDir();\n    try {\n      for (const [idx, driverKey] of driversToSync.entries()) {\n        promises.push((async () => {\n          if (await this.retrieveDriver(idx, driverKey, archivesRoot, !_.isEmpty(opts))) {\n            synchronizedDrivers.push(driverKey);\n          }\n        })());\n\n        if (promises.length % MAX_PARALLEL_DOWNLOADS === 0) {\n          await B.all(promises);\n        }\n      }\n      await B.all(promises);\n    } finally {\n      await fs.rimraf(archivesRoot);\n    }\n    if (!_.isEmpty(synchronizedDrivers)) {\n      log.info(`Successfully synchronized ` +\n        `${util.pluralize('chromedriver', synchronizedDrivers.length, true)}`);\n    } else {\n      log.info(`No chromedrivers were synchronized`);\n    }\n    return synchronizedDrivers;\n  }\n}\n\n\nexport default ChromedriverStorageClient;\n"],"file":"lib/storage-client.js","sourceRoot":"../.."}
@@ -17,7 +17,7 @@ require("source-map-support/register");
17
17
 
18
18
  var _lodash = _interopRequireDefault(require("lodash"));
19
19
 
20
- var _appiumSupport = require("appium-support");
20
+ var _support = require("@appium/support");
21
21
 
22
22
  var _path = _interopRequireDefault(require("path"));
23
23
 
@@ -76,7 +76,7 @@ function getChromedriverDir(osName = getOsName()) {
76
76
  async function getChromedriverBinaryPath(osName = getOsName()) {
77
77
  const rootDir = getChromedriverDir(osName);
78
78
  const pathSuffix = osName === OS.windows ? '.exe' : '';
79
- const paths = await _appiumSupport.fs.glob(`${CD_EXECUTABLE_PREFIX}*${pathSuffix}`, {
79
+ const paths = await _support.fs.glob(`${CD_EXECUTABLE_PREFIX}*${pathSuffix}`, {
80
80
  cwd: rootDir,
81
81
  absolute: true,
82
82
  nocase: true,
@@ -100,11 +100,11 @@ async function retrieveData(url, headers, opts = {}) {
100
100
  }
101
101
 
102
102
  const getOsName = _lodash.default.memoize(function getOsName() {
103
- if (_appiumSupport.system.isWindows()) {
103
+ if (_support.system.isWindows()) {
104
104
  return OS.windows;
105
105
  }
106
106
 
107
- if (_appiumSupport.system.isMac()) {
107
+ if (_support.system.isMac()) {
108
108
  return OS.mac;
109
109
  }
110
110
 
@@ -116,12 +116,12 @@ exports.getOsName = getOsName;
116
116
  const getOsInfo = _lodash.default.memoize(async function getOsInfo() {
117
117
  return {
118
118
  name: getOsName(),
119
- arch: await _appiumSupport.system.arch(),
120
- hardwareName: _appiumSupport.system.isWindows() ? null : _lodash.default.trim(await (0, _teen_process.exec)('uname', ['-m']))
119
+ arch: await _support.system.arch(),
120
+ hardwareName: _support.system.isWindows() ? null : _lodash.default.trim(await (0, _teen_process.exec)('uname', ['-m']))
121
121
  };
122
122
  });
123
123
 
124
124
  exports.getOsInfo = getOsInfo;require('source-map-support').install();
125
125
 
126
126
 
127
- //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/utils.js"],"names":["rootDir","path","basename","__dirname","resolve","process","env","NO_PRECOMPILE","CHROMEDRIVER_CHROME_MAPPING","require","CD_VER","npm_config_chromedriver_version","CHROMEDRIVER_VERSION","getMostRecentChromedriver","CD_BASE_DIR","CD_CDN","npm_config_chromedriver_cdnurl","CHROMEDRIVER_CDNURL","OS","linux","windows","mac","X64","X86","M1_ARCH_SUFFIX","CD_EXECUTABLE_PREFIX","mapping","_","isEmpty","Error","last","keys","sort","compareVersions","getChromeVersion","adb","bundleId","versionName","getPackageInfo","getChromedriverDir","osName","getOsName","getChromedriverBinaryPath","pathSuffix","paths","fs","glob","cwd","absolute","nocase","nodir","strict","first","retrieveData","url","headers","opts","timeout","responseType","data","memoize","system","isWindows","isMac","getOsInfo","name","arch","hardwareName","trim"],"mappings":"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","sourcesContent":["import _ from 'lodash';\nimport { system, fs } from 'appium-support';\nimport path from 'path';\nimport compareVersions from 'compare-versions';\nimport axios from 'axios';\nimport { exec } from 'teen_process';\n\n\nconst rootDir = path.basename(__dirname) === 'lib'\n  ? path.resolve(__dirname, process.env.NO_PRECOMPILE ? '..' : '../..')\n  : __dirname;\n// Chromedriver version: minimum Chrome version\nconst CHROMEDRIVER_CHROME_MAPPING = require(path.resolve(rootDir, 'config', 'mapping.json'));\n\nconst CD_VER = process.env.npm_config_chromedriver_version\n  || process.env.CHROMEDRIVER_VERSION\n  || getMostRecentChromedriver();\nconst CD_BASE_DIR = path.resolve(__dirname, '..', '..', 'chromedriver');\nconst CD_CDN = process.env.npm_config_chromedriver_cdnurl\n  || process.env.CHROMEDRIVER_CDNURL\n  || 'https://chromedriver.storage.googleapis.com';\nconst OS = {\n  linux: 'linux',\n  windows: 'win',\n  mac: 'mac'\n};\nconst X64 = '64';\nconst X86 = '32';\nconst M1_ARCH_SUFFIX = '_m1';\nconst CD_EXECUTABLE_PREFIX = 'chromedriver';\n\n\nfunction getMostRecentChromedriver (mapping = CHROMEDRIVER_CHROME_MAPPING) {\n  if (_.isEmpty(mapping)) {\n    throw new Error('Unable to get most recent Chromedriver version from empty mapping');\n  }\n  return _.last(_.keys(mapping).sort(compareVersions));\n}\n\nasync function getChromeVersion (adb, bundleId) {\n  const {versionName} = await adb.getPackageInfo(bundleId);\n  return versionName;\n}\n\nfunction getChromedriverDir (osName = getOsName()) {\n  return path.resolve(CD_BASE_DIR, osName);\n}\n\nasync function getChromedriverBinaryPath (osName = getOsName()) {\n  const rootDir = getChromedriverDir(osName);\n  const pathSuffix = osName === OS.windows ? '.exe' : '';\n  const paths = await fs.glob(`${CD_EXECUTABLE_PREFIX}*${pathSuffix}`, {\n    cwd: rootDir,\n    absolute: true,\n    nocase: true,\n    nodir: true,\n    strict: false,\n  });\n  return _.isEmpty(paths)\n    ? path.resolve(rootDir, `${CD_EXECUTABLE_PREFIX}${pathSuffix}`)\n    : _.first(paths);\n}\n\nasync function retrieveData (url, headers, opts = {}) {\n  const {\n    timeout = 5000,\n    responseType = 'text',\n  } = opts;\n  return (await axios({\n    url,\n    headers,\n    timeout,\n    responseType,\n  })).data;\n}\n\nconst getOsName = _.memoize(function getOsName () {\n  if (system.isWindows()) {\n    return OS.windows;\n  }\n  if (system.isMac()) {\n    return OS.mac;\n  }\n  return OS.linux;\n});\n\nconst getOsInfo = _.memoize(async function getOsInfo () {\n  return {\n    name: getOsName(),\n    arch: await system.arch(),\n    hardwareName: system.isWindows() ? null : _.trim(await exec('uname', ['-m'])),\n  };\n});\n\n\nexport {\n  getChromeVersion, getChromedriverDir, getChromedriverBinaryPath, getOsName,\n  CD_BASE_DIR, CD_CDN, CD_VER, CHROMEDRIVER_CHROME_MAPPING, getMostRecentChromedriver,\n  retrieveData, getOsInfo, OS, X64, X86, M1_ARCH_SUFFIX,\n};\n"],"file":"lib/utils.js","sourceRoot":"../.."}
127
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/utils.js"],"names":["rootDir","path","basename","__dirname","resolve","process","env","NO_PRECOMPILE","CHROMEDRIVER_CHROME_MAPPING","require","CD_VER","npm_config_chromedriver_version","CHROMEDRIVER_VERSION","getMostRecentChromedriver","CD_BASE_DIR","CD_CDN","npm_config_chromedriver_cdnurl","CHROMEDRIVER_CDNURL","OS","linux","windows","mac","X64","X86","M1_ARCH_SUFFIX","CD_EXECUTABLE_PREFIX","mapping","_","isEmpty","Error","last","keys","sort","compareVersions","getChromeVersion","adb","bundleId","versionName","getPackageInfo","getChromedriverDir","osName","getOsName","getChromedriverBinaryPath","pathSuffix","paths","fs","glob","cwd","absolute","nocase","nodir","strict","first","retrieveData","url","headers","opts","timeout","responseType","data","memoize","system","isWindows","isMac","getOsInfo","name","arch","hardwareName","trim"],"mappings":"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","sourcesContent":["import _ from 'lodash';\nimport { system, fs } from '@appium/support';\nimport path from 'path';\nimport compareVersions from 'compare-versions';\nimport axios from 'axios';\nimport { exec } from 'teen_process';\n\n\nconst rootDir = path.basename(__dirname) === 'lib'\n  ? path.resolve(__dirname, process.env.NO_PRECOMPILE ? '..' : '../..')\n  : __dirname;\n// Chromedriver version: minimum Chrome version\nconst CHROMEDRIVER_CHROME_MAPPING = require(path.resolve(rootDir, 'config', 'mapping.json'));\n\nconst CD_VER = process.env.npm_config_chromedriver_version\n  || process.env.CHROMEDRIVER_VERSION\n  || getMostRecentChromedriver();\nconst CD_BASE_DIR = path.resolve(__dirname, '..', '..', 'chromedriver');\nconst CD_CDN = process.env.npm_config_chromedriver_cdnurl\n  || process.env.CHROMEDRIVER_CDNURL\n  || 'https://chromedriver.storage.googleapis.com';\nconst OS = {\n  linux: 'linux',\n  windows: 'win',\n  mac: 'mac'\n};\nconst X64 = '64';\nconst X86 = '32';\nconst M1_ARCH_SUFFIX = '_m1';\nconst CD_EXECUTABLE_PREFIX = 'chromedriver';\n\n\nfunction getMostRecentChromedriver (mapping = CHROMEDRIVER_CHROME_MAPPING) {\n  if (_.isEmpty(mapping)) {\n    throw new Error('Unable to get most recent Chromedriver version from empty mapping');\n  }\n  return _.last(_.keys(mapping).sort(compareVersions));\n}\n\nasync function getChromeVersion (adb, bundleId) {\n  const {versionName} = await adb.getPackageInfo(bundleId);\n  return versionName;\n}\n\nfunction getChromedriverDir (osName = getOsName()) {\n  return path.resolve(CD_BASE_DIR, osName);\n}\n\nasync function getChromedriverBinaryPath (osName = getOsName()) {\n  const rootDir = getChromedriverDir(osName);\n  const pathSuffix = osName === OS.windows ? '.exe' : '';\n  const paths = await fs.glob(`${CD_EXECUTABLE_PREFIX}*${pathSuffix}`, {\n    cwd: rootDir,\n    absolute: true,\n    nocase: true,\n    nodir: true,\n    strict: false,\n  });\n  return _.isEmpty(paths)\n    ? path.resolve(rootDir, `${CD_EXECUTABLE_PREFIX}${pathSuffix}`)\n    : _.first(paths);\n}\n\nasync function retrieveData (url, headers, opts = {}) {\n  const {\n    timeout = 5000,\n    responseType = 'text',\n  } = opts;\n  return (await axios({\n    url,\n    headers,\n    timeout,\n    responseType,\n  })).data;\n}\n\nconst getOsName = _.memoize(function getOsName () {\n  if (system.isWindows()) {\n    return OS.windows;\n  }\n  if (system.isMac()) {\n    return OS.mac;\n  }\n  return OS.linux;\n});\n\nconst getOsInfo = _.memoize(async function getOsInfo () {\n  return {\n    name: getOsName(),\n    arch: await system.arch(),\n    hardwareName: system.isWindows() ? null : _.trim(await exec('uname', ['-m'])),\n  };\n});\n\n\nexport {\n  getChromeVersion, getChromedriverDir, getChromedriverBinaryPath, getOsName,\n  CD_BASE_DIR, CD_CDN, CD_VER, CHROMEDRIVER_CHROME_MAPPING, getMostRecentChromedriver,\n  retrieveData, getOsInfo, OS, X64, X86, M1_ARCH_SUFFIX,\n};\n"],"file":"lib/utils.js","sourceRoot":"../.."}
@@ -1,4 +1,9 @@
1
1
  {
2
+ "100.0.4896.60": "100.0.4896.60",
3
+ "99.0.4844.51": "99.0.4844.51",
4
+ "98.0.4758.102": "98.0.4758.102",
5
+ "98.0.4758.80": "98.0.4758.80",
6
+ "97.0.4692.71": "97.0.4692.71",
2
7
  "96.0.4664.45": "96.0.4664.45",
3
8
  "95.0.4638.69": "95.0.4638.69",
4
9
  "95.0.4638.54": "95.0.4638.54",
@@ -1,9 +1,9 @@
1
1
  // transpile:main
2
2
 
3
3
  import events from 'events';
4
- import { JWProxy, PROTOCOLS } from 'appium-base-driver';
4
+ import { JWProxy, PROTOCOLS } from '@appium/base-driver';
5
5
  import cp from 'child_process';
6
- import { system, fs, logger, util } from 'appium-support';
6
+ import { system, fs, logger, util } from '@appium/support';
7
7
  import { retryInterval, asyncmap } from 'asyncbox';
8
8
  import { SubProcess, exec } from 'teen_process';
9
9
  import B from 'bluebird';
@@ -69,7 +69,10 @@ class Chromedriver extends events.EventEmitter {
69
69
  this.bundleId = bundleId;
70
70
  this.executableVerified = false;
71
71
  this.state = Chromedriver.STATE_STOPPED;
72
- this.jwproxy = new JWProxy({server: this.proxyHost, port: this.proxyPort});
72
+ this.jwproxy = new JWProxy({
73
+ server: this.proxyHost,
74
+ port: this.proxyPort
75
+ });
73
76
  this.verbose = verbose;
74
77
  this.logPath = logPath;
75
78
  this.disableBuildCheck = !!disableBuildCheck;
@@ -432,7 +435,7 @@ class Chromedriver extends events.EventEmitter {
432
435
  this.changeState(Chromedriver.STATE_STARTING);
433
436
  }
434
437
 
435
- const args = ['--url-base=wd/hub', `--port=${this.proxyPort}`];
438
+ const args = [`--port=${this.proxyPort}`];
436
439
  if (this.adb && this.adb.adbPort) {
437
440
  args.push(`--adb-port=${this.adb.adbPort}`);
438
441
  }
@@ -598,14 +601,18 @@ class Chromedriver extends events.EventEmitter {
598
601
  if (emitStates) {
599
602
  this.changeState(Chromedriver.STATE_STOPPING);
600
603
  }
601
- try {
602
- await this.jwproxy.command('', 'DELETE');
603
- await this.proc.stop('SIGTERM', 20000);
604
- if (emitStates) {
605
- this.changeState(Chromedriver.STATE_STOPPED);
604
+ const runSafeStep = async (f) => {
605
+ try {
606
+ return await f();
607
+ } catch (e) {
608
+ log.warn(e.message);
609
+ log.debug(e.stack);
606
610
  }
607
- } catch (e) {
608
- log.error(e);
611
+ };
612
+ await runSafeStep(() => this.jwproxy.command('', 'DELETE'));
613
+ await runSafeStep(() => this.proc.stop('SIGTERM', 20000));
614
+ if (emitStates) {
615
+ this.changeState(Chromedriver.STATE_STOPPED);
609
616
  }
610
617
  }
611
618
 
package/lib/install.js CHANGED
@@ -1,4 +1,4 @@
1
- import { fs, mkdirp } from 'appium-support';
1
+ import { fs, mkdirp } from '@appium/support';
2
2
  import ChromedriverStorageClient from './storage-client';
3
3
  import {
4
4
  CD_CDN, CD_VER, retrieveData, getOsInfo, getChromedriverDir,
@@ -1,5 +1,5 @@
1
1
  import _ from 'lodash';
2
- import { isStandardCap } from 'appium-base-driver';
2
+ import { isStandardCap } from '@appium/base-driver';
3
3
 
4
4
  const W3C_PREFIX = 'goog:';
5
5
 
@@ -7,7 +7,7 @@ import xpath from 'xpath';
7
7
  import { DOMParser } from '@xmldom/xmldom';
8
8
  import B from 'bluebird';
9
9
  import path from 'path';
10
- import { system, fs, logger, tempDir, zip, util, net } from 'appium-support';
10
+ import { system, fs, logger, tempDir, zip, util, net } from '@appium/support';
11
11
 
12
12
 
13
13
  const TIMEOUT_MS = 15000;
package/lib/utils.js CHANGED
@@ -1,5 +1,5 @@
1
1
  import _ from 'lodash';
2
- import { system, fs } from 'appium-support';
2
+ import { system, fs } from '@appium/support';
3
3
  import path from 'path';
4
4
  import compareVersions from 'compare-versions';
5
5
  import axios from 'axios';
package/package.json CHANGED
@@ -6,7 +6,7 @@
6
6
  "chrome",
7
7
  "android"
8
8
  ],
9
- "version": "4.28.0",
9
+ "version": "5.0.2",
10
10
  "author": "appium",
11
11
  "license": "Apache-2.0",
12
12
  "repository": {
@@ -35,15 +35,15 @@
35
35
  "config/mapping.json"
36
36
  ],
37
37
  "dependencies": {
38
+ "@appium/base-driver": "^8.0.0",
39
+ "@appium/support": "^2.55.3",
38
40
  "@babel/runtime": "^7.0.0",
39
41
  "@xmldom/xmldom": "^0.x",
40
- "appium-base-driver": "^7.1.0",
41
- "appium-support": "^2.46.0",
42
42
  "asyncbox": "^2.0.2",
43
43
  "axios": "^0.x",
44
44
  "bluebird": "^3.5.1",
45
45
  "compare-versions": "^3.4.0",
46
- "fancy-log": "^1.3.2",
46
+ "fancy-log": "^2.0.0",
47
47
  "lodash": "^4.17.4",
48
48
  "semver": "^7.0.0",
49
49
  "source-map-support": "^0.x",
@@ -71,13 +71,16 @@
71
71
  "lint:fix": "gulp lint --fix"
72
72
  },
73
73
  "devDependencies": {
74
- "appium-gulp-plugins": "^5.4.0",
74
+ "@appium/gulp-plugins": "^6.0.0",
75
+ "@appium/eslint-config-appium": "^5.0.0",
76
+ "@appium/test-support": "^1.0.0",
77
+ "@babel/core": "^7.16.0",
78
+ "@babel/eslint-parser": "^7.16.3",
75
79
  "chai": "^4.1.2",
76
80
  "chai-as-promised": "^7.1.1",
77
- "eslint-config-appium": "^4.0.1",
78
81
  "gulp": "^4.0.0",
79
82
  "mocha": "^9.0.0",
80
83
  "pre-commit": "^1.1.3",
81
- "sinon": "^12.0.0"
84
+ "sinon": "^13.0.0"
82
85
  }
83
86
  }
@@ -1,82 +0,0 @@
1
- #!/usr/bin/env node
2
- "use strict";
3
-
4
- require("source-map-support/register");
5
-
6
- const fs = require('fs');
7
-
8
- const path = require('path');
9
-
10
- const log = require('fancy-log');
11
-
12
- const _ = require('lodash');
13
-
14
- const BUILD_RETRIES = 200;
15
- const BUILD_RETRY_INTERVAL = 1000;
16
- const BUILD_PATH = path.join(__dirname, 'build', 'lib', 'install.js');
17
-
18
- function waitForDeps(cb) {
19
- let i = 0;
20
-
21
- function check() {
22
- i++;
23
-
24
- try {
25
- require(BUILD_PATH);
26
-
27
- cb();
28
- } catch (err) {
29
- if (err.message.includes(`Cannot find module '${BUILD_PATH}'`)) {
30
- log.warn(`Project does not appear to be built yet. Please run 'npm run chromedriver' first.`);
31
- return cb(new Error(`Could not install module: ${err.message}`));
32
- }
33
-
34
- log.warn(`Error trying to install Chromedriver binary. Waiting ${BUILD_RETRY_INTERVAL}ms and trying again: ${err.message}`);
35
-
36
- if (i <= BUILD_RETRIES) {
37
- setTimeout(check, BUILD_RETRY_INTERVAL);
38
- } else {
39
- cb(new Error(`Could not import installation module: ${err.message}`));
40
- }
41
- }
42
- }
43
-
44
- check();
45
- }
46
-
47
- function main() {
48
- if (!_.isEmpty(process.env.APPIUM_SKIP_CHROMEDRIVER_INSTALL) || !_.isEmpty(process.env.npm_config_chromedriver_skip_install)) {
49
- log.warn(`'APPIUM_SKIP_CHROMEDRIVER_INSTALL' environment variable set, or '--chromedriver-skip-install' flag set.`);
50
- log.warn(`Skipping Chromedriver installation. Android web/hybrid testing will not be possible`);
51
- return;
52
- }
53
-
54
- waitForDeps(function wait(err) {
55
- if (err) {
56
- log.warn(`Unable to import install script: ${err.message}`);
57
- log.warn(`Re-run 'npm run chromedriver' manually.`);
58
- return;
59
- }
60
-
61
- fs.stat(BUILD_PATH, function installScriptExists(err) {
62
- if (err) {
63
- log.warn(`NOTE: Run 'npx gulp transpile' before using`);
64
- return;
65
- }
66
-
67
- require(BUILD_PATH).doInstall().catch(function installError(err) {
68
- log.error(`Error installing Chromedriver: ${err.message}`);
69
- log.error(err.stack ? err.stack : err);
70
- log.error(`Downloading Chromedriver can be skipped by using the ` + `'--chromedriver-skip-install' flag or ` + `setting the 'APPIUM_SKIP_CHROMEDRIVER_INSTALL' environment ` + `variable.`);
71
- process.exit(1);
72
- });
73
- });
74
- });
75
- }
76
-
77
- if (require.main === module) {
78
- main();
79
- }require('source-map-support').install();
80
-
81
-
82
- //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluc3RhbGwtbnBtLmpzIl0sIm5hbWVzIjpbImZzIiwicmVxdWlyZSIsInBhdGgiLCJsb2ciLCJfIiwiQlVJTERfUkVUUklFUyIsIkJVSUxEX1JFVFJZX0lOVEVSVkFMIiwiQlVJTERfUEFUSCIsImpvaW4iLCJfX2Rpcm5hbWUiLCJ3YWl0Rm9yRGVwcyIsImNiIiwiaSIsImNoZWNrIiwiZXJyIiwibWVzc2FnZSIsImluY2x1ZGVzIiwid2FybiIsIkVycm9yIiwic2V0VGltZW91dCIsIm1haW4iLCJpc0VtcHR5IiwicHJvY2VzcyIsImVudiIsIkFQUElVTV9TS0lQX0NIUk9NRURSSVZFUl9JTlNUQUxMIiwibnBtX2NvbmZpZ19jaHJvbWVkcml2ZXJfc2tpcF9pbnN0YWxsIiwid2FpdCIsInN0YXQiLCJpbnN0YWxsU2NyaXB0RXhpc3RzIiwiZG9JbnN0YWxsIiwiY2F0Y2giLCJpbnN0YWxsRXJyb3IiLCJlcnJvciIsInN0YWNrIiwiZXhpdCIsIm1vZHVsZSJdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7O0FBR0EsTUFBTUEsRUFBRSxHQUFHQyxPQUFPLENBQUMsSUFBRCxDQUFsQjs7QUFDQSxNQUFNQyxJQUFJLEdBQUdELE9BQU8sQ0FBQyxNQUFELENBQXBCOztBQUNBLE1BQU1FLEdBQUcsR0FBR0YsT0FBTyxDQUFDLFdBQUQsQ0FBbkI7O0FBQ0EsTUFBTUcsQ0FBQyxHQUFHSCxPQUFPLENBQUMsUUFBRCxDQUFqQjs7QUFVQSxNQUFNSSxhQUFhLEdBQUcsR0FBdEI7QUFDQSxNQUFNQyxvQkFBb0IsR0FBRyxJQUE3QjtBQUVBLE1BQU1DLFVBQVUsR0FBR0wsSUFBSSxDQUFDTSxJQUFMLENBQVVDLFNBQVYsRUFBcUIsT0FBckIsRUFBOEIsS0FBOUIsRUFBcUMsWUFBckMsQ0FBbkI7O0FBRUEsU0FBU0MsV0FBVCxDQUFzQkMsRUFBdEIsRUFBMEI7QUFHeEIsTUFBSUMsQ0FBQyxHQUFHLENBQVI7O0FBQ0EsV0FBU0MsS0FBVCxHQUFrQjtBQUNoQkQsSUFBQUEsQ0FBQzs7QUFDRCxRQUFJO0FBQ0ZYLE1BQUFBLE9BQU8sQ0FBQ00sVUFBRCxDQUFQOztBQUNBSSxNQUFBQSxFQUFFO0FBQ0gsS0FIRCxDQUdFLE9BQU9HLEdBQVAsRUFBWTtBQUNaLFVBQUlBLEdBQUcsQ0FBQ0MsT0FBSixDQUFZQyxRQUFaLENBQXNCLHVCQUFzQlQsVUFBVyxHQUF2RCxDQUFKLEVBQWdFO0FBQzlESixRQUFBQSxHQUFHLENBQUNjLElBQUosQ0FBVSxtRkFBVjtBQUNBLGVBQU9OLEVBQUUsQ0FBQyxJQUFJTyxLQUFKLENBQVcsNkJBQTRCSixHQUFHLENBQUNDLE9BQVEsRUFBbkQsQ0FBRCxDQUFUO0FBQ0Q7O0FBQ0RaLE1BQUFBLEdBQUcsQ0FBQ2MsSUFBSixDQUFVLHdEQUF1RFgsb0JBQXFCLHdCQUF1QlEsR0FBRyxDQUFDQyxPQUFRLEVBQXpIOztBQUNBLFVBQUlILENBQUMsSUFBSVAsYUFBVCxFQUF3QjtBQUN0QmMsUUFBQUEsVUFBVSxDQUFDTixLQUFELEVBQVFQLG9CQUFSLENBQVY7QUFDRCxPQUZELE1BRU87QUFDTEssUUFBQUEsRUFBRSxDQUFDLElBQUlPLEtBQUosQ0FBVyx5Q0FBd0NKLEdBQUcsQ0FBQ0MsT0FBUSxFQUEvRCxDQUFELENBQUY7QUFDRDtBQUNGO0FBQ0Y7O0FBQ0RGLEVBQUFBLEtBQUs7QUFDTjs7QUFFRCxTQUFTTyxJQUFULEdBQWlCO0FBRWYsTUFBSSxDQUFDaEIsQ0FBQyxDQUFDaUIsT0FBRixDQUFVQyxPQUFPLENBQUNDLEdBQVIsQ0FBWUMsZ0NBQXRCLENBQUQsSUFBNEQsQ0FBQ3BCLENBQUMsQ0FBQ2lCLE9BQUYsQ0FBVUMsT0FBTyxDQUFDQyxHQUFSLENBQVlFLG9DQUF0QixDQUFqRSxFQUE4SDtBQUM1SHRCLElBQUFBLEdBQUcsQ0FBQ2MsSUFBSixDQUFVLHlHQUFWO0FBQ0FkLElBQUFBLEdBQUcsQ0FBQ2MsSUFBSixDQUFVLHFGQUFWO0FBQ0E7QUFDRDs7QUFHRFAsRUFBQUEsV0FBVyxDQUFDLFNBQVNnQixJQUFULENBQWVaLEdBQWYsRUFBb0I7QUFDOUIsUUFBSUEsR0FBSixFQUFTO0FBRVBYLE1BQUFBLEdBQUcsQ0FBQ2MsSUFBSixDQUFVLG9DQUFtQ0gsR0FBRyxDQUFDQyxPQUFRLEVBQXpEO0FBQ0FaLE1BQUFBLEdBQUcsQ0FBQ2MsSUFBSixDQUFVLHlDQUFWO0FBQ0E7QUFDRDs7QUFDRGpCLElBQUFBLEVBQUUsQ0FBQzJCLElBQUgsQ0FBUXBCLFVBQVIsRUFBb0IsU0FBU3FCLG1CQUFULENBQThCZCxHQUE5QixFQUFtQztBQUNyRCxVQUFJQSxHQUFKLEVBQVM7QUFFUFgsUUFBQUEsR0FBRyxDQUFDYyxJQUFKLENBQVUsNkNBQVY7QUFDQTtBQUNEOztBQUNEaEIsTUFBQUEsT0FBTyxDQUFDTSxVQUFELENBQVAsQ0FBb0JzQixTQUFwQixHQUFnQ0MsS0FBaEMsQ0FBc0MsU0FBU0MsWUFBVCxDQUF1QmpCLEdBQXZCLEVBQTRCO0FBQ2hFWCxRQUFBQSxHQUFHLENBQUM2QixLQUFKLENBQVcsa0NBQWlDbEIsR0FBRyxDQUFDQyxPQUFRLEVBQXhEO0FBQ0FaLFFBQUFBLEdBQUcsQ0FBQzZCLEtBQUosQ0FBVWxCLEdBQUcsQ0FBQ21CLEtBQUosR0FBWW5CLEdBQUcsQ0FBQ21CLEtBQWhCLEdBQXdCbkIsR0FBbEM7QUFDQVgsUUFBQUEsR0FBRyxDQUFDNkIsS0FBSixDQUFXLHVEQUFELEdBQ0Msd0NBREQsR0FFQyw2REFGRCxHQUdDLFdBSFg7QUFJQVYsUUFBQUEsT0FBTyxDQUFDWSxJQUFSLENBQWEsQ0FBYjtBQUNELE9BUkQ7QUFTRCxLQWZEO0FBZ0JELEdBdkJVLENBQVg7QUF3QkQ7O0FBRUQsSUFBSWpDLE9BQU8sQ0FBQ21CLElBQVIsS0FBaUJlLE1BQXJCLEVBQTZCO0FBQzNCZixFQUFBQSxJQUFJO0FBQ0wiLCJzb3VyY2VzQ29udGVudCI6WyIjIS91c3IvYmluL2VudiBub2RlXG4vKiBlc2xpbnQtZGlzYWJsZSBwcm9taXNlL3ByZWZlci1hd2FpdC10by1jYWxsYmFja3MgKi9cblxuY29uc3QgZnMgPSByZXF1aXJlKCdmcycpO1xuY29uc3QgcGF0aCA9IHJlcXVpcmUoJ3BhdGgnKTtcbmNvbnN0IGxvZyA9IHJlcXVpcmUoJ2ZhbmN5LWxvZycpO1xuY29uc3QgXyA9IHJlcXVpcmUoJ2xvZGFzaCcpO1xuXG5cbi8qKlxuICogQmVjYXVzZSBvZiB0aGUgd2F5IG5wbSBsaWZlY3ljbGUgc2NyaXB0cyB3b3JrLCBvbiBhIGxvY2FsIGluc3RhbGwsIHdoZW4gdGhlXG4gKiBjb2RlIGhhcyBub3QgYmVlbiB0cmFucGlsZWQgeWV0IChpLmUuLCB0aGUgZmlyc3QgdGltZSwgb3IgYWZ0ZXIgdGhlICdidWlsZCdcbiAqIGRpcmVjdG9yeSBoYXMgYmVlbiBkZWxldGVkKSB0aGUgZG93bmxvYWQgKip3aWxsKiogZmFpbCwgYW5kICducG0gcnVuIGNocm9tZWRyaXZlcidcbiAqIHdpbGwgbmVlZCB0byBiZSBydW4uXG4gKi9cblxuY29uc3QgQlVJTERfUkVUUklFUyA9IDIwMDtcbmNvbnN0IEJVSUxEX1JFVFJZX0lOVEVSVkFMID0gMTAwMDtcblxuY29uc3QgQlVJTERfUEFUSCA9IHBhdGguam9pbihfX2Rpcm5hbWUsICdidWlsZCcsICdsaWInLCAnaW5zdGFsbC5qcycpO1xuXG5mdW5jdGlvbiB3YWl0Rm9yRGVwcyAoY2IpIHtcbiAgLy8gc2VlIGlmIHdlIGNhbiBpbXBvcnQgdGhlIG5lY2Vzc2FyeSBjb2RlXG4gIC8vIHRyeSBpdCBhIHJpZGljdWxvdXMgKGJ1dCBmaW5pdGUpIG51bWJlciBvZiB0aW1lc1xuICBsZXQgaSA9IDA7XG4gIGZ1bmN0aW9uIGNoZWNrICgpIHtcbiAgICBpKys7XG4gICAgdHJ5IHtcbiAgICAgIHJlcXVpcmUoQlVJTERfUEFUSCk7XG4gICAgICBjYigpO1xuICAgIH0gY2F0Y2ggKGVycikge1xuICAgICAgaWYgKGVyci5tZXNzYWdlLmluY2x1ZGVzKGBDYW5ub3QgZmluZCBtb2R1bGUgJyR7QlVJTERfUEFUSH0nYCkpIHtcbiAgICAgICAgbG9nLndhcm4oYFByb2plY3QgZG9lcyBub3QgYXBwZWFyIHRvIGJlIGJ1aWx0IHlldC4gUGxlYXNlIHJ1biAnbnBtIHJ1biBjaHJvbWVkcml2ZXInIGZpcnN0LmApO1xuICAgICAgICByZXR1cm4gY2IobmV3IEVycm9yKGBDb3VsZCBub3QgaW5zdGFsbCBtb2R1bGU6ICR7ZXJyLm1lc3NhZ2V9YCkpO1xuICAgICAgfVxuICAgICAgbG9nLndhcm4oYEVycm9yIHRyeWluZyB0byBpbnN0YWxsIENocm9tZWRyaXZlciBiaW5hcnkuIFdhaXRpbmcgJHtCVUlMRF9SRVRSWV9JTlRFUlZBTH1tcyBhbmQgdHJ5aW5nIGFnYWluOiAke2Vyci5tZXNzYWdlfWApO1xuICAgICAgaWYgKGkgPD0gQlVJTERfUkVUUklFUykge1xuICAgICAgICBzZXRUaW1lb3V0KGNoZWNrLCBCVUlMRF9SRVRSWV9JTlRFUlZBTCk7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICBjYihuZXcgRXJyb3IoYENvdWxkIG5vdCBpbXBvcnQgaW5zdGFsbGF0aW9uIG1vZHVsZTogJHtlcnIubWVzc2FnZX1gKSk7XG4gICAgICB9XG4gICAgfVxuICB9XG4gIGNoZWNrKCk7XG59XG5cbmZ1bmN0aW9uIG1haW4gKCkge1xuICAvLyBjaGVjayBpZiB3ZSBzaG91bGQgc2tpcCBpbnN0YWxsXG4gIGlmICghXy5pc0VtcHR5KHByb2Nlc3MuZW52LkFQUElVTV9TS0lQX0NIUk9NRURSSVZFUl9JTlNUQUxMKSB8fCAhXy5pc0VtcHR5KHByb2Nlc3MuZW52Lm5wbV9jb25maWdfY2hyb21lZHJpdmVyX3NraXBfaW5zdGFsbCkpIHtcbiAgICBsb2cud2FybihgJ0FQUElVTV9TS0lQX0NIUk9NRURSSVZFUl9JTlNUQUxMJyBlbnZpcm9ubWVudCB2YXJpYWJsZSBzZXQsIG9yICctLWNocm9tZWRyaXZlci1za2lwLWluc3RhbGwnIGZsYWcgc2V0LmApO1xuICAgIGxvZy53YXJuKGBTa2lwcGluZyBDaHJvbWVkcml2ZXIgaW5zdGFsbGF0aW9uLiBBbmRyb2lkIHdlYi9oeWJyaWQgdGVzdGluZyB3aWxsIG5vdCBiZSBwb3NzaWJsZWApO1xuICAgIHJldHVybjtcbiAgfVxuXG4gIC8vIGNoZWNrIGlmIHRoZSBjb2RlIGhhcyBiZWVuIHRyYW5zcGlsZWRcbiAgd2FpdEZvckRlcHMoZnVuY3Rpb24gd2FpdCAoZXJyKSB7XG4gICAgaWYgKGVycikge1xuICAgICAgLy8gdGhpcyBzaG91bGQgb25seSBoYXBwZW4gb24gbG9jYWwgaW5zdGFsbCAoaS5lLiwgbnBtIGluc3RhbGwgaW4gdGhpcyBkaXJlY3RvcnkpXG4gICAgICBsb2cud2FybihgVW5hYmxlIHRvIGltcG9ydCBpbnN0YWxsIHNjcmlwdDogJHtlcnIubWVzc2FnZX1gKTtcbiAgICAgIGxvZy53YXJuKGBSZS1ydW4gJ25wbSBydW4gY2hyb21lZHJpdmVyJyBtYW51YWxseS5gKTtcbiAgICAgIHJldHVybjtcbiAgICB9XG4gICAgZnMuc3RhdChCVUlMRF9QQVRILCBmdW5jdGlvbiBpbnN0YWxsU2NyaXB0RXhpc3RzIChlcnIpIHtcbiAgICAgIGlmIChlcnIpIHtcbiAgICAgICAgLy8gdGhpcyBzaG91bGQgb25seSBoYXBwZW4gb24gbG9jYWwgaW5zdGFsbFxuICAgICAgICBsb2cud2FybihgTk9URTogUnVuICducHggZ3VscCB0cmFuc3BpbGUnIGJlZm9yZSB1c2luZ2ApO1xuICAgICAgICByZXR1cm47XG4gICAgICB9XG4gICAgICByZXF1aXJlKEJVSUxEX1BBVEgpLmRvSW5zdGFsbCgpLmNhdGNoKGZ1bmN0aW9uIGluc3RhbGxFcnJvciAoZXJyKSB7XG4gICAgICAgIGxvZy5lcnJvcihgRXJyb3IgaW5zdGFsbGluZyBDaHJvbWVkcml2ZXI6ICR7ZXJyLm1lc3NhZ2V9YCk7XG4gICAgICAgIGxvZy5lcnJvcihlcnIuc3RhY2sgPyBlcnIuc3RhY2sgOiBlcnIpO1xuICAgICAgICBsb2cuZXJyb3IoYERvd25sb2FkaW5nIENocm9tZWRyaXZlciBjYW4gYmUgc2tpcHBlZCBieSB1c2luZyB0aGUgYCArXG4gICAgICAgICAgICAgICAgICBgJy0tY2hyb21lZHJpdmVyLXNraXAtaW5zdGFsbCcgZmxhZyBvciBgICtcbiAgICAgICAgICAgICAgICAgIGBzZXR0aW5nIHRoZSAnQVBQSVVNX1NLSVBfQ0hST01FRFJJVkVSX0lOU1RBTEwnIGVudmlyb25tZW50IGAgK1xuICAgICAgICAgICAgICAgICAgYHZhcmlhYmxlLmApO1xuICAgICAgICBwcm9jZXNzLmV4aXQoMSk7XG4gICAgICB9KTtcbiAgICB9KTtcbiAgfSk7XG59XG5cbmlmIChyZXF1aXJlLm1haW4gPT09IG1vZHVsZSkge1xuICBtYWluKCk7XG59XG4iXSwiZmlsZSI6Imluc3RhbGwtbnBtLmpzIiwic291cmNlUm9vdCI6Ii4uIn0=