繁体   English   中英

使用水豚和硒的Chrome无头下载pdf

[英]Chrome headless download pdf using capybara and selenium

我在我的Ruby on Rails(5.2.1)项目中使用了带有Selenium(3.14.0)和Capybara(3.8.0)的chrome headless,我有一个测试工作在Non-headless chrome但不在无头chrome中。 我在谷歌Chrome稳定版69上使用'--headless'标志。

我用以下设置我的无头镀铬,这适用于所有不下载文件的测试。

download_path="#{Rails.root}/tmp/downloads"

Capybara.register_driver(:headless_chrome) do |app|
  caps = Selenium::WebDriver::Remote::Capabilities.chrome(
    chromeOptions: {
      prefs: {
        'download.default_directory' => download_path,
        "download.extensions_to_open" => "applications/pdf",
        'download.directory_upgrade' => true,
        'download.prompt_for_download' => false,
        'plugins.plugins_disabled' => ["Chrome PDF Viewer"]
      },
      binary: "/opt/google/chrome/google-chrome",
      args: %w[headless disable-gpu window-size=1920,1080]
    }
  )
  Capybara::Selenium::Driver.new(
    app,
    browser: :chrome,
    desired_capabilities: caps
  )
end

我已经读过我应该向selenium chrome驱动程序发送命令以允许下载,但我无法弄清楚如何使用我的设置。 这是我想要的工作,但我的设置; (不是来自我的代码库);

@driver = Selenium::WebDriver.for :chrome, options: options

bridge = @driver.send(:bridge)
path = '/session/:session_id/chromium/send_command'
path[':session_id'] = bridge.session_id
bridge.http.call(:post, path, cmd: 'Page.setDownloadBehavior',
                 params: {
                   behavior: 'allow',
                   downloadPath: download_path
                 })

如何在我的设置中访问selenium网桥,以便我可以发送此http呼叫?

您不需要再手动发送它作为Selenium::WebDriver::Chrome::Server#download_path=添加到selenium。 您可以通过Capybara::Selenium::Driver实例在驱动程序注册中进行设置

...
Capybara::Selenium::Driver.new(
  app,
  browser: :chrome,
  desired_capabilities: caps
).tap { |d| d.browser.download_path = <your download path> }

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM