summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authordelano <delano@solutious.com>2010-03-16 15:23:15 -0400
committerdelano <delano@solutious.com>2010-03-16 15:23:15 -0400
commite06054d0f324a058cf1b9f3232b24c631ebcf612 (patch)
treeaf0fc726c53176e9b1ba06fe86a795e2168f11b1
parent070f9b3822485847f4e69abf80d0bd3729b4785c (diff)
parentab7a3ae2a92bf4f30cf4bcf533c4f102e7103647 (diff)
downloadnet-ssh-e06054d0f324a058cf1b9f3232b24c631ebcf612.tar.gz
Merge branch 'portfwfix' of http://github.com/mfazekas/net-ssh into portfwfixportfwfix
-rw-r--r--lib/net/ssh/service/forward.rb16
-rw-r--r--test/manual/test_forward.rb8
2 files changed, 18 insertions, 6 deletions
diff --git a/lib/net/ssh/service/forward.rb b/lib/net/ssh/service/forward.rb
index 024a9cb..fa3e4f0 100644
--- a/lib/net/ssh/service/forward.rb
+++ b/lib/net/ssh/service/forward.rb
@@ -213,8 +213,20 @@ module Net; module SSH; module Service
# Handles server close on the sending side by Miklós Fazekas
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|
diff --git a/test/manual/test_forward.rb b/test/manual/test_forward.rb
index 194aed7..46ddb25 100644
--- a/test/manual/test_forward.rb
+++ b/test/manual/test_forward.rb
@@ -26,7 +26,7 @@ class TestForward < Test::Unit::TestCase
end
def ssh_start_params
- [localhost ,ENV['USER']]
+ [localhost ,ENV['USER']] #:verbose => :debug
end
def find_free_port
@@ -37,7 +37,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
@@ -95,7 +95,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
@@ -118,7 +118,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