appium-chromedriver 5.2.15 → 5.2.16

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/CHANGELOG.md CHANGED
@@ -1,3 +1,10 @@
1
+ ## [5.2.16](https://github.com/appium/appium-chromedriver/compare/v5.2.15...v5.2.16) (2023-02-02)
2
+
3
+
4
+ ### Bug Fixes
5
+
6
+ * Update Apple ARM architecture detection ([#287](https://github.com/appium/appium-chromedriver/issues/287)) ([a10d2d9](https://github.com/appium/appium-chromedriver/commit/a10d2d90f66632dd161aae47a95771fb1c7b5497))
7
+
1
8
  ## [5.2.15](https://github.com/appium/appium-chromedriver/compare/v5.2.14...v5.2.15) (2023-01-17)
2
9
 
3
10
 
@@ -12,6 +12,7 @@ var _xpath = _interopRequireDefault(require("xpath"));
12
12
  var _xmldom = require("@xmldom/xmldom");
13
13
  var _bluebird = _interopRequireDefault(require("bluebird"));
14
14
  var _path = _interopRequireDefault(require("path"));
15
+ var _os = _interopRequireDefault(require("os"));
15
16
  var _support = require("@appium/support");
16
17
  const TIMEOUT_MS = 15000;
17
18
  const MAX_PARALLEL_DOWNLOADS = 5;
@@ -191,14 +192,18 @@ class ChromedriverStorageClient {
191
192
  if (!_lodash.default.isEmpty(osInfo)) {
192
193
  let {
193
194
  name,
194
- arch,
195
- hardwareName
195
+ arch
196
196
  } = osInfo;
197
197
  if (arch === _utils.X64 && !driversToSync.some(cdName => cdName.includes(`_${name}${_utils.X64}`))) {
198
198
  arch = _utils.X86;
199
199
  }
200
- if (name === _utils.OS.mac && _lodash.default.includes(hardwareName, 'arm') && driversToSync.some(cdName => cdName.includes(_utils.M1_ARCH_SUFFIX))) {
201
- arch += _utils.M1_ARCH_SUFFIX;
200
+ if (name === _utils.OS.mac && _lodash.default.includes(_lodash.default.toLower(_os.default.cpus()[0].model), 'apple')) {
201
+ for (const armSuffix of _utils.APPLE_ARM_SUFFIXES) {
202
+ if (driversToSync.some(cdName => cdName.includes(armSuffix))) {
203
+ arch = armSuffix;
204
+ break;
205
+ }
206
+ }
202
207
  }
203
208
  log.debug(`Selecting chromedrivers whose platform matches to ${name}${arch}`);
204
209
  const platformRe = new RegExp(`(\\b|_)${name}${arch}\\b`);
@@ -292,4 +297,4 @@ class ChromedriverStorageClient {
292
297
  }
293
298
  var _default = ChromedriverStorageClient;
294
299
  exports.default = _default;
295
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"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","getChromedriverDir","timeout","mapping","parseNotes","content","result","versionMatch","exec","version","minBrowserVersionMatch","minBrowserVersion","retrieveAdditionalDriverInfo","driverKey","notesUrl","infoDict","notes","retrieveData","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","getOsInfo","JSON","stringify","synchronizedDrivers","idx","entries"],"sources":["../../lib/storage-client.js"],"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"],"mappings":"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"}
300
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"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","getChromedriverDir","timeout","mapping","parseNotes","content","result","versionMatch","exec","version","minBrowserVersionMatch","minBrowserVersion","retrieveAdditionalDriverInfo","driverKey","notesUrl","infoDict","notes","retrieveData","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","X64","some","X86","OS","mac","os","cpus","model","armSuffix","APPLE_ARM_SUFFIXES","platformRe","RegExp","test","retrieveDriver","index","archivesRoot","isStrict","archivePath","resolve","net","downloadFile","isMetered","e","msg","message","error","fileName","system","isWindows","targetPath","chmod","syncDrivers","getOsInfo","JSON","stringify","synchronizedDrivers","idx","entries"],"sources":["../../lib/storage-client.js"],"sourcesContent":["import {\n  getChromedriverDir, CD_CDN, retrieveData, getOsInfo,\n  OS, X64, X86, APPLE_ARM_SUFFIXES,\n} from './utils';\nimport _ from 'lodash';\nimport xpath from 'xpath';\nimport { DOMParser } from '@xmldom/xmldom';\nimport B from 'bluebird';\nimport path from 'path';\nimport os from 'os';\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 OS.\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 === 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      // https://stackoverflow.com/questions/65146751/detecting-apple-silicon-mac-in-javascript\n      if (name === OS.mac && _.includes(_.toLower(os.cpus()[0].model), 'apple')) {\n        for (const armSuffix of APPLE_ARM_SUFFIXES) {\n          if (driversToSync.some((cdName) => cdName.includes(armSuffix))) {\n            // prefer executable for ARM arch if present\n            arch = armSuffix;\n            break;\n          }\n        }\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"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"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","getChromedriverDir","timeout","mapping","parseNotes","content","result","versionMatch","exec","version","minBrowserVersionMatch","minBrowserVersion","retrieveAdditionalDriverInfo","driverKey","notesUrl","infoDict","notes","retrieveData","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","getOsInfo","JSON","stringify","synchronizedDrivers","idx","entries"],"sources":["../../lib/storage-client.js"],"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"],"mappings":"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"}
1
+ {"version":3,"file":"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","getChromedriverDir","timeout","mapping","parseNotes","content","result","versionMatch","exec","version","minBrowserVersionMatch","minBrowserVersion","retrieveAdditionalDriverInfo","driverKey","notesUrl","infoDict","notes","retrieveData","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","X64","some","X86","OS","mac","os","cpus","model","armSuffix","APPLE_ARM_SUFFIXES","platformRe","RegExp","test","retrieveDriver","index","archivesRoot","isStrict","archivePath","resolve","net","downloadFile","isMetered","e","msg","message","error","fileName","system","isWindows","targetPath","chmod","syncDrivers","getOsInfo","JSON","stringify","synchronizedDrivers","idx","entries"],"sources":["../../lib/storage-client.js"],"sourcesContent":["import {\n getChromedriverDir, CD_CDN, retrieveData, getOsInfo,\n OS, X64, X86, APPLE_ARM_SUFFIXES,\n} from './utils';\nimport _ from 'lodash';\nimport xpath from 'xpath';\nimport { DOMParser } from '@xmldom/xmldom';\nimport B from 'bluebird';\nimport path from 'path';\nimport os from 'os';\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 OS.\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 === 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 // https://stackoverflow.com/questions/65146751/detecting-apple-silicon-mac-in-javascript\n if (name === OS.mac && _.includes(_.toLower(os.cpus()[0].model), 'apple')) {\n for (const armSuffix of APPLE_ARM_SUFFIXES) {\n if (driversToSync.some((cdName) => cdName.includes(armSuffix))) {\n // prefer executable for ARM arch if present\n arch = armSuffix;\n break;\n }\n }\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"],"mappings":"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"}
@@ -4,7 +4,7 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
4
4
  Object.defineProperty(exports, "__esModule", {
5
5
  value: true
6
6
  });
