From 268d1a2244b0179848a10a2841b4c037db52d3bd Mon Sep 17 00:00:00 2001 From: akr Date: Mon, 9 Jan 2012 11:11:24 +0000 Subject: * ext/socket/lib/socket.rb (family_addrinfo): return the given addrinfo object. Patch by Ippei Obayashi. [ruby-dev:45095] [Bug #5845] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@34244 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- test/socket/test_addrinfo.rb | 18 ++++++++++++++++++ 1 file changed, 18 insertions(+) (limited to 'test/socket') diff --git a/test/socket/test_addrinfo.rb b/test/socket/test_addrinfo.rb index c0aeba6f76..3240b9d814 100644 --- a/test/socket/test_addrinfo.rb +++ b/test/socket/test_addrinfo.rb @@ -352,6 +352,24 @@ class TestSocketAddrinfo < Test::Unit::TestCase # not test failure end } + + TCPServer.open("0.0.0.0", 0) {|serv| + serv_ai = Addrinfo.new(serv.getsockname, :INET, :STREAM) + serv_ai = tcp_unspecified_to_loopback(serv_ai) + port = random_port + begin + serv_ai.connect_from(Addrinfo.tcp("0.0.0.0", port)) {|s1| + s2 = serv.accept + begin + assert_equal(port, s2.remote_address.ip_port) + ensure + s2.close + end + } + rescue *errors_addrinuse + # not test failure + end + } end def test_connect_to -- cgit v1.2.3