diff options
author | akr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2009-02-17 11:05:35 +0000 |
---|---|---|
committer | akr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2009-02-17 11:05:35 +0000 |
commit | 536adb5d7cf0b35a3980f11f0512e85ff72d71e6 (patch) | |
tree | dfbbe980dfc75a28b390b0da680e3577c36db8e7 | |
parent | 2f8b471b89ce803c54f30e6d2cc95e12f62247c0 (diff) | |
download | ruby-536adb5d7cf0b35a3980f11f0512e85ff72d71e6.tar.gz |
care EWOULDBLOCK of accept_nonblock.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@22375 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r-- | test/socket/test_nonblock.rb | 7 |
1 files changed, 6 insertions, 1 deletions
diff --git a/test/socket/test_nonblock.rb b/test/socket/test_nonblock.rb index ea6a903e72..abc844ceb8 100644 --- a/test/socket/test_nonblock.rb +++ b/test/socket/test_nonblock.rb @@ -15,7 +15,12 @@ class TestSocketNonblock < Test::Unit::TestCase assert_raise(Errno::EAGAIN, Errno::EWOULDBLOCK) { serv.accept_nonblock } c = Socket.new(Socket::AF_INET, Socket::SOCK_STREAM, 0) c.connect(serv.getsockname) - s, sockaddr = serv.accept_nonblock + begin + s, sockaddr = serv.accept_nonblock + rescue Errno::EWOULDBLOCK + IO.select nil, [serv] + s, sockaddr = serv.accept_nonblock + end assert_equal(Socket.unpack_sockaddr_in(c.getsockname), Socket.unpack_sockaddr_in(sockaddr)) ensure serv.close if serv |