| Index: net/spdy/spdy_framer_test.cc
|
| diff --git a/net/spdy/spdy_framer_test.cc b/net/spdy/spdy_framer_test.cc
|
| index 6192b40002ae79e68f8888eab587e2b75486bdda..afedbbac31005467947057c7fa6de2388c50f378 100644
|
| --- a/net/spdy/spdy_framer_test.cc
|
| +++ b/net/spdy/spdy_framer_test.cc
|
| @@ -148,7 +148,7 @@ TEST_F(SpdyFramerTest, HeaderBlock) {
|
| EXPECT_TRUE(frame.get() != NULL);
|
|
|
| SpdyHeaderBlock new_headers;
|
| - framer.ParseHeaderBlock(frame.get(), &new_headers);
|
| + EXPECT_TRUE(framer.ParseHeaderBlock(frame.get(), &new_headers));
|
|
|
| EXPECT_EQ(headers.size(), new_headers.size());
|
| EXPECT_EQ(headers["alpha"], new_headers["alpha"]);
|
| @@ -162,6 +162,7 @@ TEST_F(SpdyFramerTest, OutOfOrderHeaders) {
|
| frame.WriteUInt16(SYN_STREAM);
|
| frame.WriteUInt32(0); // Placeholder for the length.
|
| frame.WriteUInt32(3); // stream_id
|
| + frame.WriteUInt32(0); // associated stream id
|
| frame.WriteUInt16(0); // Priority.
|
|
|
| frame.WriteUInt16(2); // Number of headers.
|
| @@ -180,6 +181,51 @@ TEST_F(SpdyFramerTest, OutOfOrderHeaders) {
|
| EXPECT_TRUE(framer.ParseHeaderBlock(control_frame.get(), &new_headers));
|
| }
|
|
|
| +TEST_F(SpdyFramerTest, WrongNumberOfHeaders) {
|
| + SpdyFrameBuilder frame1;
|
| + SpdyFrameBuilder frame2;
|
| +
|
| + // a frame with smaller number of actual headers
|
| + frame1.WriteUInt16(kControlFlagMask | 1);
|
| + frame1.WriteUInt16(SYN_STREAM);
|
| + frame1.WriteUInt32(0); // Placeholder for the length.
|
| + frame1.WriteUInt32(3); // stream_id
|
| + frame1.WriteUInt32(0); // associated stream id
|
| + frame1.WriteUInt16(0); // Priority.
|
| +
|
| + frame1.WriteUInt16(1); // Wrong number of headers (underflow)
|
| + frame1.WriteString("gamma");
|
| + frame1.WriteString("gamma");
|
| + frame1.WriteString("alpha");
|
| + frame1.WriteString("alpha");
|
| + // write the length
|
| + frame1.WriteUInt32ToOffset(4, frame1.length() - SpdyFrame::size());
|
| +
|
| + // a frame with larger number of actual headers
|
| + frame2.WriteUInt16(kControlFlagMask | 1);
|
| + frame2.WriteUInt16(SYN_STREAM);
|
| + frame2.WriteUInt32(0); // Placeholder for the length.
|
| + frame2.WriteUInt32(3); // stream_id
|
| + frame2.WriteUInt32(0); // associated stream id
|
| + frame2.WriteUInt16(0); // Priority.
|
| +
|
| + frame2.WriteUInt16(100); // Wrong number of headers (overflow)
|
| + frame2.WriteString("gamma");
|
| + frame2.WriteString("gamma");
|
| + frame2.WriteString("alpha");
|
| + frame2.WriteString("alpha");
|
| + // write the length
|
| + frame2.WriteUInt32ToOffset(4, frame2.length() - SpdyFrame::size());
|
| +
|
| + SpdyHeaderBlock new_headers;
|
| + scoped_ptr<SpdyFrame> syn_frame1(frame1.take());
|
| + scoped_ptr<SpdyFrame> syn_frame2(frame2.take());
|
| + SpdyFramer framer;
|
| + FramerSetEnableCompressionHelper(&framer, false);
|
| + EXPECT_FALSE(framer.ParseHeaderBlock(syn_frame1.get(), &new_headers));
|
| + EXPECT_FALSE(framer.ParseHeaderBlock(syn_frame2.get(), &new_headers));
|
| +}
|
| +
|
| TEST_F(SpdyFramerTest, DuplicateHeader) {
|
| SpdyFrameBuilder frame;
|
|
|
| @@ -217,7 +263,7 @@ TEST_F(SpdyFramerTest, MultiValueHeader) {
|
| frame.WriteUInt32(0); // associated stream id
|
| frame.WriteUInt16(0); // Priority.
|
|
|
| - frame.WriteUInt16(2); // Number of headers.
|
| + frame.WriteUInt16(1); // Number of headers.
|
| SpdyHeaderBlock::iterator it;
|
| frame.WriteString("name");
|
| std::string value("value1\0value2");
|
| @@ -426,9 +472,8 @@ TEST_F(SpdyFramerTest, FinOnSynReplyFrame) {
|
| 0x00, 0x02, 'v', 'v',
|
|
|
| 0x80, 0x01, 0x00, 0x02, // SYN REPLY Stream #1
|
| - 0x01, 0x00, 0x00, 0x14,
|
| + 0x01, 0x00, 0x00, 0x10,
|
| 0x00, 0x00, 0x00, 0x01,
|
| - 0x00, 0x00, 0x00, 0x00,
|
| 0x00, 0x00, 0x00, 0x01,
|
| 0x00, 0x02, 'a', 'a',
|
| 0x00, 0x02, 'b', 'b',
|
| @@ -547,7 +592,7 @@ TEST_F(SpdyFramerTest, DataCompression) {
|
| TEST_F(SpdyFramerTest, UnclosedStreamDataCompressors) {
|
| SpdyFramer send_framer;
|
|
|
| - FramerSetEnableCompressionHelper(&send_framer, true);
|
| + FramerSetEnableCompressionHelper(&send_framer, false);
|
|
|
| const char kHeader1[] = "header1";
|
| const char kHeader2[] = "header2";
|
| @@ -565,7 +610,7 @@ TEST_F(SpdyFramerTest, UnclosedStreamDataCompressors) {
|
| const char bytes[] = "this is a test test test test test!";
|
| scoped_ptr<SpdyFrame> send_frame(
|
| send_framer.CreateDataFrame(1, bytes, arraysize(bytes),
|
| - DATA_FLAG_FIN | DATA_FLAG_COMPRESSED));
|
| + DATA_FLAG_FIN));
|
| EXPECT_TRUE(send_frame.get() != NULL);
|
|
|
| // Run the inputs through the framer.
|
|
|