diff options
author | akr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2009-03-19 11:40:38 +0000 |
---|---|---|
committer | akr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2009-03-19 11:40:38 +0000 |
commit | c4049f4cb6d27ffdfe9f15f4a9ddc5a48271ecf3 (patch) | |
tree | 98df695950d4ad9be608b21479593d4825e293d9 /test | |
parent | b7800329d3070a4fb9f9dbdbe8b411c5f628f942 (diff) |
* io.c (rb_mWaitReadable): defined.
(rb_mWaitWritable): defined.
(io_getpartial): extend IO::WaitReadable on EWOULDBLOCK and EAGAIN.
(rb_io_write_nonblock): extend IO::WaitWritable on EWOULDBLOCK and
EAGAIN.
* error.c (make_errno_exc): extracted from rb_sys_fail.
(rb_mod_sys_fail): new function.
* include/ruby/ruby.h (rb_mod_sys_fail): declared.
(rb_mWaitReadable): declared.
(rb_mWaitWritable): declared.
* ext/socket/init.c (rsock_s_recvfrom_nonblock): extend
IO::WaitReadable on EWOULDBLOCK and EAGAIN.
(rsock_s_accept_nonblock): extend IO::WaitReadable on EWOULDBLOCK,
EAGAIN, ECONNABORTED and EPROTO.
* ext/socket/socket.c (sock_connect_nonblock): extend IO::WaitWritable
on EINPROGRESS.
* ext/socket/ancdata.c (bsock_sendmsg_internal): extend
IO::WaitWritable on EWOULDBLOCK and EAGAIN.
(bsock_recvmsg_internal): extend IO::WaitReadable on EWOULDBLOCK and
EAGAIN.
* ext/openssl/ossl_ssl.c (ossl_ssl_read_internal): raise SSLError
extended by IO::WaitReadable/IO::WaitWritable on
SSL_ERROR_WANT_READ/SSL_ERROR_WANT_WRITE.
* ext/openssl/ossl.c (ossl_make_error): extracted from ossl_raise.
(ossl_exc_new): new function.
* ext/openssl/ossl.h (ossl_exc_new): declared.
* lib/net/protocol.rb (rbuf_fill): rescue IO::WaitReadable and
IO::WaitWritable.
[ruby-core:22539], [ruby-dev:38140]
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@23006 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'test')
-rw-r--r-- | test/openssl/test_pair.rb | 4 | ||||
-rw-r--r-- | test/openssl/test_ssl.rb | 4 | ||||
-rw-r--r-- | test/ruby/test_io.rb | 4 | ||||
-rw-r--r-- | test/socket/test_addrinfo.rb | 4 | ||||
-rw-r--r-- | test/socket/test_nonblock.rb | 48 |
5 files changed, 32 insertions, 32 deletions
diff --git a/test/openssl/test_pair.rb b/test/openssl/test_pair.rb index 9d22a87e29..e5beebc502 100644 --- a/test/openssl/test_pair.rb +++ b/test/openssl/test_pair.rb @@ -147,14 +147,14 @@ class OpenSSL::TestPair < Test::Unit::TestCase def test_read_nonblock ssl_pair {|s1, s2| err = nil - assert_raise(Errno::EWOULDBLOCK) { + assert_raise(OpenSSL::SSL::SSLError) { begin s2.read_nonblock(10) ensure err = $! end } - assert_match(/SSL_ERROR_WANT_READ/, err.message) + assert_kind_of(IO::WaitReadable, err) s1.write "abc\ndef\n" IO.select([s2]) assert_equal("ab", s2.read_nonblock(2)) diff --git a/test/openssl/test_ssl.rb b/test/openssl/test_ssl.rb index 5053634a84..4688552cd3 100644 --- a/test/openssl/test_ssl.rb +++ b/test/openssl/test_ssl.rb @@ -172,12 +172,12 @@ class OpenSSL::TestSSL < Test::Unit::TestCase ssl = OpenSSL::SSL::SSLSocket.new(sock) ssl.sync_close = true ssl.connect - assert_raise(Errno::EAGAIN, Errno::EWOULDBLOCK) { ssl.read_nonblock(100) } + assert_raise(IO::WaitReadable) { ssl.read_nonblock(100) } ssl.write("abc\n") IO.select [ssl] assert_equal('a', ssl.read_nonblock(1)) assert_equal("bc\n", ssl.read_nonblock(100)) - assert_raise(Errno::EAGAIN, Errno::EWOULDBLOCK) { ssl.read_nonblock(100) } + assert_raise(IO::WaitReadable) { ssl.read_nonblock(100) } } end diff --git a/test/ruby/test_io.rb b/test/ruby/test_io.rb index 91da8c03c1..f456779880 100644 --- a/test/ruby/test_io.rb +++ b/test/ruby/test_io.rb @@ -864,7 +864,7 @@ class TestIO < Test::Unit::TestCase begin r.read_nonblock 4096 rescue Errno::EWOULDBLOCK - assert_match(/WANT_READ/, $!.message) + assert_kind_of(IO::WaitReadable, $!) end } end @@ -877,7 +877,7 @@ class TestIO < Test::Unit::TestCase w.write_nonblock "a"*100000 } rescue Errno::EWOULDBLOCK - assert_match(/WANT_WRITE/, $!.message) + assert_kind_of(IO::WaitWritable, $!) end } end diff --git a/test/socket/test_addrinfo.rb b/test/socket/test_addrinfo.rb index 00ed7f4e18..856fbd1308 100644 --- a/test/socket/test_addrinfo.rb +++ b/test/socket/test_addrinfo.rb @@ -236,7 +236,7 @@ class TestSocketAddrinfo < Test::Unit::TestCase c.connect(serv.local_address) begin ret = serv.accept_nonblock - rescue Errno::EAGAIN, Errno::EWOULDBLOCK, Errno::ECONNABORTED, Errno::EPROTO, Errno::EINTR + rescue IO::WaitReadable, Errno::EINTR IO.select([serv]) retry end @@ -299,7 +299,7 @@ class TestSocketAddrinfo < Test::Unit::TestCase s2.send("test-socket-recvfrom", 0, s1.getsockname) begin data, ai = s1.recvfrom_nonblock(100) - rescue Errno::EWOULDBLOCK + rescue IO::WaitReadable IO.select([s1]) retry end diff --git a/test/socket/test_nonblock.rb b/test/socket/test_nonblock.rb index 4e7807fa95..6b65cc386a 100644 --- a/test/socket/test_nonblock.rb +++ b/test/socket/test_nonblock.rb @@ -12,13 +12,13 @@ class TestSocketNonblock < Test::Unit::TestCase serv = Socket.new(Socket::AF_INET, Socket::SOCK_STREAM, 0) serv.bind(Socket.sockaddr_in(0, "127.0.0.1")) serv.listen(5) - assert_raise(Errno::EAGAIN, Errno::EWOULDBLOCK) { serv.accept_nonblock } + assert_raise(IO::WaitReadable) { serv.accept_nonblock } c = Socket.new(Socket::AF_INET, Socket::SOCK_STREAM, 0) c.connect(serv.getsockname) begin s, sockaddr = serv.accept_nonblock - rescue Errno::EWOULDBLOCK - IO.select nil, [serv] + rescue IO::WaitReadable + IO.select [serv] s, sockaddr = serv.accept_nonblock end assert_equal(Socket.unpack_sockaddr_in(c.getsockname), Socket.unpack_sockaddr_in(sockaddr)) @@ -57,8 +57,8 @@ class TestSocketNonblock < Test::Unit::TestCase u1 = UDPSocket.new u2 = UDPSocket.new u1.bind("127.0.0.1", 0) - assert_raise(Errno::EAGAIN, Errno::EWOULDBLOCK) { u1.recvfrom_nonblock(100) } - assert_raise(Errno::EAGAIN, Errno::EWOULDBLOCK, Errno::EINVAL) { u2.recvfrom_nonblock(100) } + assert_raise(IO::WaitReadable) { u1.recvfrom_nonblock(100) } + assert_raise(IO::WaitReadable, Errno::EINVAL) { u2.recvfrom_nonblock(100) } u2.send("aaa", 0, u1.getsockname) IO.select [u1] mesg, inet_addr = u1.recvfrom_nonblock(100) @@ -67,7 +67,7 @@ class TestSocketNonblock < Test::Unit::TestCase af, port, host, addr = inet_addr u2_port, u2_addr = Socket.unpack_sockaddr_in(u2.getsockname) assert_equal(u2_port, port) - assert_raise(Errno::EAGAIN, Errno::EWOULDBLOCK) { u1.recvfrom_nonblock(100) } + assert_raise(IO::WaitReadable) { u1.recvfrom_nonblock(100) } u2.send("", 0, u1.getsockname) assert_nothing_raised("cygwin 1.5.19 has a problem to send an empty UDP packet. [ruby-dev:28915]") { timeout(1) { IO.select [u1] } @@ -83,13 +83,13 @@ class TestSocketNonblock < Test::Unit::TestCase u1 = UDPSocket.new u2 = UDPSocket.new u1.bind("127.0.0.1", 0) - assert_raise(Errno::EAGAIN, Errno::EWOULDBLOCK) { u1.recv_nonblock(100) } - assert_raise(Errno::EAGAIN, Errno::EWOULDBLOCK, Errno::EINVAL) { u2.recv_nonblock(100) } + assert_raise(IO::WaitReadable) { u1.recv_nonblock(100) } + assert_raise(IO::WaitReadable, Errno::EINVAL) { u2.recv_nonblock(100) } u2.send("aaa", 0, u1.getsockname) IO.select [u1] mesg = u1.recv_nonblock(100) assert_equal("aaa", mesg) - assert_raise(Errno::EAGAIN, Errno::EWOULDBLOCK) { u1.recv_nonblock(100) } + assert_raise(IO::WaitReadable) { u1.recv_nonblock(100) } u2.send("", 0, u1.getsockname) assert_nothing_raised("cygwin 1.5.19 has a problem to send an empty UDP packet. [ruby-dev:28915]") { timeout(1) { IO.select [u1] } @@ -105,8 +105,8 @@ class TestSocketNonblock < Test::Unit::TestCase s1 = Socket.new(Socket::AF_INET, Socket::SOCK_DGRAM, 0) s1.bind(Socket.sockaddr_in(0, "127.0.0.1")) s2 = Socket.new(Socket::AF_INET, Socket::SOCK_DGRAM, 0) - assert_raise(Errno::EAGAIN, Errno::EWOULDBLOCK) { s1.recvfrom_nonblock(100) } - assert_raise(Errno::EAGAIN, Errno::EWOULDBLOCK, Errno::EINVAL) { s2.recvfrom_nonblock(100) } + assert_raise(IO::WaitReadable) { s1.recvfrom_nonblock(100) } + assert_raise(IO::WaitReadable, Errno::EINVAL) { s2.recvfrom_nonblock(100) } s2.send("aaa", 0, s1.getsockname) IO.select [s1] mesg, sockaddr = s1.recvfrom_nonblock(100) @@ -140,13 +140,13 @@ class TestSocketNonblock < Test::Unit::TestCase def test_tcp_recv_nonblock c, s = tcp_pair - assert_raise(Errno::EAGAIN, Errno::EWOULDBLOCK) { c.recv_nonblock(100) } - assert_raise(Errno::EAGAIN, Errno::EWOULDBLOCK) { s.recv_nonblock(100) } + assert_raise(IO::WaitReadable) { c.recv_nonblock(100) } + assert_raise(IO::WaitReadable) { s.recv_nonblock(100) } c.write("abc") IO.select [s] assert_equal("a", s.recv_nonblock(1)) assert_equal("bc", s.recv_nonblock(100)) - assert_raise(Errno::EAGAIN, Errno::EWOULDBLOCK) { s.recv_nonblock(100) } + assert_raise(IO::WaitReadable) { s.recv_nonblock(100) } ensure c.close if c s.close if s @@ -154,13 +154,13 @@ class TestSocketNonblock < Test::Unit::TestCase def test_read_nonblock c, s = tcp_pair - assert_raise(Errno::EAGAIN, Errno::EWOULDBLOCK) { c.read_nonblock(100) } - assert_raise(Errno::EAGAIN, Errno::EWOULDBLOCK) { s.read_nonblock(100) } + assert_raise(IO::WaitReadable) { c.read_nonblock(100) } + assert_raise(IO::WaitReadable) { s.read_nonblock(100) } c.write("abc") IO.select [s] assert_equal("a", s.read_nonblock(1)) assert_equal("bc", s.read_nonblock(100)) - assert_raise(Errno::EAGAIN, Errno::EWOULDBLOCK) { s.read_nonblock(100) } + assert_raise(IO::WaitReadable) { s.read_nonblock(100) } ensure c.close if c s.close if s @@ -175,7 +175,7 @@ class TestSocketNonblock < Test::Unit::TestCase ret = c.write_nonblock(str) assert_operator(ret, :>, 0) loop { - assert_raise(Errno::EAGAIN, Errno::EWOULDBLOCK) { + assert_raise(IO::WaitWritable) { loop { ret = c.write_nonblock(str) assert_operator(ret, :>, 0) @@ -197,7 +197,7 @@ class TestSocketNonblock < Test::Unit::TestCase c.sendmsg_nonblock("a" * 100000) } rescue Errno::EWOULDBLOCK - assert_match(/WANT_WRITE/, $!.message) + assert_kind_of(IO::WaitWritable, $!) end } end @@ -207,7 +207,7 @@ class TestSocketNonblock < Test::Unit::TestCase begin c.recvmsg_nonblock(4096) rescue Errno::EWOULDBLOCK - assert_match(/WANT_READ/, $!.message) + assert_kind_of(IO::WaitReadable, $!) end } end @@ -217,7 +217,7 @@ class TestSocketNonblock < Test::Unit::TestCase begin c.recv_nonblock(4096) rescue Errno::EWOULDBLOCK - assert_match(/WANT_READ/, $!.message) + assert_kind_of(IO::WaitReadable, $!) end } end @@ -229,7 +229,7 @@ class TestSocketNonblock < Test::Unit::TestCase begin c.connect_nonblock(Socket.sockaddr_in(port, "127.0.0.1")) rescue Errno::EINPROGRESS - assert_match(/WANT_WRITE/, $!.message) + assert_kind_of(IO::WaitWritable, $!) end ensure serv.close if serv && !serv.closed? @@ -243,8 +243,8 @@ class TestSocketNonblock < Test::Unit::TestCase port = serv.local_address.ip_port begin s, _ = serv.accept_nonblock - rescue Errno::EWOULDBLOCK, Errno::ECONNABORTED, Errno::EPROTO - assert_match(/WANT_READ/, $!.message) + rescue Errno::EWOULDBLOCK + assert_kind_of(IO::WaitReadable, $!) end ensure serv.close if serv && !serv.closed? |