appium-chromedriver 4.26.4 → 4.27.3

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.
@@ -28,21 +28,6 @@ const MAX_PARALLEL_DOWNLOADS = 5;
28
28
 
29
29
  const log = _appiumSupport.logger.getLogger('ChromedriverStorageClient');
30
30
 
31
- async function getOsInfo() {
32
- let name = 'linux';
33
-
34
- if (_appiumSupport.system.isWindows()) {
35
- name = 'win';
36
- } else if (_appiumSupport.system.isMac()) {
37
- name = 'mac';
38
- }
39
-
40
- return {
41
- name,
42
- arch: await _appiumSupport.system.arch()
43
- };
44
- }
45
-
46
31
  async function isCrcOk(src, checksum) {
47
32
  const md5 = await _appiumSupport.fs.hash(src, 'md5');
48
33
  return _lodash.default.toLower(md5) === _lodash.default.toLower(checksum);
@@ -153,7 +138,6 @@ class ChromedriverStorageClient {
153
138
  continue;
154
139
  }
155
140
 
156
- log.debug(`Processing chromedriver entry '${key}'`);
157
141
  const etag = extractNodeText(findChildNode(driverNode, 'ETag'));
158
142
 
159
143
  if (!etag) {
@@ -269,15 +253,21 @@ class ChromedriverStorageClient {
269
253
  if (!_lodash.default.isEmpty(osInfo)) {
270
254
  let {
271
255
  name,
272
- arch
256
+ arch,
257
+ hardwareName
273
258
  } = osInfo;
274
259
 
275
- if (arch === '64' && !driversToSync.some(cdName => cdName.includes(`_${name}64`))) {
276
- arch = '32';
260
+ if (arch === _utils.X64 && !driversToSync.some(cdName => cdName.includes(`_${name}${_utils.X64}`))) {
261
+ arch = _utils.X86;
262
+ }
263
+
264
+ if (name === _utils.OS.mac && _lodash.default.includes(hardwareName, 'arm') && driversToSync.some(cdName => cdName.includes(_utils.M1_ARCH_SUFFIX))) {
265
+ arch += _utils.M1_ARCH_SUFFIX;
277
266
  }
278
267
 
279
268
  log.debug(`Selecting chromedrivers whose platform matches to ${name}${arch}`);
280
- driversToSync = driversToSync.filter(cdName => cdName.includes(`_${name}${arch}`));
269
+ const platformRe = new RegExp(`(\\b|_)${name}${arch}\\b`);
270
+ driversToSync = driversToSync.filter(cdName => platformRe.test(cdName));
281
271
  log.debug(`Got ${_appiumSupport.util.pluralize('item', driversToSync.length, true)}`);
282
272
  }
283
273
 
@@ -343,6 +333,8 @@ class ChromedriverStorageClient {
343
333
  }
344
334
 
345
335
  async syncDrivers(opts = {}) {
336
+ var _opts$osInfo;
337
+
346
338
  if (_lodash.default.isEmpty(this.mapping)) {
347
339
  await this.retrieveMapping(!!opts.minBrowserVersion);
348
340
  }
@@ -351,7 +343,7 @@ class ChromedriverStorageClient {
351
343
  throw new Error('Cannot retrieve chromedrivers mapping from Google storage');
352
344
  }
353
345
 
354
- const driversToSync = this.selectMatchingDrivers(await getOsInfo(), opts);
346
+ const driversToSync = this.selectMatchingDrivers((_opts$osInfo = opts.osInfo) !== null && _opts$osInfo !== void 0 ? _opts$osInfo : await (0, _utils.getOsInfo)(), opts);
355
347
 
356
348
  if (_lodash.default.isEmpty(driversToSync)) {
357
349
  log.debug(`There are no drivers to sync. Exiting`);
@@ -396,4 +388,4 @@ var _default = ChromedriverStorageClient;
396
388
  exports.default = _default;require('source-map-support').install();
397
389
 
398
390
 
399
- //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/storage-client.js"],"names":["TIMEOUT_MS","MAX_PARALLEL_DOWNLOADS","log","logger","getLogger","getOsInfo","name","system","isWindows","isMac","arch","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","Error","basename","mv","mkdirp","rimraf","selectMatchingDrivers","osInfo","opts","versions","driversToSync","keys","filter","cdName","pluralize","isNaN","minBrowserVersionInt","parseInt","closestMatchedVersionNumber","currentMinBrowserVersion","uniq","map","some","retrieveDriver","index","archivesRoot","isStrict","archivePath","resolve","net","downloadFile","isMetered","e","msg","message","error","fileName","targetPath","chmod","syncDrivers","JSON","stringify","synchronizedDrivers","idx","entries"],"mappings":"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","sourcesContent":["import { getChromedriverDir, CD_CDN, retrieveData } 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 getOsInfo () {\n  let name = 'linux';\n  if (system.isWindows()) {\n    name = 'win';\n  } else if (system.isMac()) {\n    name = 'mac';\n  }\n  return {\n    name,\n    arch: await system.arch(),\n  };\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      log.debug(`Processing chromedriver entry '${key}'`);\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   */\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} = osInfo;\n      if (arch === '64' && !driversToSync.some((cdName) => cdName.includes(`_${name}64`))) {\n        // Fall back to x86 build if x64 one is not available for the given OS\n        arch = '32';\n      }\n      log.debug(`Selecting chromedrivers whose platform matches to ${name}${arch}`);\n      driversToSync = driversToSync.filter((cdName) => cdName.includes(`_${name}${arch}`));\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   */\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(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';\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":"../.."}
@@ -8,11 +8,9 @@ Object.defineProperty(exports, "__esModule", {
8
8
  exports.getChromeVersion = getChromeVersion;
9
9
  exports.getChromedriverDir = getChromedriverDir;
10
10
  exports.getChromedriverBinaryPath = getChromedriverBinaryPath;
11
- exports.getCurPlatform = getCurPlatform;
12
- exports.getPlatforms = getPlatforms;
13
11
  exports.getMostRecentChromedriver = getMostRecentChromedriver;
14
12
  exports.retrieveData = retrieveData;
15
- exports.CHROMEDRIVER_CHROME_MAPPING = exports.CD_VER = exports.CD_CDN = exports.LINUX_32_ONLY = exports.MAC_32_ONLY = exports.CD_BASE_DIR = void 0;
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;
16
14
 
17
15
  require("source-map-support/register");
18
16
 
@@ -22,12 +20,12 @@ var _appiumSupport = require("appium-support");
22
20
 
23
21
  var _path = _interopRequireDefault(require("path"));
24
22
 
25
- var _semver = _interopRequireDefault(require("semver"));
26
-
27
23
  var _compareVersions = _interopRequireDefault(require("compare-versions"));
28
24
 
29
25
  var _axios = _interopRequireDefault(require("axios"));
30
26
 
27
+ var _teen_process = require("teen_process");
28
+
31
29
  const rootDir = _path.default.basename(__dirname) === 'lib' ? _path.default.resolve(__dirname, process.env.NO_PRECOMPILE ? '..' : '../..') : __dirname;
32
30
 
33
31
  const CHROMEDRIVER_CHROME_MAPPING = require(_path.default.resolve(rootDir, 'config', 'mapping.json'));
@@ -41,10 +39,19 @@ const CD_BASE_DIR = _path.default.resolve(__dirname, '..', '..', 'chromedriver')
41
39
  exports.CD_BASE_DIR = CD_BASE_DIR;
42
40
  const CD_CDN = process.env.npm_config_chromedriver_cdnurl || process.env.CHROMEDRIVER_CDNURL || 'https://chromedriver.storage.googleapis.com';
43
41
  exports.CD_CDN = CD_CDN;
44
- const MAC_32_ONLY = '2.23.0';
45
- exports.MAC_32_ONLY = MAC_32_ONLY;
46
- const LINUX_32_ONLY = '2.34.0';
47
- exports.LINUX_32_ONLY = LINUX_32_ONLY;
42
+ const OS = {
43
+ linux: 'linux',
44
+ windows: 'win',
45
+ mac: 'mac'
46
+ };
47
+ exports.OS = OS;
48
+ const X64 = '64';
49
+ exports.X64 = X64;
50
+ const X86 = '32';
51
+ exports.X86 = X86;
52
+ const M1_ARCH_SUFFIX = '_m1';
53
+ exports.M1_ARCH_SUFFIX = M1_ARCH_SUFFIX;
54
+ const CD_EXECUTABLE_PREFIX = 'chromedriver';
48
55
 
49
56
  function getMostRecentChromedriver(mapping = CHROMEDRIVER_CHROME_MAPPING) {
50
57
  if (_lodash.default.isEmpty(mapping)) {
@@ -61,39 +68,21 @@ async function getChromeVersion(adb, bundleId) {
61
68
  return versionName;
62
69
  }
63
70
 
64
- function getChromedriverDir(platform = getCurPlatform()) {
65
- return _path.default.resolve(CD_BASE_DIR, platform);
66
- }
67
-
68
- async function getChromedriverBinaryPath(platform = getCurPlatform(), arch = null) {
69
- const baseDir = getChromedriverDir(platform);
70
- let ext = '';
71
-
72
- if (platform === 'win') {
73
- ext = '.exe';
74
- } else if (platform === 'linux') {
75
- ext = `_${arch || (await _appiumSupport.system.arch())}`;
76
- }
77
-
78
- return _path.default.resolve(baseDir, `chromedriver${ext}`);
71
+ function getChromedriverDir(osName = getOsName()) {
72
+ return _path.default.resolve(CD_BASE_DIR, osName);
79
73
  }
80
74
 
81
- function getCurPlatform() {
82
- return _appiumSupport.system.isWindows() ? 'win' : _appiumSupport.system.isMac() ? 'mac' : 'linux';
83
- }
84
-
85
- function getPlatforms() {
86
- let plats = [['win', '32'], ['linux', '64']];
87
-
88
- const cdVer = _semver.default.coerce(CD_VER);
89
-
90
- plats.push(_semver.default.lt(cdVer, MAC_32_ONLY) ? ['mac', '32'] : ['mac', '64']);
91
-
92
- if (_semver.default.lt(cdVer, LINUX_32_ONLY)) {
93
- plats.push(['linux', '32']);
94
- }
95
-
96
- return plats;
75
+ async function getChromedriverBinaryPath(osName = getOsName()) {
76
+ const rootDir = getChromedriverDir(osName);
77
+ const pathSuffix = osName === OS.windows ? '.exe' : '';
78
+ const paths = await _appiumSupport.fs.glob(`${CD_EXECUTABLE_PREFIX}*${pathSuffix}`, {
79
+ cwd: rootDir,
80
+ absolute: true,
81
+ nocase: true,
82
+ nodir: true,
83
+ strict: false
84
+ });
85
+ return _lodash.default.isEmpty(paths) ? _path.default.resolve(rootDir, `${CD_EXECUTABLE_PREFIX}${pathSuffix}`) : _lodash.default.first(paths);
97
86
  }
98
87
 
99
88
  async function retrieveData(url, headers, opts = {}) {
@@ -107,7 +96,31 @@ async function retrieveData(url, headers, opts = {}) {
107
96
  timeout,
108
97
  responseType
109
98
  })).data;
110
- }require('source-map-support').install();
99
+ }
100
+
101
+ const getOsName = _lodash.default.memoize(function getOsName() {
102
+ if (_appiumSupport.system.isWindows()) {
103
+ return OS.windows;
104
+ }
105
+
106
+ if (_appiumSupport.system.isMac()) {
107
+ return OS.mac;
108
+ }
109
+
110
+ return OS.linux;
111
+ });
112
+
113
+ exports.getOsName = getOsName;
114
+
115
+ const getOsInfo = _lodash.default.memoize(async function getOsInfo() {
116
+ return {
117
+ name: getOsName(),
118
+ arch: await _appiumSupport.system.arch(),
119
+ hardwareName: _appiumSupport.system.isWindows() ? null : _lodash.default.trim(await (0, _teen_process.exec)('uname', ['-m']))
120
+ };
121
+ });
122
+
123
+ exports.getOsInfo = getOsInfo;require('source-map-support').install();
111
124
 
112
125
 
113
- //# 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","MAC_32_ONLY","LINUX_32_ONLY","mapping","_","isEmpty","Error","last","keys","sort","compareVersions","getChromeVersion","adb","bundleId","versionName","getPackageInfo","getChromedriverDir","platform","getCurPlatform","getChromedriverBinaryPath","arch","baseDir","ext","system","isWindows","isMac","getPlatforms","plats","cdVer","semver","coerce","push","lt","retrieveData","url","headers","opts","timeout","responseType","data"],"mappings":"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","sourcesContent":["import _ from 'lodash';\nimport { system } from 'appium-support';\nimport path from 'path';\nimport semver from 'semver';\nimport compareVersions from 'compare-versions';\nimport axios from 'axios';\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';\n\nconst MAC_32_ONLY = '2.23.0';\nconst LINUX_32_ONLY = '2.34.0';\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 (platform = getCurPlatform()) {\n  return path.resolve(CD_BASE_DIR, platform);\n}\n\nasync function getChromedriverBinaryPath (platform = getCurPlatform(), arch = null) {\n  const baseDir = getChromedriverDir(platform);\n  let ext = '';\n  if (platform === 'win') {\n    ext = '.exe';\n  } else if (platform === 'linux') {\n    ext = `_${arch || await system.arch()}`;\n  }\n\n  return path.resolve(baseDir, `chromedriver${ext}`);\n}\n\nfunction getCurPlatform () {\n  return system.isWindows() ? 'win' : (system.isMac() ? 'mac' : 'linux');\n}\n\nfunction getPlatforms () {\n  let plats = [\n    ['win', '32'],\n    ['linux', '64'],\n  ];\n  const cdVer = semver.coerce(CD_VER);\n  // before 2.23 Mac version was 32 bit. After it is 64.\n  plats.push(semver.lt(cdVer, MAC_32_ONLY) ? ['mac', '32'] : ['mac', '64']);\n  // 2.34 and above linux is only supporting 64 bit\n  if (semver.lt(cdVer, LINUX_32_ONLY)) {\n    plats.push(['linux', '32']);\n  }\n  return plats;\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\n\nexport {\n  getChromeVersion, getChromedriverDir, getChromedriverBinaryPath,\n  getCurPlatform, getPlatforms, CD_BASE_DIR, MAC_32_ONLY, LINUX_32_ONLY,\n  CD_CDN, CD_VER, CHROMEDRIVER_CHROME_MAPPING, getMostRecentChromedriver,\n  retrieveData,\n};\n"],"file":"lib/utils.js","sourceRoot":"../.."}
126
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/utils.js"],"names":["rootDir","path","basename","__dirname","resolve","process","env","NO_PRECOMPILE","CHROMEDRIVER_CHROME_MAPPING","require","CD_VER","npm_config_chromedriver_version","CHROMEDRIVER_VERSION","getMostRecentChromedriver","CD_BASE_DIR","CD_CDN","npm_config_chromedriver_cdnurl","CHROMEDRIVER_CDNURL","OS","linux","windows","mac","X64","X86","M1_ARCH_SUFFIX","CD_EXECUTABLE_PREFIX","mapping","_","isEmpty","Error","last","keys","sort","compareVersions","getChromeVersion","adb","bundleId","versionName","getPackageInfo","getChromedriverDir","osName","getOsName","getChromedriverBinaryPath","pathSuffix","paths","fs","glob","cwd","absolute","nocase","nodir","strict","first","retrieveData","url","headers","opts","timeout","responseType","data","memoize","system","isWindows","isMac","getOsInfo","name","arch","hardwareName","trim"],"mappings":"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","sourcesContent":["import _ from 'lodash';\nimport { system, fs } from 'appium-support';\nimport path from 'path';\nimport compareVersions from 'compare-versions';\nimport axios from 'axios';\nimport { exec } from 'teen_process';\n\n\nconst rootDir = path.basename(__dirname) === 'lib'\n  ? path.resolve(__dirname, process.env.NO_PRECOMPILE ? '..' : '../..')\n  : __dirname;\n// Chromedriver version: minimum Chrome version\nconst CHROMEDRIVER_CHROME_MAPPING = require(path.resolve(rootDir, 'config', 'mapping.json'));\n\nconst CD_VER = process.env.npm_config_chromedriver_version\n  || process.env.CHROMEDRIVER_VERSION\n  || getMostRecentChromedriver();\nconst CD_BASE_DIR = path.resolve(__dirname, '..', '..', 'chromedriver');\nconst CD_CDN = process.env.npm_config_chromedriver_cdnurl\n  || process.env.CHROMEDRIVER_CDNURL\n  || 'https://chromedriver.storage.googleapis.com';\nconst OS = {\n  linux: 'linux',\n  windows: 'win',\n  mac: 'mac'\n};\nconst X64 = '64';\nconst X86 = '32';\nconst M1_ARCH_SUFFIX = '_m1';\nconst CD_EXECUTABLE_PREFIX = 'chromedriver';\n\n\nfunction getMostRecentChromedriver (mapping = CHROMEDRIVER_CHROME_MAPPING) {\n  if (_.isEmpty(mapping)) {\n    throw new Error('Unable to get most recent Chromedriver version from empty mapping');\n  }\n  return _.last(_.keys(mapping).sort(compareVersions));\n}\n\nasync function getChromeVersion (adb, bundleId) {\n  const {versionName} = await adb.getPackageInfo(bundleId);\n  return versionName;\n}\n\nfunction getChromedriverDir (osName = getOsName()) {\n  return path.resolve(CD_BASE_DIR, osName);\n}\n\nasync function getChromedriverBinaryPath (osName = getOsName()) {\n  const rootDir = getChromedriverDir(osName);\n  const pathSuffix = osName === OS.windows ? '.exe' : '';\n  const paths = await fs.glob(`${CD_EXECUTABLE_PREFIX}*${pathSuffix}`, {\n    cwd: rootDir,\n    absolute: true,\n    nocase: true,\n    nodir: true,\n    strict: false,\n  });\n  return _.isEmpty(paths)\n    ? path.resolve(rootDir, `${CD_EXECUTABLE_PREFIX}${pathSuffix}`)\n    : _.first(paths);\n}\n\nasync function retrieveData (url, headers, opts = {}) {\n  const {\n    timeout = 5000,\n    responseType = 'text',\n  } = opts;\n  return (await axios({\n    url,\n    headers,\n    timeout,\n    responseType,\n  })).data;\n}\n\nconst getOsName = _.memoize(function getOsName () {\n  if (system.isWindows()) {\n    return OS.windows;\n  }\n  if (system.isMac()) {\n    return OS.mac;\n  }\n  return OS.linux;\n});\n\nconst getOsInfo = _.memoize(async function getOsInfo () {\n  return {\n    name: getOsName(),\n    arch: await system.arch(),\n    hardwareName: system.isWindows() ? null : _.trim(await exec('uname', ['-m'])),\n  };\n});\n\n\nexport {\n  getChromeVersion, getChromedriverDir, getChromedriverBinaryPath, getOsName,\n  CD_BASE_DIR, CD_CDN, CD_VER, CHROMEDRIVER_CHROME_MAPPING, getMostRecentChromedriver,\n  retrieveData, getOsInfo, OS, X64, X86, M1_ARCH_SUFFIX,\n};\n"],"file":"lib/utils.js","sourceRoot":"../.."}
@@ -1,4 +1,8 @@
1
1
  {
2
+ "91.0.4472.101": "91.0.4472.101",
3
+ "91.0.4472.19": "91.0.4472.19",
4
+ "90.0.4430.24": "90.0.4430.24",
5
+ "89.0.4389.23": "89.0.4389.23",
2
6
  "88.0.4324.96": "88.0.4324.96",
3
7
  "87.0.4280.88": "87.0.4280.88",
4
8
  "87.0.4280.20": "87.0.4280.20",
package/lib/install.js CHANGED
@@ -1,135 +1,43 @@
1
- import _ from 'lodash';
2
- import path from 'path';
3
- import { parallel as ll } from 'asyncbox';
4
- import { system, tempDir, fs, zip, mkdirp, net } from 'appium-support';
1
+ import { fs, mkdirp } from 'appium-support';
2
+ import ChromedriverStorageClient from './storage-client';
5
3
  import {
6
- CD_CDN, CD_VER, CD_BASE_DIR, getChromedriverBinaryPath,
7
- getCurPlatform, getPlatforms, MAC_32_ONLY, retrieveData,
4
+ CD_CDN, CD_VER, retrieveData, getOsInfo, getChromedriverDir,
8
5
  } from './utils';
9
- import logger from 'fancy-log';
10
- import semver from 'semver';
11
6
 
12
7
 
13
- function log (line) {
14
- logger(`[Chromedriver Install] ${line}`);
15
- }
16
-
17
- const CD_PLATS = ['linux', 'win', 'mac'];
18
- const CD_ARCHS = ['32', '64'];
19
8
  const DOWNLOAD_TIMEOUT_MS = 15 * 1000;
9
+ const LATEST_VERSION = 'LATEST';
20
10
 
21
- async function getArchAndPlatform () {
22
- let arch = await system.arch();
23
- let platform = getCurPlatform();
24
- if (platform !== 'linux' && platform !== 'mac') {
25
- arch = '32';
26
- }
27
-
28
- const cdVer = semver.coerce(CD_VER);
29
- if (platform === 'mac' && semver.lt(cdVer, MAC_32_ONLY)) {
30
- arch = '32';
31
- }
32
- return {arch, platform};
33
- }
34
-
35
- function getDownloadUrl (version, platform, arch) {
36
- return `${CD_CDN}/${version}/chromedriver_${platform}${arch}.zip`;
37
- }
38
-
39
- function validatePlatform (platform, arch) {
40
- if (!_.includes(CD_PLATS, platform)) {
41
- throw new Error(`Invalid platform: ${platform}`);
42
- }
43
- if (!_.includes(CD_ARCHS, arch)) {
44
- throw new Error(`Invalid arch: ${arch}`);
45
- }
46
- if (arch === '64' && platform !== 'linux' && platform !== 'mac') {
47
- throw new Error('Only linux has a 64-bit version of Chromedriver');
48
- }
49
- }
50
-
51
- async function installForPlatform (version, platform, arch) {
52
- if (version === 'LATEST') {
53
- version = (await retrieveData(`${CD_CDN}/LATEST_RELEASE`, {
11
+ async function formatCdVersion (ver) {
12
+ return ver === LATEST_VERSION
13
+ ? (await retrieveData(`${CD_CDN}/LATEST_RELEASE`, {
54
14
  'user-agent': 'appium',
55
15
  accept: '*/*',
56
- }, { timeout: DOWNLOAD_TIMEOUT_MS })).trim();
57
- }
58
- validatePlatform(platform, arch);
59
-
60
- const url = getDownloadUrl(version, platform, arch);
61
-
62
- log(`Installing Chromedriver version '${version}' for platform '${platform}' and architecture '${arch}'`);
63
-
64
- // set up a temp file to download the chromedriver zipfile to
65
- const binarySpec = `chromedriver_${platform}${arch}`;
66
- log(`Opening temp file to write '${binarySpec}' to...`);
67
- const tempFile = await tempDir.open({
68
- prefix: binarySpec,
69
- suffix: '.zip'
70
- });
71
- log(`Opened temp file '${tempFile.path}'`);
72
-
73
- // actually download the zipfile and write it with appropriate perms
74
- log(`Downloading ${url} to '${tempFile.path}'`);
75
- await net.downloadFile(url, tempFile.path, {timeout: DOWNLOAD_TIMEOUT_MS});
76
- await fs.chmod(tempFile.path, 0o0644);
77
-
78
- // extract downloaded zipfile to tempdir
79
- const tempUnzipped = path.resolve(path.dirname(tempFile.path), binarySpec);
80
- log(`Extracting ${tempFile.path} to ${tempUnzipped}`);
81
- await mkdirp(tempUnzipped);
82
- await zip.extractAllTo(tempFile.path, tempUnzipped);
83
- let extractedBin = path.resolve(tempUnzipped, 'chromedriver');
84
- if (platform === 'win') {
85
- extractedBin += '.exe';
86
- }
87
-
88
- // make build dirs that will hold the chromedriver binary
89
- log(`Creating ${path.resolve(CD_BASE_DIR, platform)}...`);
90
- await mkdirp(path.resolve(CD_BASE_DIR, platform));
91
-
92
- // copy the extracted binary to the correct build dir
93
- const newBin = await getChromedriverBinaryPath(platform, arch);
94
- log(`Copying unzipped binary, reading from ${extractedBin}...`);
95
- const binContents = await fs.readFile(extractedBin, {encoding: 'binary'});
96
- log(`Writing to ${newBin}...`);
97
- await fs.writeFile(newBin, binContents, {encoding: 'binary', mode: 0o755});
98
- log(`${newBin} successfully put in place`);
16
+ }, { timeout: DOWNLOAD_TIMEOUT_MS })).trim()
17
+ : ver;
99
18
  }
100
19
 
101
- async function install () {
102
- const {arch, platform} = await getArchAndPlatform();
103
- await installForPlatform(CD_VER, platform, arch);
104
- }
105
-
106
- async function conditionalInstall () {
107
- const {arch, platform} = await getArchAndPlatform();
108
- const binPath = await getChromedriverBinaryPath(platform, arch);
109
- if (!await fs.exists(binPath)) {
110
- await installForPlatform(CD_VER, platform, arch);
111
- } else {
112
- log(`No need to install chromedriver, ${binPath} exists`);
20
+ async function prepareChromedriverDir (platformName) {
21
+ const chromedriverDir = getChromedriverDir(platformName);
22
+ if (!await fs.exists(chromedriverDir)) {
23
+ await mkdirp(chromedriverDir);
113
24
  }
25
+ return chromedriverDir;
114
26
  }
115
27
 
116
- async function installAll () {
117
- let downloads = [];
118
- for (let [platform, arch] of getPlatforms()) {
119
- downloads.push(installForPlatform(CD_VER, platform, arch));
120
- }
121
- await ll(downloads);
28
+ async function install () {
29
+ const osInfo = await getOsInfo();
30
+ const client = new ChromedriverStorageClient({
31
+ chromedriverDir: await prepareChromedriverDir(osInfo.name),
32
+ });
33
+ await client.syncDrivers({
34
+ osInfo,
35
+ versions: [await formatCdVersion(CD_VER)],
36
+ });
122
37
  }
123
38
 
124
39
  async function doInstall () {
125
- if (_.includes(process.argv, '--all') ||
126
- process.env.npm_config_chromedriver_install_all) {
127
- await installAll();
128
- } else if (_.includes(process.argv, '--conditional')) {
129
- await conditionalInstall();
130
- } else {
131
- await install();
132
- }
40
+ await install();
133
41
  }
134
42
 
135
- export { install, installAll, conditionalInstall, doInstall };
43
+ export { install, doInstall };