Chromium Code Reviews| Index: net/spdy/spdy_protocol_test.cc |
| =================================================================== |
| --- net/spdy/spdy_protocol_test.cc (working copy) |
| +++ net/spdy/spdy_protocol_test.cc (working copy) |
| @@ -44,11 +44,32 @@ |
| namespace { |
| -// Default SPDY version for unit tests. |
| -const int SPDY_VERSION_FOR_TESTS = 3; |
| +enum SpdyProtocolTestTypes { |
| + SPDY2, |
| + SPDY3, |
| +}; |
| +class SpdyProtocolTest |
| + : public ::testing::TestWithParam<SpdyProtocolTestTypes> { |
| + protected: |
| + virtual void SetUp() { |
| + spdy_version_ = (GetParam() == SPDY2) ? 2 : 3; |
| + } |
| + |
| + virtual void TearDown() {} |
| + |
| + // Default SPDY version for unit tests. |
|
Ryan Hamilton
2012/03/14 17:32:08
// Version of the SPDY protocol to be used
ramant (doing other things)
2012/03/15 04:36:04
Done.
|
| + int spdy_version_; |
| +}; |
| + |
| +//----------------------------------------------------------------------------- |
| +// All tests are run with two different SPDY versions: SPDY/2 and SPDY/3. |
| +INSTANTIATE_TEST_CASE_P(SpdyProtocolTests, |
| + SpdyProtocolTest, |
| + ::testing::Values(SPDY2, SPDY3)); |
| + |
| // Test our protocol constants |
| -TEST(SpdyProtocolSpdy3Test, ProtocolConstants) { |
| +TEST_P(SpdyProtocolTest, ProtocolConstants) { |
| EXPECT_EQ(8u, SpdyFrame::kHeaderSize); |
| EXPECT_EQ(8u, SpdyDataFrame::size()); |
| EXPECT_EQ(8u, SpdyControlFrame::kHeaderSize); |
| @@ -73,7 +94,7 @@ |
| } |
| // Test some of the protocol helper functions |
| -TEST(SpdyProtocolSpdy3Test, FrameStructs) { |
| +TEST_P(SpdyProtocolTest, FrameStructs) { |
| SpdyFrame frame(SpdyFrame::kHeaderSize); |
| frame.set_length(12345); |
| frame.set_flags(10); |
| @@ -88,14 +109,14 @@ |
| EXPECT_FALSE(frame.is_control_frame()); |
| } |
| -TEST(SpdyProtocolSpdy3Test, DataFrameStructs) { |
| +TEST_P(SpdyProtocolTest, DataFrameStructs) { |
| SpdyDataFrame data_frame; |
| data_frame.set_stream_id(12345); |
| EXPECT_EQ(12345u, data_frame.stream_id()); |
| } |
| -TEST(SpdyProtocolSpdy3Test, ControlFrameStructs) { |
| - SpdyFramer framer(SPDY_VERSION_FOR_TESTS); |
| +TEST_P(SpdyProtocolTest, ControlFrameStructs) { |
| + SpdyFramer framer(spdy_version_); |
| SpdyHeaderBlock headers; |
| scoped_ptr<SpdySynStreamControlFrame> syn_frame( |
| @@ -106,8 +127,7 @@ |
| EXPECT_EQ(123u, syn_frame->stream_id()); |
| EXPECT_EQ(456u, syn_frame->associated_stream_id()); |
| EXPECT_EQ(2u, syn_frame->priority()); |
| - EXPECT_EQ((SPDY_VERSION_FOR_TESTS < 3) ? 2 : 4, |
| - syn_frame->header_block_len()); |
| + EXPECT_EQ((spdy_version_ < 3) ? 2 : 4, syn_frame->header_block_len()); |
|
Ryan Hamilton
2012/03/14 17:32:08
Same comment about have an IsSpdy2() method.
|
| EXPECT_EQ(1u, syn_frame->flags()); |
| syn_frame->set_associated_stream_id(999u); |
| EXPECT_EQ(123u, syn_frame->stream_id()); |
| @@ -119,8 +139,7 @@ |
| EXPECT_TRUE(syn_reply->is_control_frame()); |
| EXPECT_EQ(SYN_REPLY, syn_reply->type()); |
| EXPECT_EQ(123u, syn_reply->stream_id()); |
| - EXPECT_EQ((SPDY_VERSION_FOR_TESTS < 3) ? 2 : 4, |
| - syn_reply->header_block_len()); |
| + EXPECT_EQ((spdy_version_ < 3) ? 2 : 4, syn_reply->header_block_len()); |
| EXPECT_EQ(0, syn_reply->flags()); |
| scoped_ptr<SpdyRstStreamControlFrame> rst_frame( |
| @@ -158,8 +177,7 @@ |
| EXPECT_TRUE(headers_frame->is_control_frame()); |
| EXPECT_EQ(HEADERS, headers_frame->type()); |
| EXPECT_EQ(123u, headers_frame->stream_id()); |
| - EXPECT_EQ((SPDY_VERSION_FOR_TESTS < 3) ? 2 : 4, |
| - headers_frame->header_block_len()); |
| + EXPECT_EQ((spdy_version_ < 3) ? 2 : 4, headers_frame->header_block_len()); |
| EXPECT_EQ(0, headers_frame->flags()); |
| scoped_ptr<SpdyWindowUpdateControlFrame> window_update_frame( |
| @@ -171,7 +189,7 @@ |
| EXPECT_EQ(456u, window_update_frame->delta_window_size()); |
| } |
| -TEST(SpdyProtocolSpdy3Test, TestDataFrame) { |
| +TEST_P(SpdyProtocolTest, TestDataFrame) { |
| SpdyDataFrame frame; |
| // Set the stream ID to various values. |
| @@ -214,8 +232,8 @@ |
| } |
| // Test various types of SETTINGS frames. |
| -TEST(SpdyProtocolSpdy3Test, TestSpdySettingsFrame) { |
| - SpdyFramer framer(SPDY_VERSION_FOR_TESTS); |
| +TEST_P(SpdyProtocolTest, TestSpdySettingsFrame) { |
| + SpdyFramer framer(spdy_version_); |
| // Create a settings frame with no settings. |
| SpdySettings settings; |
| @@ -229,11 +247,11 @@ |
| // We'll add several different ID/Flag combinations and then verify |
| // that they encode and decode properly. |
| SettingsFlagsAndId ids[] = { |
| - SettingsFlagsAndId::FromWireFormat(SPDY_VERSION_FOR_TESTS, 0x00000000), |
| - SettingsFlagsAndId::FromWireFormat(SPDY_VERSION_FOR_TESTS, 0xffffffff), |
| - SettingsFlagsAndId::FromWireFormat(SPDY_VERSION_FOR_TESTS, 0xff000001), |
| - SettingsFlagsAndId::FromWireFormat(SPDY_VERSION_FOR_TESTS, 0xffffffff), |
| - SettingsFlagsAndId::FromWireFormat(SPDY_VERSION_FOR_TESTS, 0x01000002), |
| + SettingsFlagsAndId::FromWireFormat(spdy_version_, 0x00000000), |
| + SettingsFlagsAndId::FromWireFormat(spdy_version_, 0xffffffff), |
| + SettingsFlagsAndId::FromWireFormat(spdy_version_, 0xff000001), |
| + SettingsFlagsAndId::FromWireFormat(spdy_version_, 0xffffffff), |
| + SettingsFlagsAndId::FromWireFormat(spdy_version_, 0x01000002), |
| SettingsFlagsAndId(3, 1) |
| }; |
| @@ -262,7 +280,7 @@ |
| } |
| } |
| -TEST(SpdyProtocolSpdy3Test, HasHeaderBlock) { |
| +TEST_P(SpdyProtocolTest, HasHeaderBlock) { |
| SpdyControlFrame frame(SpdyControlFrame::kHeaderSize); |
| for (SpdyControlType type = SYN_STREAM; |
| type < NUM_CONTROL_FRAME_TYPES; |
| @@ -276,10 +294,18 @@ |
| } |
| } |
| +//----------------------------------------------------------------------------- |
| +// All tests are run with two different SPDY versions: SPDY/2 and SPDY/3. |
| +class SpdyProtocolDeathTest : public SpdyProtocolTest {}; |
| + |
| +INSTANTIATE_TEST_CASE_P(SpdyProtocolDeathTests, |
| + SpdyProtocolDeathTest, |
| + ::testing::Values(SPDY2, SPDY3)); |
| + |
| // Make sure that overflows both die in debug mode, and do not cause problems |
| // in opt mode. Note: The EXPECT_DEBUG_DEATH call does not work on Win32 yet, |
| // so we comment it out. |
| -TEST(SpdyProtocolDeathSpdy3Test, TestDataFrame) { |
| +TEST_P(SpdyProtocolDeathTest, TestDataFrame) { |
| SpdyDataFrame frame; |
| frame.set_stream_id(0); |
| @@ -304,7 +330,7 @@ |
| EXPECT_EQ(0, frame.flags()); |
| } |
| -TEST(SpdyProtocolDeathSpdy3Test, TestSpdyControlFrameStreamId) { |
| +TEST_P(SpdyProtocolDeathTest, TestSpdyControlFrameStreamId) { |
| SpdyControlFrame frame_store(SpdySynStreamControlFrame::size()); |
| memset(frame_store.data(), '1', SpdyControlFrame::kHeaderSize); |
| SpdySynStreamControlFrame* frame = |
| @@ -319,7 +345,7 @@ |
| EXPECT_FALSE(frame->is_control_frame()); |
| } |
| -TEST(SpdyProtocolDeathSpdy3Test, TestSpdyControlFrameVersion) { |
| +TEST_P(SpdyProtocolDeathTest, TestSpdyControlFrameVersion) { |
| const unsigned int kVersionMask = 0x7fff; |
| SpdyControlFrame frame(SpdySynStreamControlFrame::size()); |
| memset(frame.data(), '1', SpdyControlFrame::kHeaderSize); |
| @@ -340,20 +366,20 @@ |
| EXPECT_EQ(SYN_STREAM, frame.type()); |
| } |
| -TEST(SpdyProtocolDeathSpdy3Test, TestSpdyControlFrameType) { |
| +TEST_P(SpdyProtocolDeathTest, TestSpdyControlFrameType) { |
| SpdyControlFrame frame(SpdyControlFrame::kHeaderSize); |
| memset(frame.data(), 255, SpdyControlFrame::kHeaderSize); |
| // type() should be out of bounds. |
| EXPECT_FALSE(frame.AppearsToBeAValidControlFrame()); |
| - frame.set_version(SPDY_VERSION_FOR_TESTS); |
| + frame.set_version(spdy_version_); |
| uint16 version = frame.version(); |
| for (int i = SYN_STREAM; i <= spdy::WINDOW_UPDATE; ++i) { |
| frame.set_type(static_cast<SpdyControlType>(i)); |
| EXPECT_EQ(i, static_cast<int>(frame.type())); |
| - if (i == spdy::NOOP) { |
| + if (spdy_version_ != 2 && i == spdy::NOOP) { |
| // NOOP frames aren't 'valid'. |
| EXPECT_FALSE(frame.AppearsToBeAValidControlFrame()); |
| } else { |
| @@ -365,8 +391,8 @@ |
| } |
| } |
| -TEST(SpdyProtocolDeathSpdy3Test, TestRstStreamStatusBounds) { |
| - SpdyFramer framer(SPDY_VERSION_FOR_TESTS); |
| +TEST_P(SpdyProtocolDeathTest, TestRstStreamStatusBounds) { |
| + SpdyFramer framer(spdy_version_); |
| scoped_ptr<SpdyRstStreamControlFrame> rst_frame; |
| rst_frame.reset(framer.CreateRstStream(123, spdy::PROTOCOL_ERROR)); |