Net::ReadTimeout: Net::ReadTimeout 和 Selenium::WebDriver::Error::UnknownError: 未知错误:Chrome 无法在 Rails 5.1.beta 系统测试上启动

2024-02-27

热衷于将 Capybara 烘焙到新版 Rails (5.1) cfhttp://weblog.rubyonrails.org/2017/2/23/Rails-5-1-beta1/ http://weblog.rubyonrails.org/2017/2/23/Rails-5-1-beta1/

不过我遇到了问题。这是我的步骤。欢迎任何线索。

全新安装:

  • Linux Ubuntu Desktop 16.10(Hyper-V 上的虚拟机),安装了 Chrome 并运行良好;
  • 红宝石 2.4;
  • Rails 5.1.beta。

1.- 创建一个简单的应用程序:

    ~$ ruby -v
    ruby 2.4.0p0 (2016-12-24 revision 57164) [x86_64-linux]
    ~$ rails -v
    Rails 5.1.0.beta1
    ~$ mkdir railsapps
    ~$ cd railsapps
    ~/railsapps$ rails new smoketestapp
    ~/railsapps$ cd smoketestapp
    ~/railsapps/smoketestapp$ rails generate scaffold post title:string body:text
    ~/railsapps/smoketestapp$ rails db:migrate

2.- 运行测试

    ~/railsapps/smoketestapp$ cat test/system/posts_test.rb
    require "application_system_test_case"

    class PostsTest < ApplicationSystemTestCase
      test "visiting the index" do
        visit posts_url

        assert_selector "h1", text: "Post"
      end
    end

     ~/railsapps/smoketestapp$ rake test TEST=test/system/posts_test.rb
    Run options: --seed 55778

    # Running:
    ...
    Error:
    PostsTest#test_visiting_the_index:
    Selenium::WebDriver::Error::WebDriverError: Unable to find chromedriver. Please download the server from http://chromedriver.storage.googleapis.com/index.html and place it somewhere on your PATH. More info at https://github.com/SeleniumHQ/selenium/wiki/ChromeDriver.
    ...
    1 runs, 0 assertions, 0 failures, 1 errors, 0 skips
     ~/railsapps/smoketestapp$

3.- 好的,让我们按照错误消息中的建议进行操作(安装chromedriver) :

     ~/railsapps/smoketestapp$ ls /usr/bin/google-chrome
    lrwxrwxrwx 1 root root 31 Mar 18 15:31 /usr/bin/google-chrome -> /etc/alternatives/google-chrome*
     ~/railsapps/smoketestapp$ echo $PATH 
    ...:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:...
     ~/railsapps/smoketestapp$ wget https://chromedriver.storage.googleapis.com/2.28/chromedriver_linux64.zip
     ~/railsapps/smoketestapp$ unzip chromedriver_linux64.zip
     ~/railsapps/smoketestapp$ sudo cp chromedriver /usr/local/bin
     ~/railsapps/smoketestapp$ ls /usr/local/bin
    total 7504
    drwxr-xr-x  2 root root    4096 Mar 19 19:05 ./
    drwxr-xr-x 10 root root    4096 Okt 12 22:42 ../
    -rwxr-xr-x  1 root root 7673176 Mar 19 19:05 chromedriver*
     ~/railsapps/smoketestapp$

4.- 好的。重试测试...

     ~/railsapps/smoketestapp$ rake test TEST=test/system/posts_test.rb
    Run options: --seed 51574

    # Running:
    ...
    Error:
    PostsTest#test_visiting_the_index:
    Net::ReadTimeout: Net::ReadTimeout test/system/posts _test.rb:5:in `block in '
    ...
    bin/rails test test/system/posts_test.rb:4
    ...
    1 runs, 0 assertions, 0 failures, 1 errors, 0 skips
     ~/railsapps/smoketestapp$

Not OK!

关于根本原因的线索'Net::ReadTimeout: Net::ReadTimeout'运行时给出错误信息rails -v在应用程序目录中,给出Selenium::WebDriver::Error::UnknownError: 未知错误:Chrome 无法启动:

    ~/railsapps/smoketestapp$ rails -v
    Run options: --seed 39896
    # Running:
    .......E
    Error:
    PostsTest#test_visiting_the_index:
    Selenium::WebDriver::Error::UnknownError: unknown error: Chrome failed to start: exited abnormally
      (Driver info: chromedriver=2.28.455506  (18f6627e265f442aeec9b6661a49fe819aeeea1f),platform=Linux 4.8.0-41-generic x86_64)
        test/system/posts_test.rb:5:in `block in <class:PostsTest>'
    Error:
    PostsTest#test_visiting_the_index:
    Net::ReadTimeout: Net::ReadTimeout

    bin/rails test test/system/posts_test.rb:4
    ...
    ~/railsapps/smoketestapp$

