如何让Capybara / Selenium在本地环境中与SSL很好地配合

问题描述 投票:2回答:1

我正在使用RSpec,Capybara和Selenium来测试我的本地Rails应用程序。水豚本身工作正常。我的问题是我在大多数应用程序中使用强制SSL连接。

我现在的解决方法是将Capybara配置为javascript测试,如下所示:

Capybara.register_driver :selenium_profile do |app|
  profile = Selenium::WebDriver::Firefox::Profile.new
  profile.secure_ssl = false
  profile.assume_untrusted_certificate_issuer = true
  Capybara::Selenium::Driver.new(app, :browser => :firefox, :profile => profile)
end 
Capybara.javascript_driver = :selenium_profile

Capybara.run_server = false
Capybara.server_port = 3001
Capybara.app_host = "https://localhost:%d" % Capybara.server_port

这只有在我使用有效的本地SSL证书在端口3001上独立启动服务器时才有效。在实践中,这很烦人,通常只是我不喜欢的手动依赖。

有谁知道这个更清洁的解决方法?或者:

1)如何配置Capybara的内部服务器以查找和使用我的本地SSL证书?或

2)如何为javascript测试禁用强制SSL,或者

3)如何在任何javascript测试之前自动启动运行的本地服务器?

任何帮助将不胜感激。

ruby-on-rails selenium capybara
1个回答
4
投票

您可以通过将接受应用程序和端口的块传递给Capybara.server来告诉Capybara如何启动服务器。默认只调用Rake :: Handler :: WEBrick.run:

# This is the default setting
Capybara.server = {|app, port| Capybara.run_default_server(app, port)}

def run_default_server(app, port)
  require 'rack/handler/webrick'
  Rack::Handler::WEBrick.run(app, :Port => port, :AccessLog => [], :Logger => WEBrick::Log::new(nil, 0))
end

只要您传递给服务器的任何内容都接受应用程序和端口,您就可以定义您喜欢的任何服务器启动代码。

Rack :: Handler :: WEBrick将其大部分选项直接传递给WEBrick :: HTTPServer,因此您可以传递SSL配置选项(SSLEnable,SSLCertificate和SSLPrivateKey,采用from the docs)并启动服务器,如下所示:

def run_ssl_server(app, port)
  require 'rack/handler/webrick'
  require 'webrick/https'

  certificate = OpenSSL::X509::Certificate.new File.read '/myapp/some_directory/certificate.pem'
  key = OpenSSL::PKey::RSA.new File.read '/myapp/some_directory/key.pem'

  opts = {
    :Port => port,
    :AccessLog => [],
    :Logger => WEBrick::Log::new(nil, 0),
    :SSLEnable => true,
    :SSLCertificate => certificate,
    :SSLPrivateKey => key 
  }

  Rack::Handler::WEBrick.run(app, opts)
end

# Elsewhere in your test/spec helper
Capybara.server = {|app, port| run_ssl_server(app, port)}
© www.soinside.com 2019 - 2024. All rights reserved.