summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authornagachika <nagachika@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2018-08-17 16:20:53 +0000
committernagachika <nagachika@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2018-08-17 16:20:53 +0000
commit34783456e8105c65377a4473b466ffeaa581d87e (patch)
tree96b0a7cabfff42bae91efa5e6fe578d941397dc8
parent428db8240313f3af7ca3eb4359110563d108fbd3 (diff)
downloadruby-34783456e8105c65377a4473b466ffeaa581d87e.tar.gz
merge revision(s) 63396: [Backport #14750]
net/imap: Fix ArgumentError in send_string_data Thanks to ShockwaveNN (Pavel Lobashov) for reporting the bug. [ruby-core:86990] [Bug #14750] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_2_5@64420 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--lib/net/imap.rb14
-rw-r--r--test/net/imap/test_imap.rb37
-rw-r--r--version.h2
3 files changed, 45 insertions, 8 deletions
diff --git a/lib/net/imap.rb b/lib/net/imap.rb
index 3d33b94fdd..7db9c7a27e 100644
--- a/lib/net/imap.rb
+++ b/lib/net/imap.rb
@@ -1323,11 +1323,11 @@ module Net
when nil
put_string("NIL")
when String
- send_string_data(data)
+ send_string_data(data, tag)
when Integer
send_number_data(data)
when Array
- send_list_data(data)
+ send_list_data(data, tag)
when Time
send_time_data(data)
when Symbol
@@ -1337,13 +1337,13 @@ module Net
end
end
- def send_string_data(str)
+ def send_string_data(str, tag = nil)
case str
when ""
put_string('""')
when /[\x80-\xff\r\n]/n
# literal
- send_literal(str)
+ send_literal(str, tag)
when /[(){ \x00-\x1f\x7f%*"\\]/n
# quoted string
send_quoted_string(str)
@@ -1356,7 +1356,7 @@ module Net
put_string('"' + str.gsub(/["\\]/n, "\\\\\\&") + '"')
end
- def send_literal(str, tag)
+ def send_literal(str, tag = nil)
synchronize do
put_string("{" + str.bytesize.to_s + "}" + CRLF)
@continued_command_tag = tag
@@ -1377,7 +1377,7 @@ module Net
put_string(num.to_s)
end
- def send_list_data(list)
+ def send_list_data(list, tag = nil)
put_string("(")
first = true
list.each do |i|
@@ -1386,7 +1386,7 @@ module Net
else
put_string(" ")
end
- send_data(i)
+ send_data(i, tag)
end
put_string(")")
end
diff --git a/test/net/imap/test_imap.rb b/test/net/imap/test_imap.rb
index 38ea84cc21..41f25fe1c7 100644
--- a/test/net/imap/test_imap.rb
+++ b/test/net/imap/test_imap.rb
@@ -530,6 +530,43 @@ class IMAPTest < Test::Unit::TestCase
end
end
+ def test_send_literal
+ server = create_tcp_server
+ port = server.addr[1]
+ requests = []
+ literal = nil
+ @threads << Thread.start do
+ sock = server.accept
+ begin
+ sock.print("* OK test server\r\n")
+ line = sock.gets
+ requests.push(line)
+ size = line.slice(/{(\d+)}\r\n/, 1).to_i
+ sock.print("+ Ready for literal data\r\n")
+ literal = sock.read(size)
+ requests.push(sock.gets)
+ sock.print("RUBY0001 OK TEST completed\r\n")
+ sock.gets
+ sock.print("* BYE terminating connection\r\n")
+ sock.print("RUBY0002 OK LOGOUT completed\r\n")
+ ensure
+ sock.close
+ server.close
+ end
+ end
+ begin
+ imap = Net::IMAP.new(server_addr, :port => port)
+ imap.send(:send_command, "TEST", ["\xDE\xAD\xBE\xEF".b])
+ assert_equal(2, requests.length)
+ assert_equal("RUBY0001 TEST ({4}\r\n", requests[0])
+ assert_equal("\xDE\xAD\xBE\xEF".b, literal)
+ assert_equal(")\r\n", requests[1])
+ imap.logout
+ ensure
+ imap.disconnect
+ end
+ end
+
def test_disconnect
server = create_tcp_server
port = server.addr[1]
diff --git a/version.h b/version.h
index 24c0c93b35..b4ac1f5bad 100644
--- a/version.h
+++ b/version.h
@@ -1,6 +1,6 @@
#define RUBY_VERSION "2.5.2"
#define RUBY_RELEASE_DATE "2018-08-18"
-#define RUBY_PATCHLEVEL 70
+#define RUBY_PATCHLEVEL 71
#define RUBY_RELEASE_YEAR 2018
#define RUBY_RELEASE_MONTH 8