在无头Chrome中调试

妖精

从切换capybara_webkit到后headless_chrome,我正在尝试寻找一种复制方法

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

要么

Capybara.javascript_driver = :webkit_debug

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

有办法实现吗?

托马斯·沃尔波尔

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

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

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

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章