这是我直接从 Ruby 调用 Selenium WebDriver 时得到的结果:

    ~/railsapps/smoketestapp$ irb
    2.4.0 :001 > require "selenium-webdriver"
     => true
    2.4.0 :002 > driver = Selenium::WebDriver.for(:chrome)
    Net::ReadTimeout: Net::ReadTimeout
    from ~/.rvm/rubies/ruby-2.4.0/lib/ruby/2.4.0/net/protocol.rb:176:in `rbuf_fill'
    from ~/.rvm/rubies/ruby-2.4.0/lib/ruby/2.4.0/net/protocol.rb:154:in `readuntil'
    from ~/.rvm/rubies/ruby-2.4.0/lib/ruby/2.4.0/net/protocol.rb:164:in `readline'
    from ~/.rvm/rubies/ruby-2.4.0/lib/ruby/2.4.0/net/http/response.rb:40:in `read_status_line'
    from ~/.rvm/rubies/ruby-2.4.0/lib/ruby/2.4.0/net/http/response.rb:29:in `read_new'
    from ~/.rvm/rubies/ruby-2.4.0/lib/ruby/2.4.0/net/http.rb:1446:in `block in transport_request'
    from ~/.rvm/rubies/ruby-2.4.0/lib/ruby/2.4.0/net/http.rb:1443:in `catch'
    from ~/.rvm/rubies/ruby-2.4.0/lib/ruby/2.4.0/net/http.rb:1443:in `transport_request'
    from ~/.rvm/rubies/ruby-2.4.0/lib/ruby/2.4.0/net/http.rb:1416:in `request'
    from ~/.rvm/rubies/ruby-2.4.0/lib/ruby/2.4.0/net/http.rb:1409:in `block in request'
    from ~/.rvm/rubies/ruby-2.4.0/lib/ruby/2.4.0/net/http.rb:877:in `start'
    from ~/.rvm/rubies/ruby-2.4.0/lib/ruby/2.4.0/net/http.rb:1407:in `request'
    from ~/.rvm/gems/ruby-2.4.0/gems/selenium-webdriver-3.3.0/lib/selenium/webdriver/remote/http/default.rb:124:in `response_for'
    from ~/.rvm/gems/ruby-2.4.0/gems/selenium-webdriver-3.3.0/lib/selenium/webdriver/remote/http/default.rb:78:in `request'
    from ~/.rvm/gems/ruby-2.4.0/gems/selenium-webdriver-3.3.0/lib/selenium/webdriver/remote/http/common.rb:61:in `call'
    from ~/.rvm/gems/ruby-2.4.0/gems/selenium-webdriver-3.3.0/lib/selenium/webdriver/remote/bridge.rb:669:in `raw_execute'
    from ~/.rvm/gems/ruby-2.4.0/gems/selenium-webdriver-3.3.0/lib/selenium/webdriver/remote/bridge.rb:108:in `create_session'
    from ~/.rvm/gems/ruby-2.4.0/gems/selenium-webdriver-3.3.0/lib/selenium/webdriver/remote/bridge.rb:71:in `initialize'
    from ~/.rvm/gems/ruby-2.4.0/gems/selenium-webdriver-3.3.0/lib/selenium/webdriver/chrome/bridge.rb:52:in `initialize'
    from ~/.rvm/gems/ruby-2.4.0/gems/selenium-webdriver-3.3.0/lib/selenium/webdriver/common/driver.rb:61:in `new'
    from ~/.rvm/gems/ruby-2.4.0/gems/selenium-webdriver-3.3.0/lib/selenium/webdriver/common/driver.rb:61:in `for'
    from ~/.rvm/gems/ruby-2.4.0/gems/selenium-webdriver-3.3.0/lib/selenium/webdriver.rb:87:in `for'
    from (irb):2
    from ~/.rvm/rubies/ruby-2.4.0/bin/irb:11:in `<main>'
    2.4.0 :003 > exit
    ~/railsapps/smoketestapp$

任何帮助表示赞赏,谢谢

Varus

Update:

发现问题,查看 Selenium 驱动程序的日志文件。为此,我在 IRB 中输入以下内容:

    require "selenium-webdriver"
    Selenium::WebDriver::Chrome.driver_path="/usr/local/bin/chromedriver"
    Selenium::WebDriver.for :chrome, :service_log_path => "/tmp/cd.log"
    driver = Selenium::WebDriver.for(:chrome)

跟踪日志文件确定了这一点:chrome 无法启动:

    ~/railsapps/smoketestapp$ tail /tmp/cd.log
       ...
    [0.247][INFO]: Launching chrome: /opt/google/chrome/google-chrome --disable-background-networking --disable-client-side-phishing-detection --disable-component-update --disable-default-apps --disable-hang-monitor --disable-prompt-on-repost --disable-web-resources --enable-logging --full-memory-crash-report --ignore-certificate-errors --load-extension=/tmp/.org.chromium.Chromium.Pdre6o/internal --logging-level=1 --metrics-recording-only --no-first-run --password-store=basic --remote-debugging-port=12264 --safebrowsing-disable-auto-update --safebrowsing-disable-download-protection --use-mock-keychain --user-data-dir=/tmp/.org.chromium.Chromium.mHJaEd data:,
    [0.250][WARNING]: PAC support disabled because there is no system implementation
    [20.281][INFO]: RESPONSE InitSession unknown error: Chrome failed to start: exited abnormally
    ~/railsapps/smoketestapp$

最后我发现通过 PuTTY 远程调用 chrome 不起作用(这就是我一直在做的事情),尽管直接在虚拟机(在终端服务器中)上执行相同的操作是有效的.

在腻子上:

    ~$ google-chrome
    [3938:3938:0320/213941.129923:ERROR:browser_main_loop.cc(279)] Gtk: cannot open display:

然而,它直接在虚拟机上运行。

不幸的是,我的快乐是短暂的,因为我遇到了另一个错误,但那是另一个故事了:

            irb(main):001:0> require "selenium-webdriver"
    => true
    irb(main):002:0> Selenium::WebDriver::Chrome.driver_path="/usr/local/bin/chromedriver"
    => "/usr/local/bin/chromedriver"
    irb(main):003:0> driver = Selenium::WebDriver.for(:chrome)
    => #<Selenium::WebDriver::Driver:0x59d7c889a916c6b8 browser=:chrome>
    irb(main):004:0> driver.navigate.to("http://www.google.com")
    Selenium::WebDriver::Error::UnknownError: unknown error: Runtime.executionContextCreated has invalid 'context': {"auxData":{"frameId":"10797.1","isDefault":true},"id":1,"name":"","origin":"://"}
      (Session info: chrome=57.0.2987.110)
      (Driver info: chromedriver=2.4.226074,platform=Linux 4.8.0-41-generic x86_64)
            from ~/.rvm/rubies/ruby-2.4.0/lib/ruby/gems/2.4.0/gems/selenium-webdriver-3.3.0/lib/selenium/webdriver/remote/response.rb:69:in `assert_ok'
            from ~/.rvm/rubies/ruby-2.4.0/lib/ruby/gems/2.4.0/gems/selenium-webdriver-3.3.0/lib/selenium/webdriver/remote/response.rb:32:in `initialize'
            from ~/.rvm/rubies/ruby-2.4.0/lib/ruby/gems/2.4.0/gems/selenium-webdriver-3.3.0/lib/selenium/webdriver/remote/http/common.rb:83:in `new'
            from ~/.rvm/rubies/ruby-2.4.0/lib/ruby/gems/2.4.0/gems/selenium-webdriver-3.3.0/lib/selenium/webdriver/remote/http/common.rb:83:in `create_response'
            from ~/.rvm/rubies/ruby-2.4.0/lib/ruby/gems/2.4.0/gems/selenium-webdriver-3.3.0/lib/selenium/webdriver/remote/http/default.rb:107:in `request'
            from ~/.rvm/rubies/ruby-2.4.0/lib/ruby/gems/2.4.0/gems/selenium-webdriver-3.3.0/lib/selenium/webdriver/remote/http/common.rb:61:in `call'
            from ~/.rvm/rubies/ruby-2.4.0/lib/ruby/gems/2.4.0/gems/selenium-webdriver-3.3.0/lib/selenium/webdriver/remote/bridge.rb:669:in `raw_execute'
            from ~/.rvm/rubies/ruby-2.4.0/lib/ruby/gems/2.4.0/gems/selenium-webdriver-3.3.0/lib/selenium/webdriver/remote/bridge.rb:647:in `execute'
            from ~/.rvm/rubies/ruby-2.4.0/lib/ruby/gems/2.4.0/gems/selenium-webdriver-3.3.0/lib/selenium/webdriver/remote/bridge.rb:120:in `get'
            from ~/.rvm/rubies/ruby-2.4.0/lib/ruby/gems/2.4.0/gems/selenium-webdriver-3.3.0/lib/selenium/webdriver/common/navigation.rb:32:in `to'
            from (irb):4
            from ~/.rvm/rubies/ruby-2.4.0/bin/irb:11:in `<main>'
    irb(main):005:0> exit

