15

突然在 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 类型”消息?

4

5 回答 5

15

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

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

npm uninstall protractor && npm install protractor
于 2021-01-11T11:06:39.887 回答
11

编辑:由于 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 mac 上也是如此。 作为一般解决方案,如果您在 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

Chromedriver 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(感谢 ciekaway 来自angular github 问题页面的此修复)

修改以下文件

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 install 覆盖。Chromedriver 和/或 webdriver-manager 团队可能会解决此问题,此时您应该清除 webdriver-manager 的修改版本并从 npm 下载修复程序。

于 2021-01-08T17:20:57.987 回答
3
npm uninstall protractor && npm install protractor
于 2021-01-28T21:42:48.743 回答
3

适用于 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停止执行并退出终端窗口。

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

于 2021-01-31T19:22:40.220 回答
0

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

bundle update webdrivers
于 2021-05-11T11:55:53.907 回答