7
- 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;
7
+ exports.X86 = exports.X64 = exports.OS = exports.CHROMEDRIVER_CHROME_MAPPING = exports.CD_VER = exports.CD_CDN = exports.CD_BASE_DIR = exports.APPLE_ARM_SUFFIXES = void 0;
8
8
  exports.generateLogPrefix = generateLogPrefix;
9
9
  exports.getChromeVersion = getChromeVersion;
10
10
  exports.getChromedriverBinaryPath = getChromedriverBinaryPath;
@@ -19,7 +19,6 @@ var _baseDriver = require("@appium/base-driver");
19
19
  var _path = _interopRequireDefault(require("path"));
20
20
  var _compareVersions = require("compare-versions");
21
21
  var _axios = _interopRequireDefault(require("axios"));
22
- var _teen_process = require("teen_process");
23
22
  const CD_CDN = process.env.npm_config_chromedriver_cdnurl || process.env.CHROMEDRIVER_CDNURL || 'https://chromedriver.storage.googleapis.com';
24
23
  exports.CD_CDN = CD_CDN;
25
24
  const OS = {
@@ -32,8 +31,8 @@ const X64 = '64';
32
31
  exports.X64 = X64;
33
32
  const X86 = '32';
34
33
  exports.X86 = X86;
35
- const M1_ARCH_SUFFIX = '_m1';
36
- exports.M1_ARCH_SUFFIX = M1_ARCH_SUFFIX;
34
+ const APPLE_ARM_SUFFIXES = ['64_m1', '_arm64'];
35
+ exports.APPLE_ARM_SUFFIXES = APPLE_ARM_SUFFIXES;
37
36
  const CD_EXECUTABLE_PREFIX = 'chromedriver';
38
37
  const MODULE_NAME = 'appium-chromedriver';
39
38
  const getModuleRoot = _lodash.default.memoize(function getModuleRoot() {
@@ -101,8 +100,7 @@ exports.getOsName = getOsName;
101
100
  const getOsInfo = _lodash.default.memoize(async function getOsInfo() {
102
101
  return {
103
102
  name: getOsName(),
104
- arch: await _support.system.arch(),
105
- hardwareName: _support.system.isWindows() ? null : _lodash.default.trim(await (0, _teen_process.exec)('uname', ['-m']))
103
+ arch: await _support.system.arch()
106
104
  };
107
105
  });
108
106
  exports.getOsInfo = getOsInfo;
@@ -110,4 +108,4 @@ const getBaseDriverInstance = _lodash.default.memoize(() => new _baseDriver.Base
110
108
  function generateLogPrefix(obj, sessionId = null) {
111
109
  return getBaseDriverInstance().helpers.generateDriverLogPrefix(obj, sessionId);
112
110
  }
113
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["CD_CDN","process","env","npm_config_chromedriver_cdnurl","CHROMEDRIVER_CDNURL","OS","linux","windows","mac","X64","X86","M1_ARCH_SUFFIX","CD_EXECUTABLE_PREFIX","MODULE_NAME","getModuleRoot","_","memoize","root","node","getModuleRootSync","__filename","Error","CHROMEDRIVER_CHROME_MAPPING","require","path","join","CD_BASE_DIR","getMostRecentChromedriver","mapping","isEmpty","last","keys","sort","compareVersions","CD_VER","npm_config_chromedriver_version","CHROMEDRIVER_VERSION","getChromeVersion","adb","bundleId","versionName","getPackageInfo","getChromedriverDir","osName","getOsName","resolve","getChromedriverBinaryPath","rootDir","pathSuffix","paths","fs","glob","cwd","absolute","nocase","nodir","strict","first","retrieveData","url","headers","opts","timeout","responseType","axios","data","system","isWindows","isMac","getOsInfo","name","arch","hardwareName","trim","exec","getBaseDriverInstance","BaseDriver","generateLogPrefix","obj","sessionId","helpers","generateDriverLogPrefix"],"sources":["../../lib/utils.js"],"sourcesContent":["import _ from 'lodash';\nimport { system, fs, node } from '@appium/support';\nimport { BaseDriver } from '@appium/base-driver';\nimport path from 'path';\nimport { compareVersions } from 'compare-versions';\nimport axios from 'axios';\nimport { exec } from 'teen_process';\n\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';\nconst MODULE_NAME = 'appium-chromedriver';\n\n/**\n * Calculates the path to the current module's root folder\n *\n * @returns {string} The full path to module root\n * @throws {Error} If the current module root folder cannot be determined\n */\nconst getModuleRoot = _.memoize(function getModuleRoot () {\n  const root = node.getModuleRootSync(MODULE_NAME, __filename);\n  if (!root) {\n    throw new Error(`Cannot find the root folder of the ${MODULE_NAME} Node.js module`);\n  }\n  return root;\n});\n\n// Chromedriver version: minimum Chrome version\nconst CHROMEDRIVER_CHROME_MAPPING = require(path.join(getModuleRoot(), 'config', 'mapping.json'));\nconst CD_BASE_DIR = path.join(getModuleRoot(), 'chromedriver');\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\nconst CD_VER = process.env.npm_config_chromedriver_version\n  || process.env.CHROMEDRIVER_VERSION\n  || getMostRecentChromedriver();\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\nconst getBaseDriverInstance = _.memoize(() => new BaseDriver({}, false));\n\n/**\n * Generates log prefix string\n *\n * @param {object} obj log owner instance\n * @param {string?} sessionId Optional session identifier\n * @returns {string}\n */\nfunction generateLogPrefix (obj, sessionId = null) {\n  return getBaseDriverInstance().helpers.generateDriverLogPrefix(obj, sessionId);\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, generateLogPrefix,\n};\n"],"mappings":"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"}
111
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["CD_CDN","process","env","npm_config_chromedriver_cdnurl","CHROMEDRIVER_CDNURL","OS","linux","windows","mac","X64","X86","APPLE_ARM_SUFFIXES","CD_EXECUTABLE_PREFIX","MODULE_NAME","getModuleRoot","_","memoize","root","node","getModuleRootSync","__filename","Error","CHROMEDRIVER_CHROME_MAPPING","require","path","join","CD_BASE_DIR","getMostRecentChromedriver","mapping","isEmpty","last","keys","sort","compareVersions","CD_VER","npm_config_chromedriver_version","CHROMEDRIVER_VERSION","getChromeVersion","adb","bundleId","versionName","getPackageInfo","getChromedriverDir","osName","getOsName","resolve","getChromedriverBinaryPath","rootDir","pathSuffix","paths","fs","glob","cwd","absolute","nocase","nodir","strict","first","retrieveData","url","headers","opts","timeout","responseType","axios","data","system","isWindows","isMac","getOsInfo","name","arch","getBaseDriverInstance","BaseDriver","generateLogPrefix","obj","sessionId","helpers","generateDriverLogPrefix"],"sources":["../../lib/utils.js"],"sourcesContent":["import _ from 'lodash';\nimport { system, fs, node } from '@appium/support';\nimport { BaseDriver } from '@appium/base-driver';\nimport path from 'path';\nimport { compareVersions } from 'compare-versions';\nimport axios from 'axios';\n\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 APPLE_ARM_SUFFIXES = ['64_m1', '_arm64'];\nconst CD_EXECUTABLE_PREFIX = 'chromedriver';\nconst MODULE_NAME = 'appium-chromedriver';\n\n/**\n * Calculates the path to the current module's root folder\n *\n * @returns {string} The full path to module root\n * @throws {Error} If the current module root folder cannot be determined\n */\nconst getModuleRoot = _.memoize(function getModuleRoot () {\n  const root = node.getModuleRootSync(MODULE_NAME, __filename);\n  if (!root) {\n    throw new Error(`Cannot find the root folder of the ${MODULE_NAME} Node.js module`);\n  }\n  return root;\n});\n\n// Chromedriver version: minimum Chrome version\nconst CHROMEDRIVER_CHROME_MAPPING = require(path.join(getModuleRoot(), 'config', 'mapping.json'));\nconst CD_BASE_DIR = path.join(getModuleRoot(), 'chromedriver');\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\nconst CD_VER = process.env.npm_config_chromedriver_version\n  || process.env.CHROMEDRIVER_VERSION\n  || getMostRecentChromedriver();\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  };\n});\n\nconst getBaseDriverInstance = _.memoize(() => new BaseDriver({}, false));\n\n/**\n * Generates log prefix string\n *\n * @param {object} obj log owner instance\n * @param {string?} sessionId Optional session identifier\n * @returns {string}\n */\nfunction generateLogPrefix (obj, sessionId = null) {\n  return getBaseDriverInstance().helpers.generateDriverLogPrefix(obj, sessionId);\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, APPLE_ARM_SUFFIXES, generateLogPrefix,\n};\n"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"utils.js","names":["CD_CDN","process","env","npm_config_chromedriver_cdnurl","CHROMEDRIVER_CDNURL","OS","linux","windows","mac","X64","X86","M1_ARCH_SUFFIX","CD_EXECUTABLE_PREFIX","MODULE_NAME","getModuleRoot","_","memoize","root","node","getModuleRootSync","__filename","Error","CHROMEDRIVER_CHROME_MAPPING","require","path","join","CD_BASE_DIR","getMostRecentChromedriver","mapping","isEmpty","last","keys","sort","compareVersions","CD_VER","npm_config_chromedriver_version","CHROMEDRIVER_VERSION","getChromeVersion","adb","bundleId","versionName","getPackageInfo","getChromedriverDir","osName","getOsName","resolve","getChromedriverBinaryPath","rootDir","pathSuffix","paths","fs","glob","cwd","absolute","nocase","nodir","strict","first","retrieveData","url","headers","opts","timeout","responseType","axios","data","system","isWindows","isMac","getOsInfo","name","arch","hardwareName","trim","exec","getBaseDriverInstance","BaseDriver","generateLogPrefix","obj","sessionId","helpers","generateDriverLogPrefix"],"sources":["../../lib/utils.js"],"sourcesContent":["import _ from 'lodash';\nimport { system, fs, node } from '@appium/support';\nimport { BaseDriver } from '@appium/base-driver';\nimport path from 'path';\nimport { compareVersions } from 'compare-versions';\nimport axios from 'axios';\nimport { exec } from 'teen_process';\n\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';\nconst MODULE_NAME = 'appium-chromedriver';\n\n/**\n * Calculates the path to the current module's root folder\n *\n * @returns {string} The full path to module root\n * @throws {Error} If the current module root folder cannot be determined\n */\nconst getModuleRoot = _.memoize(function getModuleRoot () {\n const root = node.getModuleRootSync(MODULE_NAME, __filename);\n if (!root) {\n throw new Error(`Cannot find the root folder of the ${MODULE_NAME} Node.js module`);\n }\n return root;\n});\n\n// Chromedriver version: minimum Chrome version\nconst CHROMEDRIVER_CHROME_MAPPING = require(path.join(getModuleRoot(), 'config', 'mapping.json'));\nconst CD_BASE_DIR = path.join(getModuleRoot(), 'chromedriver');\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\nconst CD_VER = process.env.npm_config_chromedriver_version\n || process.env.CHROMEDRIVER_VERSION\n || getMostRecentChromedriver();\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\nconst getBaseDriverInstance = _.memoize(() => new BaseDriver({}, false));\n\n/**\n * Generates log prefix string\n *\n * @param {object} obj log owner instance\n * @param {string?} sessionId Optional session identifier\n * @returns {string}\n */\nfunction generateLogPrefix (obj, sessionId = null) {\n return getBaseDriverInstance().helpers.generateDriverLogPrefix(obj, sessionId);\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, generateLogPrefix,\n};\n"],"mappings":"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"}
1
+ {"version":3,"file":"utils.js","names":["CD_CDN","process","env","npm_config_chromedriver_cdnurl","CHROMEDRIVER_CDNURL","OS","linux","windows","mac","X64","X86","APPLE_ARM_SUFFIXES","CD_EXECUTABLE_PREFIX","MODULE_NAME","getModuleRoot","_","memoize","root","node","getModuleRootSync","__filename","Error","CHROMEDRIVER_CHROME_MAPPING","require","path","join","CD_BASE_DIR","getMostRecentChromedriver","mapping","isEmpty","last","keys","sort","compareVersions","CD_VER","npm_config_chromedriver_version","CHROMEDRIVER_VERSION","getChromeVersion","adb","bundleId","versionName","getPackageInfo","getChromedriverDir","osName","getOsName","resolve","getChromedriverBinaryPath","rootDir","pathSuffix","paths","fs","glob","cwd","absolute","nocase","nodir","strict","first","retrieveData","url","headers","opts","timeout","responseType","axios","data","system","isWindows","isMac","getOsInfo","name","arch","getBaseDriverInstance","BaseDriver","generateLogPrefix","obj","sessionId","helpers","generateDriverLogPrefix"],"sources":["../../lib/utils.js"],"sourcesContent":["import _ from 'lodash';\nimport { system, fs, node } from '@appium/support';\nimport { BaseDriver } from '@appium/base-driver';\nimport path from 'path';\nimport { compareVersions } from 'compare-versions';\nimport axios from 'axios';\n\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 APPLE_ARM_SUFFIXES = ['64_m1', '_arm64'];\nconst CD_EXECUTABLE_PREFIX = 'chromedriver';\nconst MODULE_NAME = 'appium-chromedriver';\n\n/**\n * Calculates the path to the current module's root folder\n *\n * @returns {string} The full path to module root\n * @throws {Error} If the current module root folder cannot be determined\n */\nconst getModuleRoot = _.memoize(function getModuleRoot () {\n const root = node.getModuleRootSync(MODULE_NAME, __filename);\n if (!root) {\n throw new Error(`Cannot find the root folder of the ${MODULE_NAME} Node.js module`);\n }\n return root;\n});\n\n// Chromedriver version: minimum Chrome version\nconst CHROMEDRIVER_CHROME_MAPPING = require(path.join(getModuleRoot(), 'config', 'mapping.json'));\nconst CD_BASE_DIR = path.join(getModuleRoot(), 'chromedriver');\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\nconst CD_VER = process.env.npm_config_chromedriver_version\n || process.env.CHROMEDRIVER_VERSION\n || getMostRecentChromedriver();\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 };\n});\n\nconst getBaseDriverInstance = _.memoize(() => new BaseDriver({}, false));\n\n/**\n * Generates log prefix string\n *\n * @param {object} obj log owner instance\n * @param {string?} sessionId Optional session identifier\n * @returns {string}\n */\nfunction generateLogPrefix (obj, sessionId = null) {\n return getBaseDriverInstance().helpers.generateDriverLogPrefix(obj, sessionId);\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, APPLE_ARM_SUFFIXES, generateLogPrefix,\n};\n"],"mappings":"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"}
@@ -1,12 +1,13 @@
1
1
  import {
2
2
  getChromedriverDir, CD_CDN, retrieveData, getOsInfo,
3
- OS, X64, X86, M1_ARCH_SUFFIX,
3
+ OS, X64, X86, APPLE_ARM_SUFFIXES,
4
4
  } from './utils';
5
5
  import _ from 'lodash';
6
6
  import xpath from 'xpath';
7
7
  import { DOMParser } from '@xmldom/xmldom';
8
8
  import B from 'bluebird';
9
9
  import path from 'path';
10
+ import os from 'os';
10
11
  import { system, fs, logger, tempDir, zip, util, net } from '@appium/support';
11
12
 
12
13
 
@@ -241,10 +242,8 @@ class ChromedriverStorageClient {
241
242
  * @typedef {Object} OSInfo
242
243
  * @property {string} name - The name of the host OS
243
244
  * Can be either `mac`, `windows` or `linux`
244
- * @property {string} arch - The architecture of the host OD.
245
+ * @property {string} arch - The architecture of the host OS.
245
246
  * Can be either `32` or `64`
246
- * @property {?string} hardwareName - The output of `uname -m` command
247
- * on linux and mac systems. `null` on Windows
248
247
  */
249
248
 
250
249
  /**
@@ -303,15 +302,20 @@ class ChromedriverStorageClient {
303
302
 
304
303
  if (!_.isEmpty(osInfo)) {
305
304
  // Filter out drivers for unsupported system architectures
306
- let {name, arch, hardwareName} = osInfo;
305
+ let {name, arch} = osInfo;
307
306
  if (arch === X64 && !driversToSync.some((cdName) => cdName.includes(`_${name}${X64}`))) {
308
307
  // Fall back to x86 build if x64 one is not available for the given OS
309
308
  arch = X86;
310
309
  }
311
- if (name === OS.mac && _.includes(hardwareName, 'arm')
312
- && driversToSync.some((cdName) => cdName.includes(M1_ARCH_SUFFIX))) {
313
- // prefer executable for M1 arch if present
314
- arch += M1_ARCH_SUFFIX;
310
+ // https://stackoverflow.com/questions/65146751/detecting-apple-silicon-mac-in-javascript
311
+ if (name === OS.mac && _.includes(_.toLower(os.cpus()[0].model), 'apple')) {
312
+ for (const armSuffix of APPLE_ARM_SUFFIXES) {
313
+ if (driversToSync.some((cdName) => cdName.includes(armSuffix))) {
314
+ // prefer executable for ARM arch if present
315
+ arch = armSuffix;
316
+ break;
317
+ }
318
+ }
315
319
  }
316
320
  log.debug(`Selecting chromedrivers whose platform matches to ${name}${arch}`);
317
321
  const platformRe = new RegExp(`(\\b|_)${name}${arch}\\b`);
package/lib/utils.js CHANGED
@@ -4,7 +4,6 @@ import { BaseDriver } from '@appium/base-driver';
4
4
  import path from 'path';
5
5
  import { compareVersions } from 'compare-versions';
6
6
  import axios from 'axios';
7
- import { exec } from 'teen_process';
8
7
 
9
8
  const CD_CDN = process.env.npm_config_chromedriver_cdnurl
10
9
  || process.env.CHROMEDRIVER_CDNURL
@@ -16,7 +15,7 @@ const OS = {
16
15
  };
17
16
  const X64 = '64';
18
17
  const X86 = '32';
19
- const M1_ARCH_SUFFIX = '_m1';
18
+ const APPLE_ARM_SUFFIXES = ['64_m1', '_arm64'];
20
19
  const CD_EXECUTABLE_PREFIX = 'chromedriver';
21
20
  const MODULE_NAME = 'appium-chromedriver';
22
21
 
@@ -100,7 +99,6 @@ const getOsInfo = _.memoize(async function getOsInfo () {
100
99
  return {
101
100
  name: getOsName(),
102
101
  arch: await system.arch(),
103
- hardwareName: system.isWindows() ? null : _.trim(await exec('uname', ['-m'])),
104
102
  };
105
103
  });
106
104
 
@@ -121,5 +119,5 @@ function generateLogPrefix (obj, sessionId = null) {
121
119
  export {
122
120
  getChromeVersion, getChromedriverDir, getChromedriverBinaryPath, getOsName,
123
121
  CD_BASE_DIR, CD_CDN, CD_VER, CHROMEDRIVER_CHROME_MAPPING, getMostRecentChromedriver,
124
- retrieveData, getOsInfo, OS, X64, X86, M1_ARCH_SUFFIX, generateLogPrefix,
122
+ retrieveData, getOsInfo, OS, X64, X86, APPLE_ARM_SUFFIXES, generateLogPrefix,
125
123
  };
package/package.json CHANGED
@@ -6,7 +6,7 @@
6
6
  "chrome",
7
7
  "android"
8
8
  ],
9
- "version": "5.2.15",
9
+ "version": "5.2.16",
10
10
  "author": "Appium Contributors",
11
11
  "license": "Apache-2.0",
12
12
  "repository": {