最终,我想使用 Capybara 运行可以在我的设置中运行的系统测试(开发机器 = 操作系统 = Linux Ubuntu 的虚拟机,通过 PuTTY 远程访问)。

我找到了一种让它发挥作用的方法。

为此,我放弃了 Chrome 及其 Selenium 驱动程序,转而使用 PhantomJS 和 poltergeist。

PhantomJS 是一个无头浏览器(= 无 GUI)。效果很好。这是我的步骤(Rails 5.1):

  1. 将 gem 'poltergeist' 添加到您的 Gemfile 中,并注释掉 gem 'selenium-webdriver' (后者是 chrome 需要的,我们不会使用它):

    #gem 'selenium-webdriver'
    gem 'poltergeist'
    
  2. Run bundle update

  3. 添加 poltergeist 驱动程序配置(在文件中application_system_test_case.rb),注释掉 chrome 驱动配置:

    $ cat test/application_system_test_case.rb
    
    require "test_helper"
    
    require "capybara/poltergeist"
    Capybara.javascript_driver = :poltergeist      
    
    class ApplicationSystemTestCase < ActionDispatch::SystemTestCase
      # driven_by :selenium, using: :chrome, screen_size: [1400, 1400]
      driven_by :poltergeist
    end
    
  4. 下载“PhantomJS”无头浏览器,并将其放在 PATH 中的目录中:

    $ wget https://bitbucket.org/ariya/phantomjs/downloads/phantomjs-1.9.8-linux-x86_64.tar.bz2
    $ tar -xjvf phantomjs-1.9.8-linux-x86_64.tar.bz2
    $ sudo cp phantomjs-1.9.8-linux-x86_64/bin/phantomjs /usr/local/bin
    $ sudo chmod +x /usr/local/bin/phantomjs
    
  5. 您已准备就绪,可以运行系统测试了。例如:

    $ rake test TEST=test/system/posts_test.rb
    Run options: --seed 38196
    
    # Running:
    
    Puma starting in single mode...
    * Version 3.8.2 (ruby 2.4.0-p0), codename: Sassy Salamander
    * Min threads: 0, max threads: 1
    * Environment: test
    * Listening on tcp://0.0.0.0:44265
    Use Ctrl-C to stop
    You're running an old version of PhantomJS, update to >= 2.1.1 for a better experience.
    .
    
    Finished in 1.366478s, 0.7318 runs/s, 0.7318 assertions/s.
    
    1 runs, 1 assertions, 0 failures, 0 errors, 0 skips
    $ 
    
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Net::ReadTimeout: Net::ReadTimeout 和 Selenium::WebDriver::Error::UnknownError: 未知错误:Chrome 无法在 Rails 5.1.beta 系统测试上启动 的相关文章

  • 驱动程序在 Jenkins 中不是可执行错误,但在本地计算机 (MacBook) 中运行

    我正在 MacBook 上工作 当我通过testing xml文件运行测试时 我们的Jenkins服务器正在Linux服务器中运行 所有测试类都在运行 但是当我运行Jenkins构建时 它没有运行 错误提示驱动程序不可执行 我已经在 J e
  • ruby 2.0.0p247 的分段错误导致 Rails 服务器崩溃

    在 OS X Mavericks 1 9 上运行 Rails 4 0 Ruby 2 0 0p247 我今天遇到了一个我从未遇到过的错误 我不明白 当尝试在我的项目中启动 Rails 服务器时 服务器崩溃了 我确实尝试重新安装并重新编译一次
  • 如何将html id添加到rails中的form_for标签中?

    我正在尝试将 id 标签添加到我在 Rails 中创建的表单中 表单的开头有以下代码 我是否可以向 form for 嵌入式 ruby 添加一个 id 或者我是否必须创建一个 form tag 字段并在那里添加 id 如果我必须创建 for
  • Ruby on Rails:Cucumber:如何点击打开新窗口的链接?

    我有一个在新窗口中打开的链接 我需要测试该新窗口中的应用程序部分 任何建议将不胜感激 定义一个包含以下代码的步骤 page driver browser switch to window page driver browser window
  • Ruby on Rails 离线编程

    我将离开互联网几周 但仍然想完成一个项目 我应该采取哪些步骤来确保在断开连接时能够访问我需要的内容 ruby 和 ROR 离线时 以下内容很难获得 gems docs Rails 专家博客 堆栈溢出 so gem 安装尽可能多 下载所有的轨
  • 在表单中编辑序列化哈希?

    我正在序列化存储在settings表中的字段 并且希望能够在表单字段中编辑该哈希 class Template lt ActiveRecord Base serialize settings end 但我就是这么做那么文本区域只显示序列化数
  • 如何在 Rails 上的 .yml 本地化文件中换行?

    我有一个带有一些本地化内容的 terms en yml 文件 例如 en devise registrations terms text This agreement was written in English US To the ext
  • db:schema:load 与 db:migrate 使用 capistrano

    我有一个 Rails 应用程序 我正在将其移动到另一台服务器 我认为我应该使用 db schema load 来创建 mysql 数据库 因为这是推荐的 我的问题是我正在使用 capistrano 进行部署 并且它似乎默认为 rake db
  • 默认:Rails 资源路由的排除选项

    一个小问题 我正在将 Rails 用于 REST API 但由于它是 RESTful API 所以我并不真正需要 new or edit我的任何资源的路由 因为人们只会完全通过自动 JSON 请求而不是图形方式与此 API 交互 例如 不需
  • 为什么我需要 Nginx 和 Puma?

    我正在将 Rails 应用程序部署到生产环境中 看起来 Puma 速度很快 可以处理我想要在网络服务器中完成的许多事情 我想知道我是否需要使用 Nginx 如果只使用 Puma 我会错过什么 Nginx 是一个 Web 服务器 puma 是
  • 从 Rails 3.1.3 升级到 Rails 3.2.1。资产错误

    我尝试将应用程序从 Rails 3 1 3 升级到 Rails 3 2 1 但资产出现问题 我有这样的错误 ActionController RoutingError No route matches GET assets logos op
  • RailsAdmin 中具有 join_table 和 has_many :through 的模型的路由错误

    所以我有3个模型 category product category products 这是我的category rb attr accessible name has many category products do def with
  • 如何使用国家宝石

    我正在尝试使用国家宝石 https github com hexorx countries 但是在我捆绑安装这个 gem 后 有一些关于如何合并它的基本问题 我是否需要创建新的控制器 模型才能访问这些国家 地区 如何创建一个简单的选择下拉列
  • 更改 Active Storage 的默认 URL

    我们可以更改从活动存储创建的默认 永久 url 以重定向到 S3 类似于rails active storage representations 我不喜欢网址中的框架名称 Thanks UPDATE 最近 Rails 6 中增加了一个可配置
  • time_select 表单助手将新时间对象解释为 UTC,而不是配置的时区

    我遇到了对我来说似乎很简单的问题 但我无法弄清楚我做错了什么 在我的应用程序中 用户可以通过简单的 form for 添加他们的课程 他们可以输入课程讲座的开始时间和结束时间 如下所示 div class field Start Time
  • 无法在 Sqlite3 中添加默认值为 NULL 的 NOT NULL 列

    尝试将 NOT NULL 列添加到现有表时出现以下错误 为什么会发生这种情况 我尝试了 rake db reset 认为现有记录是问题所在 但即使重置数据库后 问题仍然存在 你能帮我解决这个问题吗 迁移文件 class AddDivisio
  • Rails 4 可安装引擎,找不到文件“jquery”

    我正在创建一个 Rails 可安装引擎插件 它使用 gem jquery rails 我在 gemspec 文件中添加了这段代码 s add dependency jquery rails gt 3 0 1 and run bundle i
  • 从数组中删除空白元素

    当我从 ruby on Rails 表单中保存多个选择时 它似乎在前面添加了一个空白元素 我该如何删除它 该字段为 selected player utf8 gt authenticity token gt H8W7qPBezubyeU0a
  • 子域中的 Rails url 助手 - 删除子域

    我网站上的用户可以拥有子域 例如 他们的页面网址是 name example com 登录的用户可以查看更多用户信息 因此在用户的显示页面上 我有一个使用以下代码生成的链接 user url user subdomain gt false
  • Selenium Grid2 - 远程节点未连接到集线器

    我当前的设置是我有一个 selenium RC 作为 Windows 机器上的集线器运行 假设机器名称是 machine name com 我使用以下命令来启动它 java jar selenium server2 15 jar role

随机推荐