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

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

Issue 1852423004: Implement SpdySerializedFrame move semantics. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 4 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
« no previous file with comments | « net/spdy/spdy_frame_builder.h ('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
(...skipping 11 matching lines...) Expand all
22 INSTANTIATE_TEST_CASE_P(SpdyFrameBuilderTests, 22 INSTANTIATE_TEST_CASE_P(SpdyFrameBuilderTests,
23 SpdyFrameBuilderTest, 23 SpdyFrameBuilderTest,
24 ::testing::Values(SPDY3, HTTP2)); 24 ::testing::Values(SPDY3, HTTP2));
25 25
26 TEST_P(SpdyFrameBuilderTest, GetWritableBuffer) { 26 TEST_P(SpdyFrameBuilderTest, GetWritableBuffer) {
27 const size_t builder_size = 10; 27 const size_t builder_size = 10;
28 SpdyFrameBuilder builder(builder_size, spdy_version_); 28 SpdyFrameBuilder builder(builder_size, spdy_version_);
29 char* writable_buffer = builder.GetWritableBuffer(builder_size); 29 char* writable_buffer = builder.GetWritableBuffer(builder_size);
30 memset(writable_buffer, ~1, builder_size); 30 memset(writable_buffer, ~1, builder_size);
31 EXPECT_TRUE(builder.Seek(builder_size)); 31 EXPECT_TRUE(builder.Seek(builder_size));
32 scoped_ptr<SpdyFrame> frame(builder.take()); 32 SpdySerializedFrame frame(builder.take());
33 char expected[builder_size]; 33 char expected[builder_size];
34 memset(expected, ~1, builder_size); 34 memset(expected, ~1, builder_size);
35 EXPECT_EQ(base::StringPiece(expected, builder_size), 35 EXPECT_EQ(base::StringPiece(expected, builder_size),
36 base::StringPiece(frame->data(), builder_size)); 36 base::StringPiece(frame.data(), builder_size));
37 } 37 }
38 38
39 TEST_P(SpdyFrameBuilderTest, RewriteLength) { 39 TEST_P(SpdyFrameBuilderTest, RewriteLength) {
40 // Create an empty SETTINGS frame both via framer and manually via builder. 40 // Create an empty SETTINGS frame both via framer and manually via builder.
41 // The one created via builder is initially given the incorrect length, but 41 // The one created via builder is initially given the incorrect length, but
42 // then is corrected via RewriteLength(). 42 // then is corrected via RewriteLength().
43 SpdyFramer framer(spdy_version_); 43 SpdyFramer framer(spdy_version_);
44 SpdySettingsIR settings_ir; 44 SpdySettingsIR settings_ir;
45 scoped_ptr<SpdyFrame> expected(framer.SerializeSettings(settings_ir)); 45 SpdySerializedFrame expected(framer.SerializeSettings(settings_ir));
46 SpdyFrameBuilder builder(expected->size() + 1, spdy_version_); 46 SpdyFrameBuilder builder(expected.size() + 1, spdy_version_);
47 if (spdy_version_ == SPDY3) { 47 if (spdy_version_ == SPDY3) {
48 builder.WriteControlFrameHeader(framer, SETTINGS, 0); 48 builder.WriteControlFrameHeader(framer, SETTINGS, 0);
49 builder.WriteUInt32(0); // Write the number of settings. 49 builder.WriteUInt32(0); // Write the number of settings.
50 } else { 50 } else {
51 builder.BeginNewFrame(framer, SETTINGS, 0, 0); 51 builder.BeginNewFrame(framer, SETTINGS, 0, 0);
52 } 52 }
53 EXPECT_TRUE(builder.GetWritableBuffer(1) != NULL); 53 EXPECT_TRUE(builder.GetWritableBuffer(1) != NULL);
54 builder.RewriteLength(framer); 54 builder.RewriteLength(framer);
55 scoped_ptr<SpdyFrame> built(builder.take()); 55 SpdySerializedFrame built(builder.take());
56 EXPECT_EQ(base::StringPiece(expected->data(), expected->size()), 56 EXPECT_EQ(base::StringPiece(expected.data(), expected.size()),
57 base::StringPiece(built->data(), expected->size())); 57 base::StringPiece(built.data(), expected.size()));
58 } 58 }
59 59
60 TEST_P(SpdyFrameBuilderTest, OverwriteFlags) { 60 TEST_P(SpdyFrameBuilderTest, OverwriteFlags) {
61 // Create a HEADERS frame both via framer and manually via builder with 61 // Create a HEADERS frame both via framer and manually via builder with
62 // different flags set, then make them match using OverwriteFlags(). 62 // different flags set, then make them match using OverwriteFlags().
63 SpdyFramer framer(spdy_version_); 63 SpdyFramer framer(spdy_version_);
64 if (spdy_version_ == SPDY3) { 64 if (spdy_version_ == SPDY3) {
65 return; 65 return;
66 } 66 }
67 SpdyHeadersIR headers_ir(1); 67 SpdyHeadersIR headers_ir(1);
68 scoped_ptr<SpdyFrame> expected(framer.SerializeHeaders(headers_ir)); 68 SpdySerializedFrame expected(framer.SerializeHeaders(headers_ir));
69 SpdyFrameBuilder builder(expected->size(), spdy_version_); 69 SpdyFrameBuilder builder(expected.size(), spdy_version_);
70 builder.BeginNewFrame(framer, HEADERS, 0, 1); 70 builder.BeginNewFrame(framer, HEADERS, 0, 1);
71 builder.OverwriteFlags(framer, HEADERS_FLAG_END_HEADERS); 71 builder.OverwriteFlags(framer, HEADERS_FLAG_END_HEADERS);
72 scoped_ptr<SpdyFrame> built(builder.take()); 72 SpdySerializedFrame built(builder.take());
73 EXPECT_EQ(base::StringPiece(expected->data(), expected->size()), 73 EXPECT_EQ(base::StringPiece(expected.data(), expected.size()),
74 base::StringPiece(built->data(), built->size())); 74 base::StringPiece(built.data(), built.size()));
75 } 75 }
76 76
77 } // namespace net 77 } // namespace net
OLDNEW
« no previous file with comments | « net/spdy/spdy_frame_builder.h ('k') | net/spdy/spdy_framer.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698