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
|
@@ -15,21 +15,21 @@ var _lodash = _interopRequireDefault(require("lodash"));
|
|
|
15
15
|
|
|
16
16
|
var _xpath = _interopRequireDefault(require("xpath"));
|
|
17
17
|
|
|
18
|
-
var _xmldom = require("xmldom");
|
|
18
|
+
var _xmldom = require("@xmldom/xmldom");
|
|
19
19
|
|
|
20
20
|
var _bluebird = _interopRequireDefault(require("bluebird"));
|
|
21
21
|
|
|
22
22
|
var _path = _interopRequireDefault(require("path"));
|
|
23
23
|
|
|
24
|
-
var
|
|
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 =
|
|
29
|
+
const log = _support.logger.getLogger('ChromedriverStorageClient');
|
|
30
30
|
|
|
31
31
|
async function isCrcOk(src, checksum) {
|
|
32
|
-
const md5 = await
|
|
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 || !
|
|
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
|
|
193
|
+
const tmpRoot = await _support.tempDir.openDir();
|
|
194
194
|
|
|
195
195
|
try {
|
|
196
|
-
await
|
|
197
|
-
const chromedriverPath = await
|
|
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
|
|
204
|
+
await _support.fs.mv(chromedriverPath, dst, {
|
|
205
205
|
mkdirp: true
|
|
206
206
|
});
|
|
207
207
|
} finally {
|
|
208
|
-
await
|
|
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 ${
|
|
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 ${
|
|
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 ${
|
|
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 ${
|
|
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
|
|
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}` + (
|
|
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
|
|
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 ${
|
|
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
|
|
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
|
|
373
|
+
await _support.fs.rimraf(archivesRoot);
|
|
374
374
|
}
|
|
375
375
|
|
|
376
376
|
if (!_lodash.default.isEmpty(synchronizedDrivers)) {
|
|
377
|
-
log.info(`Successfully synchronized ` + `${
|
|
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';\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":"../.."}
|
package/build/lib/utils.js
CHANGED
|
@@ -5,18 +5,19 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
|
|
|
5
5
|
Object.defineProperty(exports, "__esModule", {
|
|
6
6
|
value: true
|
|
7
7
|
});
|
|
8
|
+
exports.X86 = exports.X64 = exports.OS = exports.M1_ARCH_SUFFIX = exports.CHROMEDRIVER_CHROME_MAPPING = exports.CD_VER = exports.CD_CDN = exports.CD_BASE_DIR = void 0;
|
|
8
9
|
exports.getChromeVersion = getChromeVersion;
|
|
9
|
-
exports.getChromedriverDir = getChromedriverDir;
|
|
10
10
|
exports.getChromedriverBinaryPath = getChromedriverBinaryPath;
|
|
11
|
+
exports.getChromedriverDir = getChromedriverDir;
|
|
11
12
|
exports.getMostRecentChromedriver = getMostRecentChromedriver;
|
|
13
|
+
exports.getOsName = exports.getOsInfo = void 0;
|
|
12
14
|
exports.retrieveData = retrieveData;
|
|
13
|
-
exports.M1_ARCH_SUFFIX = exports.X86 = exports.X64 = exports.OS = exports.getOsInfo = exports.CHROMEDRIVER_CHROME_MAPPING = exports.CD_VER = exports.CD_CDN = exports.CD_BASE_DIR = exports.getOsName = void 0;
|
|
14
15
|
|
|
15
16
|
require("source-map-support/register");
|
|
16
17
|
|
|
17
18
|
var _lodash = _interopRequireDefault(require("lodash"));
|
|
18
19
|
|
|
19
|
-
var
|
|
20
|
+
var _support = require("@appium/support");
|
|
20
21
|
|
|
21
22
|
var _path = _interopRequireDefault(require("path"));
|
|
22
23
|
|
|
@@ -75,7 +76,7 @@ function getChromedriverDir(osName = getOsName()) {
|
|
|
75
76
|
async function getChromedriverBinaryPath(osName = getOsName()) {
|
|
76
77
|
const rootDir = getChromedriverDir(osName);
|
|
77
78
|
const pathSuffix = osName === OS.windows ? '.exe' : '';
|
|
78
|
-
const paths = await
|
|
79
|
+
const paths = await _support.fs.glob(`${CD_EXECUTABLE_PREFIX}*${pathSuffix}`, {
|
|
79
80
|
cwd: rootDir,
|
|
80
81
|
absolute: true,
|
|
81
82
|
nocase: true,
|
|
@@ -99,11 +100,11 @@ async function retrieveData(url, headers, opts = {}) {
|
|
|
99
100
|
}
|
|
100
101
|
|
|
101
102
|
const getOsName = _lodash.default.memoize(function getOsName() {
|
|
102
|
-
if (
|
|
103
|
+
if (_support.system.isWindows()) {
|
|
103
104
|
return OS.windows;
|
|
104
105
|
}
|
|
105
106
|
|
|
106
|
-
if (
|
|
107
|
+
if (_support.system.isMac()) {
|
|
107
108
|
return OS.mac;
|
|
108
109
|
}
|
|
109
110
|
|
|
@@ -115,12 +116,12 @@ exports.getOsName = getOsName;
|
|
|
115
116
|
const getOsInfo = _lodash.default.memoize(async function getOsInfo() {
|
|
116
117
|
return {
|
|
117
118
|
name: getOsName(),
|
|
118
|
-
arch: await
|
|
119
|
-
hardwareName:
|
|
119
|
+
arch: await _support.system.arch(),
|
|
120
|
+
hardwareName: _support.system.isWindows() ? null : _lodash.default.trim(await (0, _teen_process.exec)('uname', ['-m']))
|
|
120
121
|
};
|
|
121
122
|
});
|
|
122
123
|
|
|
123
124
|
exports.getOsInfo = getOsInfo;require('source-map-support').install();
|
|
124
125
|
|
|
125
126
|
|
|
126
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,
|
|
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":"../.."}
|
package/config/mapping.json
CHANGED
|
@@ -1,4 +1,13 @@
|
|
|
1
1
|
{
|
|
2
|
+
"97.0.4692.71": "97.0.4692.71",
|
|
3
|
+
"96.0.4664.45": "96.0.4664.45",
|
|
4
|
+
"95.0.4638.69": "95.0.4638.69",
|
|
5
|
+
"95.0.4638.54": "95.0.4638.54",
|
|
6
|
+
"94.0.4606.61": "94.0.4606.61",
|
|
7
|
+
"93.0.4577.63": "93.0.4577.63",
|
|
8
|
+
"93.0.4577.15": "93.0.4577.15",
|
|
9
|
+
"92.0.4515.107": "92.0.4515.107",
|
|
10
|
+
"92.0.4515.43": "92.0.4515.43",
|
|
2
11
|
"91.0.4472.101": "91.0.4472.101",
|
|
3
12
|
"91.0.4472.19": "91.0.4472.19",
|
|
4
13
|
"90.0.4430.24": "90.0.4430.24",
|
package/lib/chromedriver.js
CHANGED
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
// transpile:main
|
|
2
2
|
|
|
3
3
|
import events from 'events';
|
|
4
|
-
import { JWProxy, PROTOCOLS } from 'appium
|
|
4
|
+
import { JWProxy, PROTOCOLS } from '@appium/base-driver';
|
|
5
5
|
import cp from 'child_process';
|
|
6
|
-
import { system, fs, logger, util } from 'appium
|
|
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({
|
|
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 = [
|
|
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
|
}
|
|
@@ -528,12 +531,16 @@ class Chromedriver extends events.EventEmitter {
|
|
|
528
531
|
}
|
|
529
532
|
|
|
530
533
|
let message = '';
|
|
531
|
-
// often the user's Chrome version is
|
|
534
|
+
// often the user's Chrome version is not supported by the version of Chromedriver
|
|
532
535
|
if (e.message.includes('Chrome version must be')) {
|
|
533
|
-
message += 'Unable to automate Chrome version because it is
|
|
536
|
+
message += 'Unable to automate Chrome version because it is not supported by this version of Chromedriver.\n';
|
|
534
537
|
if (webviewVersion) {
|
|
535
538
|
message += `Chrome version on the device: ${webviewVersion}\n`;
|
|
536
539
|
}
|
|
540
|
+
const versionsSupportedByDriver = /Chrome version must be (.+)/.exec(e.message)?.[1] || '';
|
|
541
|
+
if (versionsSupportedByDriver) {
|
|
542
|
+
message += `Chromedriver supports Chrome version(s): ${versionsSupportedByDriver}\n`;
|
|
543
|
+
}
|
|
537
544
|
message += `Visit '${CHROMEDRIVER_TUTORIAL}' to troubleshoot the problem.\n`;
|
|
538
545
|
}
|
|
539
546
|
|
package/lib/install.js
CHANGED
package/lib/protocol-helpers.js
CHANGED
package/lib/storage-client.js
CHANGED
|
@@ -4,10 +4,10 @@ import {
|
|
|
4
4
|
} from './utils';
|
|
5
5
|
import _ from 'lodash';
|
|
6
6
|
import xpath from 'xpath';
|
|
7
|
-
import { DOMParser } from 'xmldom';
|
|
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
|
|
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
package/package.json
CHANGED
|
@@ -6,7 +6,7 @@
|
|
|
6
6
|
"chrome",
|
|
7
7
|
"android"
|
|
8
8
|
],
|
|
9
|
-
"version": "
|
|
9
|
+
"version": "5.0.1",
|
|
10
10
|
"author": "appium",
|
|
11
11
|
"license": "Apache-2.0",
|
|
12
12
|
"repository": {
|
|
@@ -35,19 +35,19 @@
|
|
|
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
|
-
"
|
|
40
|
-
"appium-support": "^2.46.0",
|
|
41
|
+
"@xmldom/xmldom": "^0.x",
|
|
41
42
|
"asyncbox": "^2.0.2",
|
|
42
43
|
"axios": "^0.x",
|
|
43
44
|
"bluebird": "^3.5.1",
|
|
44
45
|
"compare-versions": "^3.4.0",
|
|
45
|
-
"fancy-log": "^
|
|
46
|
+
"fancy-log": "^2.0.0",
|
|
46
47
|
"lodash": "^4.17.4",
|
|
47
48
|
"semver": "^7.0.0",
|
|
48
49
|
"source-map-support": "^0.x",
|
|
49
50
|
"teen_process": "^1.15.0",
|
|
50
|
-
"xmldom": "^0.x",
|
|
51
51
|
"xpath": "^0.x"
|
|
52
52
|
},
|
|
53
53
|
"pre-commit": [
|
|
@@ -71,13 +71,20 @@
|
|
|
71
71
|
"lint:fix": "gulp lint --fix"
|
|
72
72
|
},
|
|
73
73
|
"devDependencies": {
|
|
74
|
-
"appium
|
|
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
|
|
81
|
+
"eslint": "^7.32.0",
|
|
82
|
+
"eslint-plugin-import": "^2.25.3",
|
|
83
|
+
"eslint-plugin-mocha": "^9.0.0",
|
|
84
|
+
"eslint-plugin-promise": "^6.0.0",
|
|
78
85
|
"gulp": "^4.0.0",
|
|
79
86
|
"mocha": "^9.0.0",
|
|
80
87
|
"pre-commit": "^1.1.3",
|
|
81
|
-
"sinon": "^
|
|
88
|
+
"sinon": "^12.0.0"
|
|
82
89
|
}
|
|
83
90
|
}
|