mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
234a30459c
Now URI is normally UTF-8, and US-ASCII URI string is considered as escaped a UTF-8 string. https://github.com/rails/rails/issues/32294 git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@62897 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
56 lines
1.4 KiB
Ruby
56 lines
1.4 KiB
Ruby
# frozen_string_literal: false
|
|
require 'test/unit'
|
|
require 'uri'
|
|
|
|
class URI::TestParser < Test::Unit::TestCase
|
|
def uri_to_ary(uri)
|
|
uri.class.component.collect {|c| uri.send(c)}
|
|
end
|
|
|
|
def test_compare
|
|
url = 'http://a/b/c/d;p?q'
|
|
u0 = URI.parse(url)
|
|
u1 = URI.parse(url)
|
|
p = URI::Parser.new
|
|
u2 = p.parse(url)
|
|
u3 = p.parse(url)
|
|
|
|
assert(u0 == u1)
|
|
assert(u0.eql?(u1))
|
|
assert(!u0.equal?(u1))
|
|
|
|
assert(u1 == u2)
|
|
assert(!u1.eql?(u2))
|
|
assert(!u1.equal?(u2))
|
|
|
|
assert(u2 == u3)
|
|
assert(u2.eql?(u3))
|
|
assert(!u2.equal?(u3))
|
|
end
|
|
|
|
def test_parse
|
|
escaped = URI::REGEXP::PATTERN::ESCAPED
|
|
hex = URI::REGEXP::PATTERN::HEX
|
|
p1 = URI::Parser.new(:ESCAPED => "(?:#{escaped}|%u[#{hex}]{4})")
|
|
u1 = p1.parse('http://a/b/%uABCD')
|
|
assert_equal(['http', nil, 'a', URI::HTTP.default_port, '/b/%uABCD', nil, nil],
|
|
uri_to_ary(u1))
|
|
u1.path = '/%uDCBA'
|
|
assert_equal(['http', nil, 'a', URI::HTTP.default_port, '/%uDCBA', nil, nil],
|
|
uri_to_ary(u1))
|
|
end
|
|
|
|
def test_raise_bad_uri_for_integer
|
|
assert_raise(URI::InvalidURIError) do
|
|
URI.parse(1)
|
|
end
|
|
end
|
|
|
|
def test_unescape
|
|
p1 = URI::Parser.new
|
|
assert_equal("\xe3\x83\x90", p1.unescape("\xe3\x83\x90"))
|
|
assert_equal("\xe3\x83\x90", p1.unescape('%e3%83%90'))
|
|
assert_equal("\u3042", p1.unescape('%e3%81%82'.force_encoding(Encoding::US_ASCII)))
|
|
assert_equal("\xe3\x83\x90\xe3\x83\x90", p1.unescape("\xe3\x83\x90%e3%83%90"))
|
|
end
|
|
end
|