summaryrefslogtreecommitdiff
path: root/test/socket/test_nonblock.rb
diff options
context:
space:
mode:
authorakr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2009-02-17 11:05:35 +0000
committerakr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2009-02-17 11:05:35 +0000
commit536adb5d7cf0b35a3980f11f0512e85ff72d71e6 (patch)
treedfbbe980dfc75a28b390b0da680e3577c36db8e7 /test/socket/test_nonblock.rb
parent2f8b471b89ce803c54f30e6d2cc95e12f62247c0 (diff)
care EWOULDBLOCK of accept_nonblock.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@22375 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'test/socket/test_nonblock.rb')
-rw-r--r--test/socket/test_nonblock.rb7
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