diff options
author | Kazuki Yamaguchi <k@rhe.jp> | 2016-05-08 22:41:53 +0900 |
---|---|---|
committer | Kazuki Yamaguchi <k@rhe.jp> | 2016-05-08 22:41:53 +0900 |
commit | ef9daa152ecf2e3f9fe0f2c5eb083379a5077c3b (patch) | |
tree | b9e2afa99c7912ffca4dc0a24c1ccd886348f91b /test/plum/test_frame_utils.rb | |
parent | 85f218f35d2e9f1332701d908d9570c698708620 (diff) | |
parent | 89c73779d0eab2d9aae1e524245beebd589bf15d (diff) | |
download | plum-ef9daa152ecf2e3f9fe0f2c5eb083379a5077c3b.tar.gz |
Merge branch 'topic/refactor-for-0.3'
* topic/refactor-for-0.3:
examples: static_server: use test certificate in test/
style: prefer "".b over String.new
frame: settings: add Frame::Settings.ack
avoid Frame#type if possible
client: decoders: unfreeze Client::Decoders::DECODERS
frame: create subclasses for each frame type
merge *_{utils,factory}
Diffstat (limited to 'test/plum/test_frame_utils.rb')
-rw-r--r-- | test/plum/test_frame_utils.rb | 29 |
1 files changed, 19 insertions, 10 deletions
diff --git a/test/plum/test_frame_utils.rb b/test/plum/test_frame_utils.rb index 7ad869f..3851f6a 100644 --- a/test/plum/test_frame_utils.rb +++ b/test/plum/test_frame_utils.rb @@ -2,19 +2,14 @@ require "test_helper" class FrameUtilsTest < Minitest::Test def test_frame_enough_short - frame = Frame.new(type: :data, stream_id: 1, payload: "123") + frame = Frame::Data.new(1, "123") ret = frame.to_enum(:split, 3).to_a assert_equal(1, ret.size) assert_equal("123", ret.first.payload) end - def test_frame_unknown - frame = Frame.new(type: :settings, stream_id: 1, payload: "123") - assert_raises(NotImplementedError) { frame.split(2) } - end - def test_frame_data - frame = Frame.new(type: :data, flags: [:end_stream], stream_id: 1, payload: "12345") + frame = Frame::Data.new(1, "12345", end_stream: true) ret = frame.to_enum(:split, 2).to_a assert_equal(3, ret.size) assert_equal("12", ret.first.payload) @@ -23,8 +18,8 @@ class FrameUtilsTest < Minitest::Test assert_equal([:end_stream], ret.last.flags) end - def test_frame_headers - frame = Frame.new(type: :headers, flags: [:priority, :end_stream, :end_headers], stream_id: 1, payload: "1234567") + def test_headers_split + frame = Frame.craft(type: :headers, flags: [:priority, :end_stream, :end_headers], stream_id: 1, payload: "1234567") ret = frame.to_enum(:split, 3).to_a assert_equal(3, ret.size) assert_equal("123", ret[0].payload) @@ -35,9 +30,23 @@ class FrameUtilsTest < Minitest::Test assert_equal([:end_headers], ret[2].flags) end + def test_push_promise_split + frame = Frame::PushPromise.new(1, 2, "1234567", end_headers: true) + ret = frame.to_enum(:split, 3).to_a + assert_equal(4, ret.size) + assert_equal("\x00\x00\x00", ret[0].payload) + assert_equal([], ret[0].flags) + assert_equal("\x0212", ret[1].payload) + assert_equal([], ret[1].flags) + assert_equal("345", ret[2].payload) + assert_equal([], ret[2].flags) + assert_equal("67", ret[3].payload) + assert_equal([:end_headers], ret[3].flags) + end + def test_frame_parse_settings # :header_table_size => 0x1010, :enable_push => 0x00, :header_table_size => 0x1011 (overwrite) - frame = Frame.new(type: :settings, flags: [], stream_id: 0, payload: "\x00\x01\x00\x00\x10\x10\x00\x02\x00\x00\x00\x00\x00\x01\x00\x00\x10\x11") + frame = Frame.parse!("\x00\x00\x12\x04\x00\x00\x00\x00\x00" "\x00\x01\x00\x00\x10\x10\x00\x02\x00\x00\x00\x00\x00\x01\x00\x00\x10\x11") ret = frame.parse_settings assert_equal(0x1011, ret[:header_table_size]) assert_equal(0x0000, ret[:enable_push]) |