3

我正在使用 RSpec、Capybara 和 Selenium 来测试我的本地 Rails 应用程序。Capybara 本身运行良好。我的问题是我在大多数应用程序中都使用了强制 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 测试之前自动启动本地服务器运行?

任何帮助将不胜感激。

4

1 回答 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,取自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)}
于 2013-07-17T02:00:57.460 回答