mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
resolv.rb: no encodings
* 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/trunk@44312 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
96225160f6
commit
1ffbe07e17
4 changed files with 34 additions and 2 deletions
|
@ -1,3 +1,10 @@
|
||||||
|
Sat Dec 21 12:37:19 2013 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.
|
||||||
|
|
||||||
Sat Dec 21 05:43:27 2013 NAKAMURA Usaku <usa@ruby-lang.org>
|
Sat Dec 21 05:43:27 2013 NAKAMURA Usaku <usa@ruby-lang.org>
|
||||||
|
|
||||||
* tool/make-snapshot: replace RUBY_PATCHLEVEL_STR in version.h to
|
* tool/make-snapshot: replace RUBY_PATCHLEVEL_STR in version.h to
|
||||||
|
|
|
@ -187,7 +187,7 @@ class Resolv
|
||||||
unless @initialized
|
unless @initialized
|
||||||
@name2addr = {}
|
@name2addr = {}
|
||||||
@addr2name = {}
|
@addr2name = {}
|
||||||
open(@filename) {|f|
|
open(@filename, 'rb') {|f|
|
||||||
f.each {|line|
|
f.each {|line|
|
||||||
line.sub!(/#.*/, '')
|
line.sub!(/#.*/, '')
|
||||||
addr, hostname, *aliases = line.split(/\s+/)
|
addr, hostname, *aliases = line.split(/\s+/)
|
||||||
|
@ -920,7 +920,7 @@ class Resolv
|
||||||
nameserver = []
|
nameserver = []
|
||||||
search = nil
|
search = nil
|
||||||
ndots = 1
|
ndots = 1
|
||||||
open(filename) {|f|
|
open(filename, 'rb') {|f|
|
||||||
f.each {|line|
|
f.each {|line|
|
||||||
line.sub!(/[#;].*/, '')
|
line.sub!(/[#;].*/, '')
|
||||||
keyword, *args = line.split(/\s+/)
|
keyword, *args = line.split(/\s+/)
|
||||||
|
|
|
@ -13,4 +13,16 @@ class TestResolvAddr < Test::Unit::TestCase
|
||||||
end
|
end
|
||||||
}
|
}
|
||||||
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
|
end
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
require 'test/unit'
|
require 'test/unit'
|
||||||
require 'resolv'
|
require 'resolv'
|
||||||
require 'socket'
|
require 'socket'
|
||||||
|
require 'tempfile'
|
||||||
|
|
||||||
class TestResolvDNS < Test::Unit::TestCase
|
class TestResolvDNS < Test::Unit::TestCase
|
||||||
def setup
|
def setup
|
||||||
|
@ -150,4 +151,16 @@ class TestResolvDNS < Test::Unit::TestCase
|
||||||
}
|
}
|
||||||
end
|
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
|
||||||
|
Resolv::DNS.open(tmpfile.path) do |dns|
|
||||||
|
assert_nothing_raised(ArgumentError, bug9273) do
|
||||||
|
dns.getresources("foo.example.org", Resolv::DNS::Resource::IN::A)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue