簡體   English   中英

在 rails 項目上使用 capybara 和 selenium-webdriver 運行系統測試失敗:由於 bridge.rb:44:in `handshake 中的 ArgumentError

[英]Running system test with capybara & selenium-webdriver on a rails project is failing: due to ArgumentError in bridge.rb:44:in `handshake

我有以下水豚配置:

Capybara.register_driver :chrome_headless do |app|
  media_tab_screen_size = '1280,800'
  chrome_capabilities = Selenium::WebDriver::Remote::Capabilities.chrome(
    loggingPrefs: {
      browser: 'ALL',
      client: 'ALL',
      driver: 'ALL',
      server: 'ALL'
    },
    chromeOptions: {
      args: %W[no-sandbox
               disable-dev-shm-usage
               no-default-browser-check
               start-maximized
               headless
               disable-gpu
               window-size=#{media_tab_screen_size}]
    }
  )
  if ENV['HUB_URL']
    Capybara::Selenium::Driver.new(app,
                                   browser: :remote,
                                   url: ENV['HUB_URL'],
                                   desired_capabilities: chrome_capabilities)
  else
    Capybara::Selenium::Driver.new(app,
                                   browser: :chrome,
                                   desired_capabilities: chrome_capabilities)
  end
end

RSpec.configure do |config|

    driven_by :chrome_headless

    # Sets host for tests with selenium
    Capybara.app_host = "http://#{IPSocket.getaddress(Socket.gethostname)}:3000"
    # Capybara.server = :puma # Until your setup is working
    Capybara.server_host = IPSocket.getaddress(Socket.gethostname)
    Capybara.server_port = 3000
end

當我使用 docker-compose 並通過selenium/standalone-chrome:88.0圖像運行系統測試時,當我像這樣運行測試時出現以下錯誤docker-compose run --rm -e RAILS_ENV=test web bin/rails spec:system

          ArgumentError:
            wrong number of arguments (given 1, expected 0)
          # /usr/local/bundle/gems/selenium-webdriver-3.142.7/lib/selenium/webdriver/remote/bridge.rb:44:in `handshake'
          # /usr/local/bundle/gems/selenium-webdriver-3.142.7/lib/selenium/webdriver/remote/driver.rb:39:in `initialize'
          # /usr/local/bundle/gems/selenium-webdriver-3.142.7/lib/selenium/webdriver/common/driver.rb:58:in `new'
          # /usr/local/bundle/gems/selenium-webdriver-3.142.7/lib/selenium/webdriver/common/driver.rb:58:in `for'
          # /usr/local/bundle/gems/selenium-webdriver-3.142.7/lib/selenium/webdriver.rb:88:in `for'
          # /usr/local/bundle/gems/capybara-3.35.3/lib/capybara/selenium/driver.rb:83:in `browser'
          # /usr/local/bundle/gems/capybara-3.35.3/lib/capybara/selenium/driver.rb:104:in `visit'
          # /usr/local/bundle/gems/capybara-3.35.3/lib/capybara/session.rb:278:in `visit'
          # /usr/local/bundle/gems/capybara-3.35.3/lib/capybara/dsl.rb:53:in `call'
          # /usr/local/bundle/gems/capybara-3.35.3/lib/capybara/dsl.rb:53:in `visit'
          # ./spec/system/home_page_spec.rb:7:in `block (2 levels) in <top (required)>'
          # /usr/local/bundle/gems/webmock-3.11.2/lib/webmock/rspec.rb:37:in `block (2 levels) in <main>'

     1.2) Failure/Error:
                    def self.handshake(**opts)
                      desired_capabilities = opts.delete(:desired_capabilities) { Capabilities.new }

                      if desired_capabilities.is_a?(Symbol)
                        unless Capabilities.respond_to?(desired_capabilities)
                          raise Error::WebDriverError, "invalid desired capability: #{desired_capabilities.inspect}"
                        end

                        desired_capabilities = Capabilities.__send__(desired_capabilities)
                      end

          ArgumentError:
            wrong number of arguments (given 1, expected 0)

我真的不知道是什么原因造成的,是配置問題還是兼容性問題。 我試圖調試它無數次並更改 gems 版本,但什么也沒發生。 我將不勝感激任何幫助。

查看堆棧跟蹤中列出的代碼,遠程驅動程序正在執行

def initialize(opts = {})
  listener = opts.delete(:listener)
  @bridge = Bridge.handshake(opts)
  ...

這是調用遠程橋代碼

def self.handshake(**opts)
  desired_capabilities = opts.delete(:desired_capabilities) { Capabilities.new }
  ...

從這里我們可以看出,遠程驅動程序正在傳遞一個 Hash,但handshake需要關鍵字 arguments。 This would have worked in Ruby < 3.0 because the last Hash parameter would have been interpreted as keyword args (in Ruby 2.7 it would give a deprecation warning), but not in Ruby 3.0+, so I assume you're using Ruby 3.0 which isn '與 Selenium 3.x 不兼容

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM