从capybara_webkit
切换到headless_chrome
之后,我试图找到一种复制方法
Capybara::Webkit.configure do |config|
config.debug = true
end
或
Capybara.javascript_driver = :webkit_debug
使用新驱动程序。
目标是能够查看运行rspec my_spec.rb
时发生的所有事件的日志:例如,所有GET requests
。
有办法实现吗?
答案 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