mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
66 lines
1.9 KiB
Ruby
66 lines
1.9 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_inspect
|
|
assert_match(/URI::RFC2396_Parser/, URI::Parser.new.inspect)
|
|
assert_match(/URI::RFC3986_Parser/, URI::RFC3986_Parser.new.inspect)
|
|
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_parse_query_pct_encoded
|
|
assert_equal('q=%32!$&-/?.09;=:@AZ_az~', URI.parse('https://www.example.com/search?q=%32!$&-/?.09;=:@AZ_az~').query)
|
|
assert_raise(URI::InvalidURIError) { URI.parse('https://www.example.com/search?q=%XX') }
|
|
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
|