Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(353)

Side by Side Diff: net/spdy/spdy_frame_builder_test.cc

Issue 246013002: SPDY: Headers & Push-Promise now use Continuations (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Rebase only Created 6 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « net/spdy/spdy_frame_builder.cc ('k') | net/spdy/spdy_framer.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "net/spdy/spdy_frame_builder.h" 5 #include "net/spdy/spdy_frame_builder.h"
6 6
7 #include "net/spdy/spdy_framer.h" 7 #include "net/spdy/spdy_framer.h"
8 #include "net/spdy/spdy_protocol.h" 8 #include "net/spdy/spdy_protocol.h"
9 #include "testing/platform_test.h" 9 #include "testing/platform_test.h"
10 10
11 namespace net { 11 namespace net {
12 12
13 TEST(SpdyFrameBuilderTestVersionAgnostic, GetWritableBuffer) {
14 const size_t builder_size = 10;
15 SpdyFrameBuilder builder(builder_size);
16 char* writable_buffer = builder.GetWritableBuffer(builder_size);
17 memset(writable_buffer, ~1, builder_size);
18 EXPECT_TRUE(builder.Seek(builder_size));
19 scoped_ptr<SpdyFrame> frame(builder.take());
20 char expected[builder_size];
21 memset(expected, ~1, builder_size);
22 EXPECT_EQ(base::StringPiece(expected, builder_size),
23 base::StringPiece(frame->data(), builder_size));
24 }
25
26 class SpdyFrameBuilderTest : public ::testing::TestWithParam<SpdyMajorVersion> { 13 class SpdyFrameBuilderTest : public ::testing::TestWithParam<SpdyMajorVersion> {
27 protected: 14 protected:
28 virtual void SetUp() { 15 virtual void SetUp() {
29 spdy_version_ = GetParam(); 16 spdy_version_ = GetParam();
30 } 17 }
31 18
32 // Major version of SPDY protocol to be used. 19 // Major version of SPDY protocol to be used.
33 SpdyMajorVersion spdy_version_; 20 SpdyMajorVersion spdy_version_;
34 }; 21 };
35 22
36 // All tests are run with two different SPDY versions: SPDY/2 and SPDY/3. 23 // All tests are run with two different SPDY versions: SPDY/2 and SPDY/3.
37 INSTANTIATE_TEST_CASE_P(SpdyFrameBuilderTests, 24 INSTANTIATE_TEST_CASE_P(SpdyFrameBuilderTests,
38 SpdyFrameBuilderTest, 25 SpdyFrameBuilderTest,
39 ::testing::Values(SPDY2, SPDY3, SPDY4)); 26 ::testing::Values(SPDY2, SPDY3, SPDY4));
40 27
28 TEST_P(SpdyFrameBuilderTest, GetWritableBuffer) {
29 const size_t builder_size = 10;
30 SpdyFrameBuilder builder(builder_size, spdy_version_);
31 char* writable_buffer = builder.GetWritableBuffer(builder_size);
32 memset(writable_buffer, ~1, builder_size);
33 EXPECT_TRUE(builder.Seek(builder_size));
34 scoped_ptr<SpdyFrame> frame(builder.take());
35 char expected[builder_size];
36 memset(expected, ~1, builder_size);
37 EXPECT_EQ(base::StringPiece(expected, builder_size),
38 base::StringPiece(frame->data(), builder_size));
39 }
40
41 TEST_P(SpdyFrameBuilderTest, RewriteLength) { 41 TEST_P(SpdyFrameBuilderTest, RewriteLength) {
42 // Create an empty SETTINGS frame both via framer and manually via builder. 42 // Create an empty SETTINGS frame both via framer and manually via builder.
43 // The one created via builder is initially given the incorrect length, but 43 // The one created via builder is initially given the incorrect length, but
44 // then is corrected via RewriteLength(). 44 // then is corrected via RewriteLength().
45 SpdyFramer framer(spdy_version_); 45 SpdyFramer framer(spdy_version_);
46 SpdySettingsIR settings_ir; 46 SpdySettingsIR settings_ir;
47 scoped_ptr<SpdyFrame> expected(framer.SerializeSettings(settings_ir)); 47 scoped_ptr<SpdyFrame> expected(framer.SerializeSettings(settings_ir));
48 SpdyFrameBuilder builder(expected->size() + 1); 48 SpdyFrameBuilder builder(expected->size() + 1, spdy_version_);
49 if (spdy_version_ < 4) { 49 if (spdy_version_ < 4) {
50 builder.WriteControlFrameHeader(framer, SETTINGS, 0); 50 builder.WriteControlFrameHeader(framer, SETTINGS, 0);
51 builder.WriteUInt32(0); // Write the number of settings. 51 builder.WriteUInt32(0); // Write the number of settings.
52 } else { 52 } else {
53 builder.WriteFramePrefix(framer, SETTINGS, 0, 0); 53 builder.BeginNewFrame(framer, SETTINGS, 0, 0);
54 } 54 }
55 EXPECT_TRUE(builder.GetWritableBuffer(1) != NULL); 55 EXPECT_TRUE(builder.GetWritableBuffer(1) != NULL);
56 builder.RewriteLength(framer); 56 builder.RewriteLength(framer);
57 scoped_ptr<SpdyFrame> built(builder.take()); 57 scoped_ptr<SpdyFrame> built(builder.take());
58 EXPECT_EQ(base::StringPiece(expected->data(), expected->size()), 58 EXPECT_EQ(base::StringPiece(expected->data(), expected->size()),
59 base::StringPiece(built->data(), expected->size())); 59 base::StringPiece(built->data(), expected->size()));
60 } 60 }
61 61
62 TEST_P(SpdyFrameBuilderTest, OverwriteFlags) { 62 TEST_P(SpdyFrameBuilderTest, OverwriteFlags) {
63 // Create a HEADERS frame both via framer and manually via builder with 63 // Create a HEADERS frame both via framer and manually via builder with
64 // different flags set, then make them match using OverwriteFlags(). 64 // different flags set, then make them match using OverwriteFlags().
65 SpdyFramer framer(spdy_version_); 65 SpdyFramer framer(spdy_version_);
66 if (spdy_version_ < SPDY4) { 66 if (spdy_version_ < SPDY4) {
67 return; 67 return;
68 } 68 }
69 SpdyHeadersIR headers_ir(1); 69 SpdyHeadersIR headers_ir(1);
70 headers_ir.set_end_headers(false); 70 headers_ir.set_end_headers(false);
71 scoped_ptr<SpdyFrame> expected(framer.SerializeHeaders(headers_ir)); 71 scoped_ptr<SpdyFrame> expected(framer.SerializeHeaders(headers_ir));
72 SpdyFrameBuilder builder(expected->size()); 72 SpdyFrameBuilder builder(expected->size(), spdy_version_);
73 builder.WriteFramePrefix(framer, HEADERS, HEADERS_FLAG_END_HEADERS, 1); 73 builder.BeginNewFrame(framer, HEADERS, HEADERS_FLAG_END_HEADERS, 1);
74 builder.OverwriteFlags(framer, 0); 74 builder.OverwriteFlags(framer, 0);
75 scoped_ptr<SpdyFrame> built(builder.take()); 75 scoped_ptr<SpdyFrame> built(builder.take());
76 EXPECT_EQ(base::StringPiece(expected->data(), expected->size()), 76 EXPECT_EQ(base::StringPiece(expected->data(), expected->size()),
77 base::StringPiece(built->data(), built->size())); 77 base::StringPiece(built->data(), built->size()));
78 } 78 }
79 79
80 } // namespace net 80 } // namespace net
OLDNEW
« no previous file with comments | « net/spdy/spdy_frame_builder.cc ('k') | net/spdy/spdy_framer.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698