OSX 修复 Selenium Chromedriver 启动错误 spawn 未知系统错误 -86 可执行文件中的 CPU 类型错误?

问题描述

2021 年 1 月 6 日下午突然,我在 OSX 下的 Selenium Protractor 测试停止工作,出现神秘错误

spawn UnkNown system error -86

我做了一些研究,发现错误号 86 与

Bad cpu type in executable

并运行以下命令将我的 chromedriver 二进制文件cpu 架构与我的系统进行比较:

% file chromedriver_87.0.4280.88
chromedriver_87.0.4280.88: Mach-O 64-bit executable arm64
% uname -a
Darwin kobl179273m 19.6.0 Darwin Kernel Version 19.6.0: Thu Oct 29 22:56:45 PDT 2020; root:xnu-6153.141.2.2~1/RELEASE_X86_64 x86_64
% uname -p
i386

如何修复 Selenium 使用的 chromedriver 二进制文件,以便它可以在我的 Intel x64 mac 上运行并清除“系统错误 -86”或“cpu 类型错误”消息?

解决方法

问题在 https://github.com/angular/webdriver-manager/issues/476 中进行了描述。 此问题现已在 12.1.8 中修复,因此只需更新到该 webdriver 管理器即可。

对于大多数用户来说,这可以通过

npm uninstall protractor && npm install protractor
,

编辑:此答案应被视为已弃用,因为 webdriver-manager 中的底层错误已得到修复。更好的解决方案是升级到最新版本的 webdriver-manager。如果人们需要使用仍然存在错误的旧版本 webdriver-manager,下面的答案可能会很有用。

根据上面 Deepak Srinivasan 的评论,此错误是由 https://github.com/angular/webdriver-manager/issues/476

引起的

根本原因: ChromeDriver 团队在其 Apple Silicon ARM 版本的 Chromedriver 的文件名末尾添加了“_m1”——但 Silicon 和 Intel 版本的 chromedriver 的文件名中都包含“mac64”,并且版本号完全相同。这导致 webdriver-manager 始终下载 Chromedriver 的 Silicon 版本,即使在 Intel macs 上也是如此。 作为通用解决方案,如果您使用的是 Intel mac,请避免使用文件名中包含 _m1 的 chromedriver。

解决方案 1: 降级到 Chrome 86.0.4240.198 和 Chromedriver 86.0.4240.22。这些版本可以协同工作,并且是对 Silicon ARM 的新的和有问题的支持之前的最新版本

Chrome 86 下载页面: https://google-chrome.en.uptodown.com/mac/download/2920124

在 Chrome 中禁用自动更新:https://superuser.com/questions/1359017/how-do-i-disable-automatic-updates-of-google-chrome-on-mac-os-x

Chrome 驱动程序 86:https://chromedriver.storage.googleapis.com/index.html?path=86.0.4240.22/

% webdriver-manager update --versions.chrome=86.0.4240.22

解决方案 2:修改 webdriver-manager npm 包以指向正确的 chromedriver(感谢来自 angular github issue page 的 ciekaway 对此修复)

修改以下文件

node_modules/webdriver-manager/built/lib/files/file_manager.js

或者,如果使用量角器

node_modules/protractor/node_modules/webdriver-manager/built/lib/files/file_manager.js

在第 166 行附近的 downloadFile 方法顶部,添加以下行以从文件名中删除“_m1”:

fileUrl.url = fileUrl.url.replace(/_m1/,'');

它必须在以 .then 开头的块的开头

binary.getUrl(binary.version()).then(fileUrl => {

它也需要在下一次引用 fileUrl 之前。
例如:

binary.getUrl(binary.version()).then(fileUrl => {
    binary.versionCustom = fileUrl.version;
    fileUrl.url = fileUrl.url.replace(/_m1/,'');
    let filePath = path.resolve(outputDir,binary.filename());

请注意,此解决方案是暂时的。它将被 npm 安装覆盖。 Chromedriver 和/或 webdriver-manager 团队可能会解决此问题,此时您应该清除 webdriver-manager 的修改版本并从 npm 下载修复程序。

,
npm uninstall protractor && npm install protractor
,

适用于 macOS Catalina 版本 10.15.6 (19G73)

就我而言,我使用 Rails 和 Capybara 进行功能测试。对我有用的是

  1. 首先,找到实际运行的 chromedriver 位置:

    which chromedriver
    
    # Which returned:
    
    /Users/alex/.webdrivers/chromedriver
    
  2. 然后,通过 Homebrew 安装 chromedriver

    brew install chromedriver
    
  3. 然后,删除在先前位置找到的旧 chromedriver 引用:

    rm /Users/alex/.webdrivers/chromedriver
    
  4. 现在,将旧的 chromedriver 引用链接到使用 brew 安装的引用:

    ln -s /usr/local/bin/chromedriver /Users/alex/.webdrivers/chromedriver
    
  5. 然后,打开Finder应用程序,然后点击Go菜单,然后点击Go to folder ...选项,输入这条路线:

    /usr/local/Caskroom/chromedriver/
    
  6. 在那里您应该会看到一个包含您安装的 chromedriver 版本的文件夹,如下所示:

    88.0.4324.96
    
  7. 进入该文件夹,您应该会看到 chromedriver 二进制文件。

  8. 右键单击它,然后单击 Open

    现在,您应该会弹出一个带有输出的终端窗口:

    Last login: Sun Jan 31 12:29:15 on ttys001
    /usr/local/Caskroom/chromedriver/88.0.4324.96/chromedriver ; exit;
       ~  /usr/local/Caskroom/chromedriver/88.0.4324.96/chromedriver ; exit;
    Starting ChromeDriver 88.0.4324.96 (68dba2d8a0b149a1d3afac56fa74648032bcf46b-    refs/branch-heads/4324@{#1784}) on port 9515
    Only local connections are allowed.
    Please see https://chromedriver.chromium.org/security-considerations for suggestions on keeping ChromeDriver safe.
    ChromeDriver was started successfully.
    
  9. 最后,按 Ctrl+C 停止执行并退出终端窗口。

现在,您应该可以运行水豚测试了。

,

如果您使用 webdrivers gem,请升级它:

bundle update webdrivers