在无头Chrome中调试

时间:2018-07-26 11:27:51

标签: ruby testing rspec capybara headless

capybara_webkit切换到headless_chrome之后,我试图找到一种复制方法

Capybara::Webkit.configure do |config|
  config.debug = true
end

Capybara.javascript_driver = :webkit_debug

使用新驱动程序。 目标是能够查看运行rspec my_spec.rb时发生的所有事件的日志:例如,所有GET requests

有办法实现吗?

1 个答案:

答案 0 :(得分:2)

使用Selenium时没有选项,例如capybara_webkit调试选项,它实时输出调试信息,但是您可以访问Chrome日志并在每次测试结束时将其输出(或者您也可以编写一个助手以在每次调用时输出它们。)

首先,您需要配置硒驱动程序以进行记录

Capybara.register_driver :logging_chrome do |app|
  caps = Selenium::WebDriver::Remote::Capabilities.chrome(
    # customize this based on which and what level logs your prefer
    loggingPrefs: { 
      browser: 'ALL',
      driver: 'ALL',
      performance: 'ALL'
    }
  )
  browser_options = ::Selenium::WebDriver::Chrome::Options.new()
  browser_options.headless!
  Capybara::Selenium::Driver.new(
    app,
    browser: :chrome,
    desired_capabilities: caps,
    options: browser_options
  )
end

然后您将设置为使用该驱动程序

Capybara.javascript_driver = :logging_chrome # possibly default_driver = depending on your config

,然后添加一个after块来获取日志并显示它们

after(:each) do
  # customize based on which type of logs you want displayed
  log_types = page.driver.browser.manage.logs.available_types
  log_types.each do |t|
     puts t.to_s + ": " + page.driver.browser.manage.logs.get(t).join("\n")
  end
end