appium-chromedriver 4.27.3 → 5.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/build/lib/chromedriver.js +30 -22
- package/build/lib/install.js +5 -5
- package/build/lib/protocol-helpers.js +4 -4
- package/build/lib/storage-client.js +22 -22
- package/build/lib/utils.js +10 -9
- package/config/mapping.json +9 -0
- package/lib/chromedriver.js +13 -6
- package/lib/install.js +1 -1
- package/lib/protocol-helpers.js +1 -1
- package/lib/storage-client.js +2 -2
- package/lib/utils.js +1 -1
- package/package.json +15 -8
- package/build/install-npm.js +0 -82
|
@@ -11,11 +11,11 @@ require("source-map-support/register");
|
|
|
11
11
|
|
|
12
12
|
var _events = _interopRequireDefault(require("events"));
|
|
13
13
|
|
|
14
|
-
var
|
|
14
|
+
var _baseDriver = require("@appium/base-driver");
|
|
15
15
|
|
|
16
16
|
var _child_process = _interopRequireDefault(require("child_process"));
|
|
17
17
|
|
|
18
|
-
var
|
|
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 =
|
|
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
|
|
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 =
|
|
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
|
|
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
|
|
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
|
|
135
|
-
log.debug(`Found ${
|
|
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
|
|
286
|
+
if (await _support.fs.exists(this.mappingPath)) {
|
|
287
287
|
try {
|
|
288
|
-
await
|
|
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 ${
|
|
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 ${
|
|
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
|
|
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 ${
|
|
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 ${
|
|
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 =
|
|
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 = [
|
|
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}`);
|
|
@@ -554,12 +554,20 @@ class Chromedriver extends _events.default.EventEmitter {
|
|
|
554
554
|
let message = '';
|
|
555
555
|
|
|
556
556
|
if (e.message.includes('Chrome version must be')) {
|
|
557
|
-
|
|
557
|
+
var _$exec;
|
|
558
|
+
|
|
559
|
+
message += 'Unable to automate Chrome version because it is not supported by this version of Chromedriver.\n';
|
|
558
560
|
|
|
559
561
|
if (webviewVersion) {
|
|
560
562
|
message += `Chrome version on the device: ${webviewVersion}\n`;
|
|
561
563
|
}
|
|
562
564
|
|
|
565
|
+
const versionsSupportedByDriver = ((_$exec = /Chrome version must be (.+)/.exec(e.message)) === null || _$exec === void 0 ? void 0 : _$exec[1]) || '';
|
|
566
|
+
|
|
567
|
+
if (versionsSupportedByDriver) {
|
|
568
|
+
message += `Chromedriver supports Chrome version(s): ${versionsSupportedByDriver}\n`;
|
|
569
|
+
}
|
|
570
|
+
|
|
563
571
|
message += `Visit '${CHROMEDRIVER_TUTORIAL}' to troubleshoot the problem.\n`;
|
|
564
572
|
}
|
|
565
573
|
|
|
@@ -609,7 +617,7 @@ class Chromedriver extends _events.default.EventEmitter {
|
|
|
609
617
|
}
|
|
610
618
|
|
|
611
619
|
async startSession() {
|
|
612
|
-
const sessionCaps = this.desiredProtocol ===
|
|
620
|
+
const sessionCaps = this.desiredProtocol === _baseDriver.PROTOCOLS.W3C ? {
|
|
613
621
|
capabilities: {
|
|
614
622
|
alwaysMatch: this.capabilities
|
|
615
623
|
}
|
|
@@ -655,7 +663,7 @@ class Chromedriver extends _events.default.EventEmitter {
|
|
|
655
663
|
}
|
|
656
664
|
|
|
657
665
|
async killAll() {
|
|
658
|
-
let cmd =
|
|
666
|
+
let cmd = _support.system.isWindows() ? `wmic process where "commandline like '%chromedriver.exe%--port=${this.proxyPort}%'" delete` : `pkill -15 -f "${this.chromedriver}.*--port=${this.proxyPort}"`;
|
|
659
667
|
log.debug(`Killing any old chromedrivers, running: ${cmd}`);
|
|
660
668
|
|
|
661
669
|
try {
|
|
@@ -716,4 +724,4 @@ var _default = Chromedriver;
|
|
|
716
724
|
exports.default = _default;require('source-map-support').install();
|
|
717
725
|
|
|
718
726
|
|
|
719
|
-
//# 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","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 too low for the version of Chromedriver\n      if (e.message.includes('Chrome version must be')) {\n        message += 'Unable to automate Chrome version because it is too old for this version of Chromedriver.\\n';\n        if (webviewVersion) {\n          message += `Chrome version on the device: ${webviewVersion}\\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":"../.."}
|
|
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({\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    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":"../.."}
|
package/build/lib/install.js
CHANGED
|
@@ -5,12 +5,12 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
|
|
|
5
5
|
Object.defineProperty(exports, "__esModule", {
|
|
6
6
|
value: true
|
|
7
7
|
});
|
|
8
|
-
exports.install = install;
|
|
9
8
|
exports.doInstall = doInstall;
|
|
9
|
+
exports.install = install;
|
|
10
10
|
|
|
11
11
|
require("source-map-support/register");
|
|
12
12
|
|
|
13
|
-
var
|
|
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
|
|
35
|
-
await (0,
|
|
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,
|
|
57
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImxpYi9pbnN0YWxsLmpzIl0sIm5hbWVzIjpbIkRPV05MT0FEX1RJTUVPVVRfTVMiLCJMQVRFU1RfVkVSU0lPTiIsImZvcm1hdENkVmVyc2lvbiIsInZlciIsIkNEX0NETiIsImFjY2VwdCIsInRpbWVvdXQiLCJ0cmltIiwicHJlcGFyZUNocm9tZWRyaXZlckRpciIsInBsYXRmb3JtTmFtZSIsImNocm9tZWRyaXZlckRpciIsImZzIiwiZXhpc3RzIiwiaW5zdGFsbCIsIm9zSW5mbyIsImNsaWVudCIsIkNocm9tZWRyaXZlclN0b3JhZ2VDbGllbnQiLCJuYW1lIiwic3luY0RyaXZlcnMiLCJ2ZXJzaW9ucyIsIkNEX1ZFUiIsImRvSW5zdGFsbCJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7O0FBQUE7O0FBQ0E7O0FBQ0E7O0FBS0EsTUFBTUEsbUJBQW1CLEdBQUcsS0FBSyxJQUFqQztBQUNBLE1BQU1DLGNBQWMsR0FBRyxRQUF2Qjs7QUFFQSxlQUFlQyxlQUFmLENBQWdDQyxHQUFoQyxFQUFxQztBQUNuQyxTQUFPQSxHQUFHLEtBQUtGLGNBQVIsR0FDSCxDQUFDLE1BQU0seUJBQWMsR0FBRUcsYUFBTyxpQkFBdkIsRUFBeUM7QUFDaEQsa0JBQWMsUUFEa0M7QUFFaERDLElBQUFBLE1BQU0sRUFBRTtBQUZ3QyxHQUF6QyxFQUdOO0FBQUVDLElBQUFBLE9BQU8sRUFBRU47QUFBWCxHQUhNLENBQVAsRUFHb0NPLElBSHBDLEVBREcsR0FLSEosR0FMSjtBQU1EOztBQUVELGVBQWVLLHNCQUFmLENBQXVDQyxZQUF2QyxFQUFxRDtBQUNuRCxRQUFNQyxlQUFlLEdBQUcsK0JBQW1CRCxZQUFuQixDQUF4Qjs7QUFDQSxNQUFJLEVBQUMsTUFBTUUsWUFBR0MsTUFBSCxDQUFVRixlQUFWLENBQVAsQ0FBSixFQUF1QztBQUNyQyxVQUFNLHFCQUFPQSxlQUFQLENBQU47QUFDRDs7QUFDRCxTQUFPQSxlQUFQO0FBQ0Q7O0FBRUQsZUFBZUcsT0FBZixHQUEwQjtBQUN4QixRQUFNQyxNQUFNLEdBQUcsTUFBTSx1QkFBckI7QUFDQSxRQUFNQyxNQUFNLEdBQUcsSUFBSUMsc0JBQUosQ0FBOEI7QUFDM0NOLElBQUFBLGVBQWUsRUFBRSxNQUFNRixzQkFBc0IsQ0FBQ00sTUFBTSxDQUFDRyxJQUFSO0FBREYsR0FBOUIsQ0FBZjtBQUdBLFFBQU1GLE1BQU0sQ0FBQ0csV0FBUCxDQUFtQjtBQUN2QkosSUFBQUEsTUFEdUI7QUFFdkJLLElBQUFBLFFBQVEsRUFBRSxDQUFDLE1BQU1qQixlQUFlLENBQUNrQixhQUFELENBQXRCO0FBRmEsR0FBbkIsQ0FBTjtBQUlEOztBQUVELGVBQWVDLFNBQWYsR0FBNEI7QUFDMUIsUUFBTVIsT0FBTyxFQUFiO0FBQ0QiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBmcywgbWtkaXJwIH0gZnJvbSAnQGFwcGl1bS9zdXBwb3J0JztcbmltcG9ydCBDaHJvbWVkcml2ZXJTdG9yYWdlQ2xpZW50IGZyb20gJy4vc3RvcmFnZS1jbGllbnQnO1xuaW1wb3J0IHtcbiAgQ0RfQ0ROLCBDRF9WRVIsIHJldHJpZXZlRGF0YSwgZ2V0T3NJbmZvLCBnZXRDaHJvbWVkcml2ZXJEaXIsXG59IGZyb20gJy4vdXRpbHMnO1xuXG5cbmNvbnN0IERPV05MT0FEX1RJTUVPVVRfTVMgPSAxNSAqIDEwMDA7XG5jb25zdCBMQVRFU1RfVkVSU0lPTiA9ICdMQVRFU1QnO1xuXG5hc3luYyBmdW5jdGlvbiBmb3JtYXRDZFZlcnNpb24gKHZlcikge1xuICByZXR1cm4gdmVyID09PSBMQVRFU1RfVkVSU0lPTlxuICAgID8gKGF3YWl0IHJldHJpZXZlRGF0YShgJHtDRF9DRE59L0xBVEVTVF9SRUxFQVNFYCwge1xuICAgICAgJ3VzZXItYWdlbnQnOiAnYXBwaXVtJyxcbiAgICAgIGFjY2VwdDogJyovKicsXG4gICAgfSwgeyB0aW1lb3V0OiBET1dOTE9BRF9USU1FT1VUX01TIH0pKS50cmltKClcbiAgICA6IHZlcjtcbn1cblxuYXN5bmMgZnVuY3Rpb24gcHJlcGFyZUNocm9tZWRyaXZlckRpciAocGxhdGZvcm1OYW1lKSB7XG4gIGNvbnN0IGNocm9tZWRyaXZlckRpciA9IGdldENocm9tZWRyaXZlckRpcihwbGF0Zm9ybU5hbWUpO1xuICBpZiAoIWF3YWl0IGZzLmV4aXN0cyhjaHJvbWVkcml2ZXJEaXIpKSB7XG4gICAgYXdhaXQgbWtkaXJwKGNocm9tZWRyaXZlckRpcik7XG4gIH1cbiAgcmV0dXJuIGNocm9tZWRyaXZlckRpcjtcbn1cblxuYXN5bmMgZnVuY3Rpb24gaW5zdGFsbCAoKSB7XG4gIGNvbnN0IG9zSW5mbyA9IGF3YWl0IGdldE9zSW5mbygpO1xuICBjb25zdCBjbGllbnQgPSBuZXcgQ2hyb21lZHJpdmVyU3RvcmFnZUNsaWVudCh7XG4gICAgY2hyb21lZHJpdmVyRGlyOiBhd2FpdCBwcmVwYXJlQ2hyb21lZHJpdmVyRGlyKG9zSW5mby5uYW1lKSxcbiAgfSk7XG4gIGF3YWl0IGNsaWVudC5zeW5jRHJpdmVycyh7XG4gICAgb3NJbmZvLFxuICAgIHZlcnNpb25zOiBbYXdhaXQgZm9ybWF0Q2RWZXJzaW9uKENEX1ZFUildLFxuICB9KTtcbn1cblxuYXN5bmMgZnVuY3Rpb24gZG9JbnN0YWxsICgpIHtcbiAgYXdhaXQgaW5zdGFsbCgpO1xufVxuXG5leHBvcnQgeyBpbnN0YWxsLCBkb0luc3RhbGwgfTtcbiJdLCJmaWxlIjoibGliL2luc3RhbGwuanMiLCJzb3VyY2VSb290IjoiLi4vLi4ifQ==
|
|
@@ -5,19 +5,19 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
|
|
|
5
5
|
Object.defineProperty(exports, "__esModule", {
|
|
6
6
|
value: true
|
|
7
7
|
});
|
|
8
|
-
exports.toW3cCapNames = toW3cCapNames;
|
|
9
8
|
exports.getCapValue = getCapValue;
|
|
9
|
+
exports.toW3cCapNames = toW3cCapNames;
|
|
10
10
|
|
|
11
11
|
require("source-map-support/register");
|
|
12
12
|
|
|
13
13
|
var _lodash = _interopRequireDefault(require("lodash"));
|
|
14
14
|
|
|
15
|
-
var
|
|
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,
|
|
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,
|
|
41
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImxpYi9wcm90b2NvbC1oZWxwZXJzLmpzIl0sIm5hbWVzIjpbIlczQ19QUkVGSVgiLCJ0b1czY0NhcE5hbWUiLCJjYXBOYW1lIiwiXyIsImlzU3RyaW5nIiwiaW5jbHVkZXMiLCJnZXRDYXBWYWx1ZSIsImFsbENhcHMiLCJyYXdDYXBOYW1lIiwiZGVmYXVsdFZhbHVlIiwiY2FwVmFsdWUiLCJ0b1BhaXJzIiwidG9XM2NDYXBOYW1lcyIsIm9yaWdpbmFsQ2FwcyIsInJlZHVjZSIsImFjYyIsInZhbHVlIiwia2V5Il0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7QUFBQTs7QUFDQTs7QUFFQSxNQUFNQSxVQUFVLEdBQUcsT0FBbkI7O0FBRUEsU0FBU0MsWUFBVCxDQUF1QkMsT0FBdkIsRUFBZ0M7QUFDOUIsU0FBUUMsZ0JBQUVDLFFBQUYsQ0FBV0YsT0FBWCxLQUF1QixDQUFDQSxPQUFPLENBQUNHLFFBQVIsQ0FBaUIsR0FBakIsQ0FBeEIsSUFBaUQsQ0FBQywrQkFBY0gsT0FBZCxDQUFuRCxHQUNGLEdBQUVGLFVBQVcsR0FBRUUsT0FBUSxFQURyQixHQUVIQSxPQUZKO0FBR0Q7O0FBRUQsU0FBU0ksV0FBVCxDQUFzQkMsT0FBTyxHQUFHLEVBQWhDLEVBQW9DQyxVQUFwQyxFQUFnREMsWUFBaEQsRUFBOEQ7QUFDNUQsT0FBSyxNQUFNLENBQUNQLE9BQUQsRUFBVVEsUUFBVixDQUFYLElBQWtDUCxnQkFBRVEsT0FBRixDQUFVSixPQUFWLENBQWxDLEVBQXNEO0FBQ3BELFFBQUlOLFlBQVksQ0FBQ0MsT0FBRCxDQUFaLEtBQTBCRCxZQUFZLENBQUNPLFVBQUQsQ0FBMUMsRUFBd0Q7QUFDdEQsYUFBT0UsUUFBUDtBQUNEO0FBQ0Y7O0FBQ0QsU0FBT0QsWUFBUDtBQUNEOztBQUVELFNBQVNHLGFBQVQsQ0FBd0JDLFlBQVksR0FBRyxFQUF2QyxFQUEyQztBQUN6QyxTQUFPVixnQkFBRVcsTUFBRixDQUFTRCxZQUFULEVBQXVCLENBQUNFLEdBQUQsRUFBTUMsS0FBTixFQUFhQyxHQUFiLEtBQXFCO0FBQ2pERixJQUFBQSxHQUFHLENBQUNkLFlBQVksQ0FBQ2dCLEdBQUQsQ0FBYixDQUFILEdBQXlCRCxLQUF6QjtBQUNBLFdBQU9ELEdBQVA7QUFDRCxHQUhNLEVBR0osRUFISSxDQUFQO0FBSUQiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgXyBmcm9tICdsb2Rhc2gnO1xuaW1wb3J0IHsgaXNTdGFuZGFyZENhcCB9IGZyb20gJ0BhcHBpdW0vYmFzZS1kcml2ZXInO1xuXG5jb25zdCBXM0NfUFJFRklYID0gJ2dvb2c6JztcblxuZnVuY3Rpb24gdG9XM2NDYXBOYW1lIChjYXBOYW1lKSB7XG4gIHJldHVybiAoXy5pc1N0cmluZyhjYXBOYW1lKSAmJiAhY2FwTmFtZS5pbmNsdWRlcygnOicpICYmICFpc1N0YW5kYXJkQ2FwKGNhcE5hbWUpKVxuICAgID8gYCR7VzNDX1BSRUZJWH0ke2NhcE5hbWV9YFxuICAgIDogY2FwTmFtZTtcbn1cblxuZnVuY3Rpb24gZ2V0Q2FwVmFsdWUgKGFsbENhcHMgPSB7fSwgcmF3Q2FwTmFtZSwgZGVmYXVsdFZhbHVlKSB7XG4gIGZvciAoY29uc3QgW2NhcE5hbWUsIGNhcFZhbHVlXSBvZiBfLnRvUGFpcnMoYWxsQ2FwcykpIHtcbiAgICBpZiAodG9XM2NDYXBOYW1lKGNhcE5hbWUpID09PSB0b1czY0NhcE5hbWUocmF3Q2FwTmFtZSkpIHtcbiAgICAgIHJldHVybiBjYXBWYWx1ZTtcbiAgICB9XG4gIH1cbiAgcmV0dXJuIGRlZmF1bHRWYWx1ZTtcbn1cblxuZnVuY3Rpb24gdG9XM2NDYXBOYW1lcyAob3JpZ2luYWxDYXBzID0ge30pIHtcbiAgcmV0dXJuIF8ucmVkdWNlKG9yaWdpbmFsQ2FwcywgKGFjYywgdmFsdWUsIGtleSkgPT4ge1xuICAgIGFjY1t0b1czY0NhcE5hbWUoa2V5KV0gPSB2YWx1ZTtcbiAgICByZXR1cm4gYWNjO1xuICB9LCB7fSk7XG59XG5cbmV4cG9ydCB7IHRvVzNjQ2FwTmFtZXMsIGdldENhcFZhbHVlIH07XG4iXSwiZmlsZSI6ImxpYi9wcm90b2NvbC1oZWxwZXJzLmpzIiwic291cmNlUm9vdCI6Ii4uLy4uIn0=
|