From 29aff19f1ab92bd9a4fc891fcaed5b6b4bb18cb6 Mon Sep 17 00:00:00 2001 From: akr Date: Sat, 17 Jan 2009 09:39:14 +0000 Subject: [PATCH] extract TestBasicSocket from test_socket.rb. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@21626 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- test/socket/test_basicsocket.rb | 88 +++++++++++++++++++++++++++++++++ test/socket/test_socket.rb | 83 ------------------------------- 2 files changed, 88 insertions(+), 83 deletions(-) create mode 100644 test/socket/test_basicsocket.rb diff --git a/test/socket/test_basicsocket.rb b/test/socket/test_basicsocket.rb new file mode 100644 index 0000000000..34b4019bd0 --- /dev/null +++ b/test/socket/test_basicsocket.rb @@ -0,0 +1,88 @@ +begin + require "socket" + require "test/unit" +rescue LoadError +end + +class TestBasicSocket < Test::Unit::TestCase + def inet_stream + sock = Socket.new(Socket::AF_INET, Socket::SOCK_STREAM, 0) + yield sock + ensure + assert_raise(IOError) {sock.close} + end + + def test_getsockopt + inet_stream do |s| + n = s.getsockopt(Socket::SOL_SOCKET, Socket::SO_TYPE) + assert_equal([Socket::SOCK_STREAM].pack("i"), n) + + n = s.getsockopt("SOL_SOCKET", "SO_TYPE") + assert_equal([Socket::SOCK_STREAM].pack("i"), n) + + n = s.getsockopt(:SOL_SOCKET, :SO_TYPE) + assert_equal([Socket::SOCK_STREAM].pack("i"), n) + + n = s.getsockopt(:SOCKET, :TYPE) + assert_equal([Socket::SOCK_STREAM].pack("i"), n) + + n = s.getsockopt(Socket::SOL_SOCKET, Socket::SO_ERROR) + assert_equal([0].pack("i"), n) + + val = Object.new + class << val; self end.send(:define_method, :to_int) { + s.close + Socket::SO_TYPE + } + assert_raise(IOError) { + n = s.getsockopt(Socket::SOL_SOCKET, val) + } + end + end + + def test_setsockopt + s = nil + linger = [0, 0].pack("ii") + + val = Object.new + class << val; self end.send(:define_method, :to_str) { + s.close + linger + } + inet_stream do |sock| + s = sock + assert_equal(0, s.setsockopt(Socket::SOL_SOCKET, Socket::SO_LINGER, linger)) + + assert_raise(IOError, "[ruby-dev:25039]") { + s.setsockopt(Socket::SOL_SOCKET, Socket::SO_LINGER, val) + } + end + + val = Object.new + class << val; self end.send(:define_method, :to_int) { + s.close + Socket::SO_LINGER + } + inet_stream do |sock| + s = sock + assert_raise(IOError) { + s.setsockopt(Socket::SOL_SOCKET, val, linger) + } + end + end + + def test_listen + s = nil + log = Object.new + class << log; self end.send(:define_method, :to_int) { + s.close + 2 + } + inet_stream do |sock| + s = sock + assert_raise(IOError) { + s.listen(log) + } + end + end +end if defined?(BasicSocket) diff --git a/test/socket/test_socket.rb b/test/socket/test_socket.rb index e35cedbbc1..d2aab5f1f3 100644 --- a/test/socket/test_socket.rb +++ b/test/socket/test_socket.rb @@ -4,89 +4,6 @@ begin rescue LoadError end -class TestBasicSocket < Test::Unit::TestCase - def inet_stream - sock = Socket.new(Socket::AF_INET, Socket::SOCK_STREAM, 0) - yield sock - ensure - assert_raise(IOError) {sock.close} - end - - def test_getsockopt - inet_stream do |s| - n = s.getsockopt(Socket::SOL_SOCKET, Socket::SO_TYPE) - assert_equal([Socket::SOCK_STREAM].pack("i"), n) - - n = s.getsockopt("SOL_SOCKET", "SO_TYPE") - assert_equal([Socket::SOCK_STREAM].pack("i"), n) - - n = s.getsockopt(:SOL_SOCKET, :SO_TYPE) - assert_equal([Socket::SOCK_STREAM].pack("i"), n) - - n = s.getsockopt(:SOCKET, :TYPE) - assert_equal([Socket::SOCK_STREAM].pack("i"), n) - - n = s.getsockopt(Socket::SOL_SOCKET, Socket::SO_ERROR) - assert_equal([0].pack("i"), n) - - val = Object.new - class << val; self end.send(:define_method, :to_int) { - s.close - Socket::SO_TYPE - } - assert_raise(IOError) { - n = s.getsockopt(Socket::SOL_SOCKET, val) - } - end - end - - def test_setsockopt - s = nil - linger = [0, 0].pack("ii") - - val = Object.new - class << val; self end.send(:define_method, :to_str) { - s.close - linger - } - inet_stream do |sock| - s = sock - assert_equal(0, s.setsockopt(Socket::SOL_SOCKET, Socket::SO_LINGER, linger)) - - assert_raise(IOError, "[ruby-dev:25039]") { - s.setsockopt(Socket::SOL_SOCKET, Socket::SO_LINGER, val) - } - end - - val = Object.new - class << val; self end.send(:define_method, :to_int) { - s.close - Socket::SO_LINGER - } - inet_stream do |sock| - s = sock - assert_raise(IOError) { - s.setsockopt(Socket::SOL_SOCKET, val, linger) - } - end - end - - def test_listen - s = nil - log = Object.new - class << log; self end.send(:define_method, :to_int) { - s.close - 2 - } - inet_stream do |sock| - s = sock - assert_raise(IOError) { - s.listen(log) - } - end - end -end if defined?(Socket) - class TestSocket < Test::Unit::TestCase def test_unpack_sockaddr sockaddr_in = Socket.sockaddr_in(80, "")