From 17a085ea8cd6f5e9d5dcdacfa48ef4364b3e7025 Mon Sep 17 00:00:00 2001 From: akr Date: Fri, 20 Mar 2009 17:39:44 +0000 Subject: * ext/openssl/lib/openssl/buffering.rb (OpenSSL::Buffering#write_nonblock): new method. * ext/openssl/ossl_ssl.c (ossl_ssl_write_nonblock): new method. (ossl_ssl_write_internal): defined. (ossl_ssl_write): use ossl_ssl_write_internal. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@23020 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- test/openssl/test_pair.rb | 27 +++++++++++++++++++++++++++ 1 file changed, 27 insertions(+) (limited to 'test/openssl/test_pair.rb') diff --git a/test/openssl/test_pair.rb b/test/openssl/test_pair.rb index e5beebc502..a6f1e4f55d 100644 --- a/test/openssl/test_pair.rb +++ b/test/openssl/test_pair.rb @@ -165,6 +165,33 @@ class OpenSSL::TestPair < Test::Unit::TestCase } end + def test_write_nonblock + ssl_pair {|s1, s2| + n = 0 + begin + n += s1.write_nonblock("a" * 100000) + n += s1.write_nonblock("b" * 100000) + n += s1.write_nonblock("c" * 100000) + n += s1.write_nonblock("d" * 100000) + n += s1.write_nonblock("e" * 100000) + n += s1.write_nonblock("f" * 100000) + rescue IO::WaitWritable + end + s1.close + assert_equal(n, s2.read.length) + } + end + + def test_write_nonblock_with_buffered_data + ssl_pair {|s1, s2| + s1.write "foo" + s1.write_nonblock("bar") + s1.write "baz" + s1.close + assert_equal("foobarbaz", s2.read) + } + end + end end -- cgit v1.2.3