summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog4
-rw-r--r--lib/net/ftp.rb23
-rw-r--r--test/net/ftp/test_ftp.rb15
3 files changed, 30 insertions, 12 deletions
diff --git a/ChangeLog b/ChangeLog
index 52914b66e8..677ba7033a 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,7 @@
+Mon May 21 11:26:17 2012 NARUSE, Yui <naruse@ruby-lang.org>
+
+ * lib/net/ftp.rb (Net::FTP#transfercmd): rescue shutdown.
+
Sun May 20 23:00:11 2012 Nobuyoshi Nakada <nobu@ruby-lang.org>
* ext/extmk.rb (extmake): reopen $stdout to NULL, since setting
diff --git a/lib/net/ftp.rb b/lib/net/ftp.rb
index 3684d1ebf4..8694b09063 100644
--- a/lib/net/ftp.rb
+++ b/lib/net/ftp.rb
@@ -433,7 +433,7 @@ module Net
end
conn = BufferedSocket.new(sock.accept)
conn.read_timeout = @read_timeout
- sock.shutdown(Socket::SHUT_WR)
+ sock.shutdown(Socket::SHUT_WR) rescue nil
sock.read rescue nil
sock.close
end
@@ -483,16 +483,19 @@ module Net
def retrbinary(cmd, blocksize, rest_offset = nil) # :yield: data
synchronize do
with_binary(true) do
- conn = transfercmd(cmd, rest_offset)
- loop do
- data = conn.read(blocksize)
- break if data == nil
- yield(data)
+ begin
+ conn = transfercmd(cmd, rest_offset)
+ loop do
+ data = conn.read(blocksize)
+ break if data == nil
+ yield(data)
+ end
+ conn.shutdown(Socket::SHUT_WR)
+ conn.read_timeout = 1
+ conn.read
+ ensure
+ conn.close
end
- conn.shutdown(Socket::SHUT_WR)
- conn.read_timeout = 1
- conn.read
- conn.close
voidresp
end
end
diff --git a/test/net/ftp/test_ftp.rb b/test/net/ftp/test_ftp.rb
index 5a566a52f2..a3a08c67b2 100644
--- a/test/net/ftp/test_ftp.rb
+++ b/test/net/ftp/test_ftp.rb
@@ -6,6 +6,16 @@ require "stringio"
class FTPTest < Test::Unit::TestCase
SERVER_ADDR = "127.0.0.1"
+ def setup
+ @thread = nil
+ end
+
+ def teardown
+ if @thread
+ @thread.join
+ end
+ end
+
def test_not_connected
ftp = Net::FTP.new
assert_raise(Net::FTPConnectionError) do
@@ -272,7 +282,8 @@ class FTPTest < Test::Unit::TestCase
conn.print(l, "\r\n")
end
conn.shutdown(Socket::SHUT_WR)
- conn.read
+ conn.read_timeout = 1
+ conn.read unless conn.eof?
conn.close
sock.print("226 Directory send OK.\r\n")
}
@@ -586,7 +597,7 @@ class FTPTest < Test::Unit::TestCase
def create_ftp_server(sleep_time = nil)
server = TCPServer.new(SERVER_ADDR, 0)
- Thread.start do
+ @thread = Thread.start do
begin
if sleep_time
sleep(sleep_time)