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 | 04edb49a2ae968f4af7f37dfec622003259d4d75 (patch) | |
tree | dfbbe980dfc75a28b390b0da680e3577c36db8e7 /test | |
parent | 9a02f50a16931807c109907983e97390e473a706 (diff) | |
download | ruby-04edb49a2ae968f4af7f37dfec622003259d4d75.tar.gz ruby-04edb49a2ae968f4af7f37dfec622003259d4d75.tar.xz ruby-04edb49a2ae968f4af7f37dfec622003259d4d75.zip |
care EWOULDBLOCK of accept_nonblock.
git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@22375 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'test')
-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 ea6a903e7..abc844ceb 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 |