1
0
Fork 0
mirror of https://github.com/teamcapybara/capybara.git synced 2022-11-09 12:08:07 -05:00
teamcapybara--capybara/lib/capybara/server.rb
Jo Liss a52ffd8dc3 Poll for the server coming up more frequently
Capybara.timeout sleeps 50ms between polls, and since the server tends
to boot quickly, this is a reasonable value. By not adding another
500ms, we shave a few seconds off the test execution time, mostly in
spec/server_spec.rb.
2012-01-03 21:59:17 +01:00

89 lines
1.7 KiB
Ruby

require 'uri'
require 'net/http'
require 'rack'
require 'capybara/util/timeout'
module Capybara
class Server
class Identify
def initialize(app)
@app = app
end
def call(env)
if env["PATH_INFO"] == "/__identify__"
[200, {}, [@app.object_id.to_s]]
else
@app.call(env)
end
end
end
class << self
def ports
@ports ||= {}
end
end
attr_reader :app, :port
def initialize(app)
@app = app
end
def host
Capybara.server_host || "127.0.0.1"
end
def url(path)
if path =~ /^http/
path
else
(Capybara.app_host || "http://#{host}:#{port}") + path.to_s
end
end
def responsive?
res = Net::HTTP.start(host, @port) { |http| http.get('/__identify__') }
if res.is_a?(Net::HTTPSuccess) or res.is_a?(Net::HTTPRedirection)
return res.body == @app.object_id.to_s
end
rescue Errno::ECONNREFUSED, Errno::EBADF
return false
end
def boot
if @app
@port = Capybara::Server.ports[@app.object_id]
if not @port or not responsive?
@port = Capybara.server_port || find_available_port
Capybara::Server.ports[@app.object_id] = @port
Thread.new do
Capybara.server.call(Identify.new(@app), @port)
end
Capybara.timeout(Capybara.server_boot_timeout) do
responsive?
end
end
end
rescue TimeoutError
raise "Rack application timed out during boot"
else
self
end
private
def find_available_port
server = TCPServer.new('127.0.0.1', 0)
server.addr[1]
ensure
server.close if server
end
end
end