mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
ae76a2323e
value, don't use pipe. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@26058 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
58 lines
1.7 KiB
Ruby
58 lines
1.7 KiB
Ruby
require "test/unit"
|
|
require "tempfile"
|
|
require "webrick"
|
|
require File.join(File.dirname(__FILE__), "utils.rb")
|
|
|
|
class TestWEBrickServer < Test::Unit::TestCase
|
|
class Echo < WEBrick::GenericServer
|
|
def run(sock)
|
|
while line = sock.gets
|
|
sock << line
|
|
end
|
|
end
|
|
end
|
|
|
|
def test_server
|
|
TestWEBrick.start_server(Echo){|server, addr, port, log|
|
|
TCPSocket.open(addr, port){|sock|
|
|
sock.puts("foo"); assert_equal("foo\n", sock.gets, log.call)
|
|
sock.puts("bar"); assert_equal("bar\n", sock.gets, log.call)
|
|
sock.puts("baz"); assert_equal("baz\n", sock.gets, log.call)
|
|
sock.puts("qux"); assert_equal("qux\n", sock.gets, log.call)
|
|
}
|
|
}
|
|
end
|
|
|
|
def test_callbacks
|
|
accepted = started = stopped = 0
|
|
config = {
|
|
:AcceptCallback => Proc.new{ accepted += 1 },
|
|
:StartCallback => Proc.new{ started += 1 },
|
|
:StopCallback => Proc.new{ stopped += 1 },
|
|
}
|
|
TestWEBrick.start_server(Echo, config){|server, addr, port, log|
|
|
true while server.status != :Running
|
|
assert_equal(started, 1, log.call)
|
|
assert_equal(stopped, 0, log.call)
|
|
assert_equal(accepted, 0, log.call)
|
|
TCPSocket.open(addr, port){|sock| (sock << "foo\n").gets }
|
|
TCPSocket.open(addr, port){|sock| (sock << "foo\n").gets }
|
|
TCPSocket.open(addr, port){|sock| (sock << "foo\n").gets }
|
|
assert_equal(accepted, 3, log.call)
|
|
}
|
|
assert_equal(started, 1)
|
|
assert_equal(stopped, 1)
|
|
end
|
|
|
|
def test_daemon
|
|
begin
|
|
pid = Process.fork{
|
|
WEBrick::Daemon.start
|
|
sleep
|
|
}
|
|
assert(Process.kill(:KILL, pid))
|
|
rescue NotImplementedError
|
|
# snip this test
|
|
end
|
|
end
|
|
end
|