diff options
author | Matt Muller <mamuller@amazon.com> | 2020-02-21 13:55:07 -0800 |
---|---|---|
committer | Hiroshi SHIBATA <hsbt@ruby-lang.org> | 2020-03-26 18:06:14 +0900 |
commit | 92a238a21caa6e8c9e4823b8bee67e37a362a9f8 (patch) | |
tree | 18918830458573b5bd9573c3156e5836fff473e3 /test | |
parent | 844ff7ea45b79e95eaed4b725fd0cf5c33874058 (diff) | |
download | ruby-92a238a21caa6e8c9e4823b8bee67e37a362a9f8.tar.gz |
[ruby/uri] Add support for WebSockets
https://github.com/ruby/uri/commit/805a95786a
Diffstat (limited to 'test')
-rw-r--r-- | test/uri/test_ws.rb | 70 |
1 files changed, 70 insertions, 0 deletions
diff --git a/test/uri/test_ws.rb b/test/uri/test_ws.rb new file mode 100644 index 0000000000..e3e66f80c0 --- /dev/null +++ b/test/uri/test_ws.rb @@ -0,0 +1,70 @@ +# frozen_string_literal: false +require 'test/unit' +require 'uri/ws' + +module URI + + +class TestWS < 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_build + u = URI::WS.build(host: 'www.example.com', path: '/foo/bar') + assert_kind_of(URI::WS, u) + end + + def test_parse + u = URI.parse('ws://a') + assert_kind_of(URI::WS, u) + assert_equal(['ws', + nil, 'a', URI::HTTP.default_port, + '', nil], uri_to_ary(u)) + end + + def test_normalize + host = 'aBcD' + u1 = URI.parse('ws://' + host + '/eFg?HiJ') + u2 = URI.parse('ws://' + 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('ws://abc/', URI.parse('ws://abc').normalize.to_s) + end + + def test_equal + assert(URI.parse('ws://abc') == URI.parse('ws://ABC')) + assert(URI.parse('ws://abc/def') == URI.parse('ws://ABC/def')) + assert(URI.parse('ws://abc/def') != URI.parse('ws://ABC/DEF')) + end + + def test_request_uri + assert_equal('/', URI.parse('ws://a.b.c/').request_uri) + assert_equal('/?abc=def', URI.parse('ws://a.b.c/?abc=def').request_uri) + assert_equal('/', URI.parse('ws://a.b.c').request_uri) + assert_equal('/?abc=def', URI.parse('ws://a.b.c?abc=def').request_uri) + assert_equal(nil, URI.parse('ws:foo').request_uri) + end + + def test_select + assert_equal(['ws', 'a.b.c', 80], URI.parse('ws://a.b.c/').select(:scheme, :host, :port)) + u = URI.parse('ws://a.b.c/') + assert_equal(uri_to_ary(u), u.select(*u.component)) + assert_raise(ArgumentError) do + u.select(:scheme, :host, :not_exist, :port) + end + end +end + + +end |