1
0
Fork 0
mirror of https://github.com/sinatra/sinatra synced 2023-03-27 23:18:01 -04:00
sinatra/test/integration_test.rb

66 lines
1.4 KiB
Ruby
Raw Normal View History

2011-10-31 17:40:22 -04:00
require File.expand_path('../helper', __FILE__)
require 'rbconfig'
require 'open-uri'
require 'timeout'
2011-10-31 17:40:22 -04:00
class IntegrationTest < Test::Unit::TestCase
2011-10-31 17:59:09 -04:00
def app_file
File.expand_path('../integration/app.rb', __FILE__)
end
def port
2011-10-31 19:19:22 -04:00
5000 + (Process.pid % 1000)
end
2011-10-31 17:59:09 -04:00
def command
cmd = ['exec']
2011-10-31 17:40:22 -04:00
if RbConfig.respond_to? :ruby
cmd << RbConfig.ruby.inspect
else
file, dir = RbConfig::CONFIG.values_at('ruby_install_name', 'bindir')
cmd << File.expand_path(file, dir).inspect
end
cmd << "-I" << File.expand_path('../../lib', __FILE__).inspect
cmd << app_file.inspect << '-p' << port << '2>&1'
2011-10-31 17:59:09 -04:00
cmd.join(" ")
end
def display_output(pipe)
out = ""
loop { out << pipe.read_nonblock(1) }
rescue
$stderr.puts command, out unless out.empty?
end
def kill(pid, signal = "TERM")
Process.kill(signal, pid)
rescue NotImplementedError
system "kill -s #{signal} #{pid}"
end
2011-10-31 17:59:09 -04:00
def with_server
pipe = IO.popen(command)
error = nil
Timeout.timeout(120) do
begin
2011-10-31 17:59:09 -04:00
yield
rescue Errno::ECONNREFUSED => e
error = e
sleep 0.1
retry
end
end
kill(pipe.pid) if pipe
rescue Timeout::Error => e
display_output pipe
kill(pipe.pid, "KILL") if pipe
raise error || e
2011-10-31 17:40:22 -04:00
end
2011-10-31 17:59:09 -04:00
it 'starts a top level application' do
with_server do
assert_equal open("http://127.0.0.1:#{port}/app_file").read, app_file
2011-10-31 17:59:09 -04:00
end
end
2011-10-31 17:40:22 -04:00
end