diff options
author | yugui <yugui@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2008-08-25 15:02:05 +0000 |
---|---|---|
committer | yugui <yugui@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2008-08-25 15:02:05 +0000 |
commit | 0dc342de848a642ecce8db697b8fecd83a63e117 (patch) | |
tree | 2b7ed4724aff1f86073e4740134bda9c4aac1a39 /trunk/test/uri/test_http.rb | |
parent | ef70cf7138ab8034b5b806f466e4b484b24f0f88 (diff) |
added tag v1_9_0_4
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/tags/v1_9_0_4@18845 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'trunk/test/uri/test_http.rb')
-rw-r--r-- | trunk/test/uri/test_http.rb | 63 |
1 files changed, 63 insertions, 0 deletions
diff --git a/trunk/test/uri/test_http.rb b/trunk/test/uri/test_http.rb new file mode 100644 index 0000000000..a6846141df --- /dev/null +++ b/trunk/test/uri/test_http.rb @@ -0,0 +1,63 @@ +require 'test/unit' +require 'uri/http' + +module URI + + +class TestHTTP < Test::Unit::TestCase + def setup + end + + def teardown + end + + def uri_to_ary(uri) + uri.class.component.collect {|c| uri.send(c)} + end + + def test_parse + u = URI.parse('http://a') + assert_kind_of(URI::HTTP, u) + assert_equal(['http', + nil, 'a', URI::HTTP.default_port, + '', nil, nil], uri_to_ary(u)) + end + + def test_normalize + host = 'aBcD' + u1 = URI.parse('http://' + host + '/eFg?HiJ') + u2 = URI.parse('http://' + host.downcase + '/eFg?HiJ') + assert(u1.normalize.host == 'abcd') + assert(u1.normalize.path == u1.path) + assert(u1.normalize == u2.normalize) + assert(!u1.normalize.host.equal?(u1.host)) + assert( u2.normalize.host.equal?(u2.host)) + + assert_equal('http://abc/', URI.parse('http://abc').normalize.to_s) + end + + def test_equal + assert(URI.parse('http://abc') == URI.parse('http://ABC')) + assert(URI.parse('http://abc/def') == URI.parse('http://ABC/def')) + assert(URI.parse('http://abc/def') != URI.parse('http://ABC/DEF')) + end + + def test_request_uri + assert_equal('/', URI.parse('http://a.b.c/').request_uri) + assert_equal('/?abc=def', URI.parse('http://a.b.c/?abc=def').request_uri) + assert_equal('/', URI.parse('http://a.b.c').request_uri) + assert_equal('/?abc=def', URI.parse('http://a.b.c?abc=def').request_uri) + end + + def test_select + assert_equal(['http', 'a.b.c', 80], URI.parse('http://a.b.c/').select(:scheme, :host, :port)) + u = URI.parse('http://a.b.c/') + assert_equal(uri_to_ary(u), u.select(*u.component)) + assert_raises(ArgumentError) do + u.select(:scheme, :host, :not_exist, :port) + end + end +end + + +end |