mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
* lib/net/ftp.rb (gettextfile, getbinaryfile): use the safe
navigation operator. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@52239 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
1d3c07633c
commit
3eabc555cb
3 changed files with 147 additions and 15 deletions
|
@ -1,3 +1,8 @@
|
|||
Fri Oct 23 15:20:02 2015 Shugo Maeda <shugo@ruby-lang.org>
|
||||
|
||||
* lib/net/ftp.rb (gettextfile, getbinaryfile): use the safe
|
||||
navigation operator.
|
||||
|
||||
Fri Oct 23 13:51:33 2015 yui-knk <spiketeika@gmail.com>
|
||||
|
||||
* test_call.rb (test_safe_call): Add test cases for safe
|
||||
|
|
|
@ -1,5 +1,4 @@
|
|||
#
|
||||
# -*- frozen_string_literal: true -*-
|
||||
# frozen_string_literal: true
|
||||
#
|
||||
# = net/ftp.rb - FTP Client Library
|
||||
#
|
||||
|
@ -601,7 +600,8 @@ module Net
|
|||
# chunks.
|
||||
#
|
||||
def getbinaryfile(remotefile, localfile = File.basename(remotefile),
|
||||
blocksize = DEFAULT_BLOCKSIZE) # :yield: data
|
||||
blocksize = DEFAULT_BLOCKSIZE, &block) # :yield: data
|
||||
f = nil
|
||||
result = nil
|
||||
if localfile
|
||||
if @resume
|
||||
|
@ -615,15 +615,15 @@ module Net
|
|||
result = String.new
|
||||
end
|
||||
begin
|
||||
f.binmode if localfile
|
||||
f.?binmode
|
||||
retrbinary("RETR #{remotefile}", blocksize, rest_offset) do |data|
|
||||
f.write(data) if localfile
|
||||
yield(data) if block_given?
|
||||
result.concat(data) if result
|
||||
f.?write(data)
|
||||
block.?(data)
|
||||
result.?concat(data)
|
||||
end
|
||||
return result
|
||||
ensure
|
||||
f.close if localfile
|
||||
f.?close
|
||||
end
|
||||
end
|
||||
|
||||
|
@ -634,7 +634,9 @@ module Net
|
|||
# If a block is supplied, it is passed the retrieved data one
|
||||
# line at a time.
|
||||
#
|
||||
def gettextfile(remotefile, localfile = File.basename(remotefile)) # :yield: line
|
||||
def gettextfile(remotefile, localfile = File.basename(remotefile),
|
||||
&block) # :yield: line
|
||||
f = nil
|
||||
result = nil
|
||||
if localfile
|
||||
f = open(localfile, "w")
|
||||
|
@ -644,13 +646,13 @@ module Net
|
|||
begin
|
||||
retrlines("RETR #{remotefile}") do |line, newline|
|
||||
l = newline ? line + "\n" : line
|
||||
f.print(l) if localfile
|
||||
yield(line, newline) if block_given?
|
||||
result.concat(l) if result
|
||||
f.?print(l)
|
||||
block.?(line, newline)
|
||||
result.?concat(l)
|
||||
end
|
||||
return result
|
||||
ensure
|
||||
f.close if localfile
|
||||
f.?close
|
||||
end
|
||||
end
|
||||
|
||||
|
|
|
@ -1,10 +1,10 @@
|
|||
#
|
||||
# -*- frozen_string_literal: true -*-
|
||||
# frozen_string_literal: true
|
||||
|
||||
require "net/ftp"
|
||||
require "test/unit"
|
||||
require "ostruct"
|
||||
require "stringio"
|
||||
require "tempfile"
|
||||
|
||||
class FTPTest < Test::Unit::TestCase
|
||||
SERVER_ADDR = "127.0.0.1"
|
||||
|
@ -758,6 +758,64 @@ class FTPTest < Test::Unit::TestCase
|
|||
end
|
||||
end
|
||||
|
||||
def test_getbinaryfile_with_filename_and_block
|
||||
commands = []
|
||||
binary_data = (0..0xff).map {|i| i.chr}.join * 4 * 3
|
||||
server = create_ftp_server { |sock|
|
||||
sock.print("220 (test_ftp).\r\n")
|
||||
commands.push(sock.gets)
|
||||
sock.print("331 Please specify the password.\r\n")
|
||||
commands.push(sock.gets)
|
||||
sock.print("230 Login successful.\r\n")
|
||||
commands.push(sock.gets)
|
||||
sock.print("200 Switching to Binary mode.\r\n")
|
||||
line = sock.gets
|
||||
commands.push(line)
|
||||
port_args = line.slice(/\APORT (.*)/, 1).split(/,/)
|
||||
host = port_args[0, 4].join(".")
|
||||
port = port_args[4, 2].map(&:to_i).inject {|x, y| (x << 8) + y}
|
||||
sock.print("200 PORT command successful.\r\n")
|
||||
commands.push(sock.gets)
|
||||
sock.print("150 Opening BINARY mode data connection for foo (#{binary_data.size} bytes)\r\n")
|
||||
conn = TCPSocket.new(host, port)
|
||||
binary_data.scan(/.{1,1024}/nm) do |s|
|
||||
conn.print(s)
|
||||
end
|
||||
conn.shutdown(Socket::SHUT_WR)
|
||||
conn.read
|
||||
conn.close
|
||||
sock.print("226 Transfer complete.\r\n")
|
||||
}
|
||||
begin
|
||||
begin
|
||||
ftp = Net::FTP.new
|
||||
ftp.read_timeout = 0.2
|
||||
ftp.connect(SERVER_ADDR, server.port)
|
||||
ftp.login
|
||||
assert_match(/\AUSER /, commands.shift)
|
||||
assert_match(/\APASS /, commands.shift)
|
||||
assert_equal("TYPE I\r\n", commands.shift)
|
||||
Tempfile.create("foo", external_encoding: "ASCII-8BIT") do |f|
|
||||
buf = String.new
|
||||
res = ftp.getbinaryfile("foo", f.path) { |s|
|
||||
buf << s
|
||||
}
|
||||
assert_equal(nil, res)
|
||||
assert_equal(binary_data, buf)
|
||||
assert_equal(Encoding::ASCII_8BIT, buf.encoding)
|
||||
assert_equal(binary_data, f.read)
|
||||
end
|
||||
assert_match(/\APORT /, commands.shift)
|
||||
assert_equal("RETR foo\r\n", commands.shift)
|
||||
assert_equal(nil, commands.shift)
|
||||
ensure
|
||||
ftp.close if ftp
|
||||
end
|
||||
ensure
|
||||
server.close
|
||||
end
|
||||
end
|
||||
|
||||
def test_storbinary
|
||||
commands = []
|
||||
binary_data = (0..0xff).map {|i| i.chr}.join * 4 * 3
|
||||
|
@ -966,6 +1024,73 @@ EOF
|
|||
end
|
||||
end
|
||||
|
||||
def test_gettextfile_with_filename_and_block
|
||||
commands = []
|
||||
text_data = <<EOF.gsub(/\n/, "\r\n")
|
||||
foo
|
||||
bar
|
||||
baz
|
||||
EOF
|
||||
server = create_ftp_server { |sock|
|
||||
sock.print("220 (test_ftp).\r\n")
|
||||
commands.push(sock.gets)
|
||||
sock.print("331 Please specify the password.\r\n")
|
||||
commands.push(sock.gets)
|
||||
sock.print("230 Login successful.\r\n")
|
||||
commands.push(sock.gets)
|
||||
sock.print("200 Switching to Binary mode.\r\n")
|
||||
commands.push(sock.gets)
|
||||
sock.print("200 Switching to ASCII mode.\r\n")
|
||||
line = sock.gets
|
||||
commands.push(line)
|
||||
port_args = line.slice(/\APORT (.*)/, 1).split(/,/)
|
||||
host = port_args[0, 4].join(".")
|
||||
port = port_args[4, 2].map(&:to_i).inject {|x, y| (x << 8) + y}
|
||||
sock.print("200 PORT command successful.\r\n")
|
||||
commands.push(sock.gets)
|
||||
sock.print("150 Opening TEXT mode data connection for foo (#{text_data.size} bytes)\r\n")
|
||||
conn = TCPSocket.new(host, port)
|
||||
text_data.each_line do |line|
|
||||
conn.print(line)
|
||||
end
|
||||
conn.shutdown(Socket::SHUT_WR)
|
||||
conn.read
|
||||
conn.close
|
||||
sock.print("226 Transfer complete.\r\n")
|
||||
commands.push(sock.gets)
|
||||
sock.print("200 Switching to Binary mode.\r\n")
|
||||
}
|
||||
begin
|
||||
begin
|
||||
ftp = Net::FTP.new
|
||||
ftp.connect(SERVER_ADDR, server.port)
|
||||
ftp.login
|
||||
assert_match(/\AUSER /, commands.shift)
|
||||
assert_match(/\APASS /, commands.shift)
|
||||
assert_equal("TYPE I\r\n", commands.shift)
|
||||
Tempfile.create("foo", external_encoding: "ascii-8bit") do |f|
|
||||
buf = String.new
|
||||
res = ftp.gettextfile("foo", f.path) { |s|
|
||||
buf << s << "\n"
|
||||
}
|
||||
assert_equal(nil, res)
|
||||
assert_equal(text_data.gsub(/\r\n/, "\n"), buf)
|
||||
assert_equal(Encoding::ASCII_8BIT, buf.encoding)
|
||||
assert_equal(buf, f.read)
|
||||
end
|
||||
assert_equal("TYPE A\r\n", commands.shift)
|
||||
assert_match(/\APORT /, commands.shift)
|
||||
assert_equal("RETR foo\r\n", commands.shift)
|
||||
assert_equal("TYPE I\r\n", commands.shift)
|
||||
assert_equal(nil, commands.shift)
|
||||
ensure
|
||||
ftp.close if ftp
|
||||
end
|
||||
ensure
|
||||
server.close
|
||||
end
|
||||
end
|
||||
|
||||
def test_getbinaryfile_in_list
|
||||
commands = []
|
||||
binary_data = (0..0xff).map {|i| i.chr}.join
|
||||
|
|
Loading…
Reference in a new issue