1
0
Fork 0
mirror of https://github.com/teamcapybara/capybara.git synced 2022-11-09 12:08:07 -05:00

Explicit module for Server

This commit is contained in:
Jonas Nicklas 2010-07-09 20:31:58 +02:00
parent d7938b9cd9
commit bbc8964439

View file

@ -3,113 +3,115 @@ require 'net/http'
require 'rack'
require 'capybara/timeout'
class Capybara::Server
class Identify
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
attr_reader :app, :port
def initialize(app)
@app = app
end
def call(env)
if env["PATH_INFO"] == "/__identify__"
[200, {}, @app.object_id.to_s]
def host
"localhost"
end
def url(path)
if path =~ /^http/
path
else
@app.call(env)
(Capybara.app_host || "http://#{host}:#{port}") + path.to_s
end
end
end
attr_reader :app, :port
def initialize(app)
@app = app
end
def host
"localhost"
end
def url(path)
if path =~ /^http/
path
else
(Capybara.app_host || "http://#{host}:#{port}") + path.to_s
def responsive?
is_running_on_port?(port)
end
end
def responsive?
is_running_on_port?(port)
end
def handler
begin
require 'rack/handler/thin'
Rack::Handler::Thin
rescue LoadError
def handler
begin
require 'rack/handler/mongrel'
Rack::Handler::Mongrel
require 'rack/handler/thin'
Rack::Handler::Thin
rescue LoadError
require 'rack/handler/webrick'
Rack::Handler::WEBrick
begin
require 'rack/handler/mongrel'
Rack::Handler::Mongrel
rescue LoadError
require 'rack/handler/webrick'
Rack::Handler::WEBrick
end
end
end
end
def boot
return self unless @app
find_available_port
Capybara.log "application has already booted" and return self if responsive?
Capybara.log "booting Rack applicartion on port #{port}"
def boot
return self unless @app
find_available_port
Capybara.log "application has already booted" and return self if responsive?
Capybara.log "booting Rack applicartion on port #{port}"
Thread.new do
handler.run(Identify.new(@app), :Port => port, :AccessLog => [])
end
Capybara.log "checking if application has booted"
Capybara.timeout(10) do
if responsive?
Capybara.log("application has booted")
true
else
sleep 0.5
false
Thread.new do
handler.run(Identify.new(@app), :Port => port, :AccessLog => [])
end
end
self
rescue Timeout::Error
Capybara.log "Rack application timed out during boot"
exit
end
Capybara.log "checking if application has booted"
private
def find_available_port
@port = 9887
@port += 1 while is_port_open?(@port) and not is_running_on_port?(@port)
end
def is_running_on_port?(tested_port)
res = Net::HTTP.start(host, tested_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 is_port_open?(tested_port)
Timeout::timeout(1) do
begin
s = TCPSocket.new(host, tested_port)
s.close
return true
rescue Errno::ECONNREFUSED, Errno::EHOSTUNREACH
return false
Capybara.timeout(10) do
if responsive?
Capybara.log("application has booted")
true
else
sleep 0.5
false
end
end
self
rescue Timeout::Error
Capybara.log "Rack application timed out during boot"
exit
end
rescue Timeout::Error
return false
end
private
def find_available_port
@port = 9887
@port += 1 while is_port_open?(@port) and not is_running_on_port?(@port)
end
def is_running_on_port?(tested_port)
res = Net::HTTP.start(host, tested_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 is_port_open?(tested_port)
Timeout::timeout(1) do
begin
s = TCPSocket.new(host, tested_port)
s.close
return true
rescue Errno::ECONNREFUSED, Errno::EHOSTUNREACH
return false
end
end
rescue Timeout::Error
return false
end
end
end