2018-08-03 12:19:40 -04:00
|
|
|
require_relative '../spec_helper'
|
2018-03-04 10:09:32 -05:00
|
|
|
require_relative '../fixtures/classes'
|
2017-05-07 08:04:49 -04:00
|
|
|
|
|
|
|
describe "TCPServer#accept" do
|
|
|
|
before :each do
|
2017-06-15 08:48:52 -04:00
|
|
|
@server = TCPServer.new("127.0.0.1", 0)
|
|
|
|
@port = @server.addr[1]
|
2017-05-07 08:04:49 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
after :each do
|
|
|
|
@server.close unless @server.closed?
|
|
|
|
end
|
|
|
|
|
|
|
|
it "accepts a connection and returns a TCPSocket" do
|
|
|
|
data = nil
|
|
|
|
t = Thread.new do
|
|
|
|
client = @server.accept
|
|
|
|
client.should be_kind_of(TCPSocket)
|
|
|
|
data = client.read(5)
|
|
|
|
client << "goodbye"
|
|
|
|
client.close
|
|
|
|
end
|
|
|
|
Thread.pass while t.status and t.status != "sleep"
|
|
|
|
|
2017-06-15 08:48:52 -04:00
|
|
|
socket = TCPSocket.new('127.0.0.1', @port)
|
2017-05-07 08:04:49 -04:00
|
|
|
socket.write('hello')
|
|
|
|
socket.shutdown(1) # we are done with sending
|
|
|
|
socket.read.should == 'goodbye'
|
|
|
|
t.join
|
|
|
|
data.should == 'hello'
|
|
|
|
socket.close
|
|
|
|
end
|
|
|
|
|
|
|
|
it "can be interrupted by Thread#kill" do
|
|
|
|
t = Thread.new { @server.accept }
|
|
|
|
|
|
|
|
Thread.pass while t.status and t.status != "sleep"
|
|
|
|
|
|
|
|
# kill thread, ensure it dies in a reasonable amount of time
|
|
|
|
t.kill
|
2017-06-15 08:48:52 -04:00
|
|
|
a = 0
|
|
|
|
while t.alive? and a < 5000
|
|
|
|
sleep 0.001
|
2017-05-07 08:04:49 -04:00
|
|
|
a += 1
|
|
|
|
end
|
2017-06-15 08:48:52 -04:00
|
|
|
a.should < 5000
|
2017-05-07 08:04:49 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
it "can be interrupted by Thread#raise" do
|
2017-10-28 11:15:48 -04:00
|
|
|
t = Thread.new {
|
|
|
|
-> {
|
|
|
|
@server.accept
|
|
|
|
}.should raise_error(Exception, "interrupted")
|
|
|
|
}
|
2017-05-07 08:04:49 -04:00
|
|
|
|
|
|
|
Thread.pass while t.status and t.status != "sleep"
|
2017-10-28 11:15:48 -04:00
|
|
|
t.raise Exception, "interrupted"
|
|
|
|
t.join
|
2017-05-07 08:04:49 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
it "raises an IOError if the socket is closed" do
|
|
|
|
@server.close
|
|
|
|
lambda { @server.accept }.should raise_error(IOError)
|
|
|
|
end
|
|
|
|
end
|
2018-08-03 12:19:40 -04:00
|
|
|
|
|
|
|
describe 'TCPServer#accept' do
|
|
|
|
SocketSpecs.each_ip_protocol do |family, ip_address|
|
|
|
|
before do
|
|
|
|
@server = TCPServer.new(ip_address, 0)
|
|
|
|
end
|
|
|
|
|
|
|
|
after do
|
|
|
|
@server.close
|
|
|
|
end
|
|
|
|
|
|
|
|
describe 'without a connected client' do
|
|
|
|
it 'blocks the caller' do
|
|
|
|
lambda { @server.accept }.should block_caller
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe 'with a connected client' do
|
|
|
|
before do
|
|
|
|
@client = TCPSocket.new(ip_address, @server.connect_address.ip_port)
|
|
|
|
end
|
|
|
|
|
|
|
|
after do
|
|
|
|
@socket.close if @socket
|
|
|
|
@client.close
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns a TCPSocket' do
|
|
|
|
@socket = @server.accept
|
|
|
|
@socket.should be_an_instance_of(TCPSocket)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|