diff options
author | Miklós Fazekas <mfazekas@szemafor.com> | 2010-03-16 20:08:13 +0100 |
---|---|---|
committer | Miklós Fazekas <mfazekas@szemafor.com> | 2010-03-16 20:08:13 +0100 |
commit | ab7a3ae2a92bf4f30cf4bcf533c4f102e7103647 (patch) | |
tree | 41bd92650573a91d3e41bf18c69da0511b1cf378 | |
parent | 845eb8f97d437f14874a1cae64e29f52528fab33 (diff) | |
download | net-ssh-ab7a3ae2a92bf4f30cf4bcf533c4f102e7103647.tar.gz |
Handling poptential exceptions in on_eof, and deadlock in tests
-rw-r--r-- | endtoendtests/test_forward.rb | 8 | ||||
-rw-r--r-- | lib/net/ssh/service/forward.rb | 16 |
2 files changed, 18 insertions, 6 deletions
diff --git a/endtoendtests/test_forward.rb b/endtoendtests/test_forward.rb index 929f136..4898f1c 100644 --- a/endtoendtests/test_forward.rb +++ b/endtoendtests/test_forward.rb @@ -17,7 +17,7 @@ class TestForward < Test::Unit::TestCase end def ssh_start_params - [localhost ,ENV['USER']] + [localhost ,ENV['USER']] #:verbose => :debug end def find_free_port @@ -28,7 +28,7 @@ class TestForward < Test::Unit::TestCase port end - def start_server_sending_lot_of_data(exceptions=nil) + def start_server_sending_lot_of_data(exceptions) server = TCPServer.open(0) Thread.start do loop do @@ -86,7 +86,7 @@ class TestForward < Test::Unit::TestCase end end session.loop(0.1) { client_done.empty? } - assert_equal "Broken pipe", "#{server_exc.pop}" + assert_equal "Broken pipe", "#{server_exc.pop}" unless server_exc.empty? end def test_loop_should_not_abort_when_local_side_of_forward_is_reset @@ -109,7 +109,7 @@ class TestForward < Test::Unit::TestCase end end session.loop(0.1) { client_done.empty? } - assert_equal "Broken pipe", "#{server_exc.pop}" + assert_equal "Broken pipe", "#{server_exc.pop}" unless server_exc.empty? end def test_loop_should_not_abort_when_server_side_of_forward_is_closed diff --git a/lib/net/ssh/service/forward.rb b/lib/net/ssh/service/forward.rb index 67b12ba..9e37dce 100644 --- a/lib/net/ssh/service/forward.rb +++ b/lib/net/ssh/service/forward.rb @@ -246,8 +246,20 @@ module Net; module SSH; module Service channel.on_eof do |ch| debug { "eof #{type} on #{type} forwarded channel" } - ch[:socket].send_pending - ch[:socket].shutdown Socket::SHUT_WR + begin + ch[:socket].send_pending + ch[:socket].shutdown Socket::SHUT_WR + rescue IOError => e + if e.message =~ /closed/ then + debug { "epipe in on_eof => shallowing exception:#{e}" } + else + raise + end + rescue Errno::EPIPE => e + debug { "epipe in on_eof => shallowing exception:#{e}" } + rescue Errno::ENOTCONN => e + debug { "enotconn in on_eof => shallowing exception:#{e}" } + end end channel.on_close do |ch| |