mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
merge revision(s) 44312,44318,44321: [Backport #9273]
* lib/resolv.rb (Resolv::Hosts#lazy_initialize): should not consider encodings in hosts file. [ruby-core:59239] [Bug #9273] * lib/resolv.rb (Resolv::Config.parse_resolv_conf): ditto. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_9_3@44739 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
12aec90ddf
commit
888372e595
5 changed files with 34 additions and 3 deletions
|
@ -1,3 +1,10 @@
|
|||
Wed Jan 29 13:25:32 2014 Nobuyoshi Nakada <nobu@ruby-lang.org>
|
||||
|
||||
* lib/resolv.rb (Resolv::Hosts#lazy_initialize): should not
|
||||
consider encodings in hosts file. [ruby-core:59239] [Bug #9273]
|
||||
|
||||
* lib/resolv.rb (Resolv::Config.parse_resolv_conf): ditto.
|
||||
|
||||
Wed Jan 29 13:00:17 2014 Nobuyoshi Nakada <nobu@ruby-lang.org>
|
||||
|
||||
* util.c (ruby_qsort): fix potential stack overflow on a large
|
||||
|
|
|
@ -186,7 +186,7 @@ class Resolv
|
|||
unless @initialized
|
||||
@name2addr = {}
|
||||
@addr2name = {}
|
||||
open(@filename) {|f|
|
||||
open(@filename, 'rb') {|f|
|
||||
f.each {|line|
|
||||
line.sub!(/#.*/, '')
|
||||
addr, hostname, *aliases = line.split(/\s+/)
|
||||
|
@ -857,7 +857,7 @@ class Resolv
|
|||
nameserver = []
|
||||
search = nil
|
||||
ndots = 1
|
||||
open(filename) {|f|
|
||||
open(filename, 'rb') {|f|
|
||||
f.each {|line|
|
||||
line.sub!(/[#;].*/, '')
|
||||
keyword, *args = line.split(/\s+/)
|
||||
|
|
|
@ -1,6 +1,7 @@
|
|||
require 'test/unit'
|
||||
require 'resolv'
|
||||
require 'socket'
|
||||
require 'tempfile'
|
||||
|
||||
class TestResolvAddr < Test::Unit::TestCase
|
||||
def test_invalid_ipv4_address
|
||||
|
@ -13,4 +14,16 @@ class TestResolvAddr < Test::Unit::TestCase
|
|||
end
|
||||
}
|
||||
end
|
||||
|
||||
def test_invalid_byte_comment
|
||||
bug9273 = '[ruby-core:59239] [Bug #9273]'
|
||||
Tempfile.open('resolv_test_addr_') do |tmpfile|
|
||||
tmpfile.print("\xff\x00\x40")
|
||||
tmpfile.close
|
||||
hosts = Resolv::Hosts.new(tmpfile.path)
|
||||
assert_nothing_raised(ArgumentError, bug9273) do
|
||||
hosts.each_address("") {break}
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
|
|
|
@ -1,6 +1,7 @@
|
|||
require 'test/unit'
|
||||
require 'resolv'
|
||||
require 'socket'
|
||||
require 'tempfile'
|
||||
|
||||
class TestResolvDNS < Test::Unit::TestCase
|
||||
def setup
|
||||
|
@ -118,4 +119,14 @@ class TestResolvDNS < Test::Unit::TestCase
|
|||
}
|
||||
end
|
||||
|
||||
def test_invalid_byte_comment
|
||||
bug9273 = '[ruby-core:59239] [Bug #9273]'
|
||||
Tempfile.open('resolv_test_dns_') do |tmpfile|
|
||||
tmpfile.print("\xff\x00\x40")
|
||||
tmpfile.close
|
||||
assert_nothing_raised(ArgumentError, bug9273) do
|
||||
Resolv::DNS::Config.parse_resolv_conf(tmpfile.path)
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
#define RUBY_VERSION "1.9.3"
|
||||
#define RUBY_PATCHLEVEL 493
|
||||
#define RUBY_PATCHLEVEL 494
|
||||
|
||||
#define RUBY_RELEASE_DATE "2014-01-29"
|
||||
#define RUBY_RELEASE_YEAR 2014
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue