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

Side by Side Diff: courgette/streams_unittest.cc

Issue 149597: Code changes to get the code to compile under GCC.... (Closed) Base URL: svn://chrome-svn/chrome/trunk/src/
Patch Set: '' Created 11 years, 5 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 | « courgette/streams.cc ('k') | courgette/third_party/bsdiff_create.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Property Changes:
Name: svn:eol-style
+ LF
OLDNEW
1 // Copyright (c) 2009 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2009 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 "courgette/streams.h" 5 #include "courgette/streams.h"
6 6
7 #include <vector>
8
7 #include "testing/gtest/include/gtest/gtest.h" 9 #include "testing/gtest/include/gtest/gtest.h"
8 10
9 TEST(StreamsTest, SimpleWriteRead) { 11 TEST(StreamsTest, SimpleWriteRead) {
10 const unsigned int kValue1 = 12345; 12 const unsigned int kValue1 = 12345;
11 courgette::SinkStream sink; 13 courgette::SinkStream sink;
12 14
13 sink.WriteVarint32(kValue1); 15 sink.WriteVarint32(kValue1);
14 16
15 const uint8* sink_buffer = sink.Buffer(); 17 const uint8* sink_buffer = sink.Buffer();
16 size_t length = sink.Length(); 18 size_t length = sink.Length();
17 19
18 courgette::SourceStream source; 20 courgette::SourceStream source;
19 source.Init(sink_buffer, length); 21 source.Init(sink_buffer, length);
20 22
21 unsigned int value; 23 unsigned int value;
22 bool can_read = source.ReadVarint32(&value); 24 bool can_read = source.ReadVarint32(&value);
23 EXPECT_EQ(true, can_read); 25 EXPECT_EQ(true, can_read);
24 EXPECT_EQ(kValue1, value); 26 EXPECT_EQ(kValue1, value);
25 EXPECT_EQ(0, source.Remaining()); 27 EXPECT_EQ(0U, source.Remaining());
26 } 28 }
27 29
28 TEST(StreamsTest, SimpleWriteRead2) { 30 TEST(StreamsTest, SimpleWriteRead2) {
29 courgette::SinkStream sink; 31 courgette::SinkStream sink;
30 32
31 sink.Write("Hello", 5); 33 sink.Write("Hello", 5);
32 34
33 const uint8* sink_buffer = sink.Buffer(); 35 const uint8* sink_buffer = sink.Buffer();
34 size_t sink_length = sink.Length(); 36 size_t sink_length = sink.Length();
35 37
36 courgette::SourceStream source; 38 courgette::SourceStream source;
37 source.Init(sink_buffer, sink_length); 39 source.Init(sink_buffer, sink_length);
38 40
39 char text[10] = {0}; 41 char text[10] = {0};
40 bool can_read = source.Read(text, 5); 42 bool can_read = source.Read(text, 5);
41 EXPECT_EQ(true, can_read); 43 EXPECT_EQ(true, can_read);
42 EXPECT_EQ(0, memcmp("Hello", text, 5)); 44 EXPECT_EQ(0, memcmp("Hello", text, 5));
43 EXPECT_EQ(0, source.Remaining()); 45 EXPECT_EQ(0U, source.Remaining());
44 } 46 }
45 47
46 TEST(StreamsTest, StreamSetWriteRead) { 48 TEST(StreamsTest, StreamSetWriteRead) {
47 courgette::SinkStreamSet out; 49 courgette::SinkStreamSet out;
48 out.Init(4); 50 out.Init(4);
49 51
50 const unsigned int kValue1 = 12345; 52 const unsigned int kValue1 = 12345;
51 53
52 out.stream(3)->WriteVarint32(kValue1); 54 out.stream(3)->WriteVarint32(kValue1);
53 55
54 courgette::SinkStream collected; 56 courgette::SinkStream collected;
55 57
56 out.CopyTo(&collected); 58 out.CopyTo(&collected);
57 59
58 const uint8* collected_buffer = collected.Buffer(); 60 const uint8* collected_buffer = collected.Buffer();
59 size_t collected_length = collected.Length(); 61 size_t collected_length = collected.Length();
60 62
61 courgette::SourceStreamSet in; 63 courgette::SourceStreamSet in;
62 bool can_init = in.Init(collected_buffer, collected_length); 64 bool can_init = in.Init(collected_buffer, collected_length);
63 EXPECT_EQ(true, can_init); 65 EXPECT_EQ(true, can_init);
64 66
65 uint32 value; 67 uint32 value;
66 bool can_read = in.stream(3)->ReadVarint32(&value); 68 bool can_read = in.stream(3)->ReadVarint32(&value);
67 EXPECT_EQ(true, can_read); 69 EXPECT_EQ(true, can_read);
68 EXPECT_EQ(kValue1, value); 70 EXPECT_EQ(kValue1, value);
69 EXPECT_EQ(0, in.stream(3)->Remaining()); 71 EXPECT_EQ(0U, in.stream(3)->Remaining());
70 EXPECT_EQ(0, in.stream(2)->Remaining()); 72 EXPECT_EQ(0U, in.stream(2)->Remaining());
71 } 73 }
72 74
73 TEST(StreamsTest, StreamSetWriteRead2) { 75 TEST(StreamsTest, StreamSetWriteRead2) {
74 const size_t kNumberOfStreams = 4; 76 const size_t kNumberOfStreams = 4;
75 const unsigned int kEnd = ~0U; 77 const unsigned int kEnd = ~0U;
76 78
77 courgette::SinkStreamSet out; 79 courgette::SinkStreamSet out;
78 out.Init(kNumberOfStreams); 80 out.Init(kNumberOfStreams);
79 81
80 static const unsigned int data[] = { 82 static const unsigned int data[] = {
(...skipping 21 matching lines...) Expand all
102 for (size_t i = 0; data[i] != kEnd; i += 2) { 104 for (size_t i = 0; data[i] != kEnd; i += 2) {
103 size_t id = data[i]; 105 size_t id = data[i];
104 size_t datum = data[i + 1]; 106 size_t datum = data[i + 1];
105 uint32 value = 77; 107 uint32 value = 77;
106 bool can_read = in.stream(id)->ReadVarint32(&value); 108 bool can_read = in.stream(id)->ReadVarint32(&value);
107 EXPECT_EQ(true, can_read); 109 EXPECT_EQ(true, can_read);
108 EXPECT_EQ(datum, value); 110 EXPECT_EQ(datum, value);
109 } 111 }
110 112
111 for (size_t i = 0; i < kNumberOfStreams; ++i) { 113 for (size_t i = 0; i < kNumberOfStreams; ++i) {
112 EXPECT_EQ(0, in.stream(i)->Remaining()); 114 EXPECT_EQ(0U, in.stream(i)->Remaining());
113 } 115 }
114 } 116 }
115 117
116 TEST(StreamsTest, SignedVarint32) { 118 TEST(StreamsTest, SignedVarint32) {
117 courgette::SinkStream out; 119 courgette::SinkStream out;
118 120
119 static const int32 data[] = { 121 static const int32 data[] = {
120 0, 64, 128, 8192, 16384, 122 0, 64, 128, 8192, 16384,
121 1 << 20, 1 << 21, 1 << 22, 123 1 << 20, 1 << 21, 1 << 22,
122 1 << 27, 1 << 28, 124 1 << 27, 1 << 28,
(...skipping 11 matching lines...) Expand all
134 } 136 }
135 } 137 }
136 138
137 courgette::SourceStream in; 139 courgette::SourceStream in;
138 in.Init(out); 140 in.Init(out);
139 141
140 for (size_t i = 0; i < values.size(); ++i) { 142 for (size_t i = 0; i < values.size(); ++i) {
141 int written_value = values[i]; 143 int written_value = values[i];
142 int32 datum; 144 int32 datum;
143 bool can_read = in.ReadVarint32Signed(&datum); 145 bool can_read = in.ReadVarint32Signed(&datum);
146 EXPECT_EQ(true, can_read);
144 EXPECT_EQ(written_value, datum); 147 EXPECT_EQ(written_value, datum);
145 } 148 }
146 149
147 EXPECT_EQ(true, in.Empty()); 150 EXPECT_EQ(true, in.Empty());
148 } 151 }
149 152
150 TEST(StreamsTest, StreamSetReadWrite) { 153 TEST(StreamsTest, StreamSetReadWrite) {
151 courgette::SinkStreamSet out; 154 courgette::SinkStreamSet out;
152 155
153 { // Local scope for temporary stream sets. 156 { // Local scope for temporary stream sets.
(...skipping 26 matching lines...) Expand all
180 183
181 courgette::SourceStreamSet subset3; 184 courgette::SourceStreamSet subset3;
182 bool can_read_3 = in.ReadSet(&subset3); 185 bool can_read_3 = in.ReadSet(&subset3);
183 EXPECT_EQ(false, can_read_3); 186 EXPECT_EQ(false, can_read_3);
184 187
185 EXPECT_EQ(false, subset1.Empty()); 188 EXPECT_EQ(false, subset1.Empty());
186 EXPECT_EQ(false, subset1.Empty()); 189 EXPECT_EQ(false, subset1.Empty());
187 190
188 uint32 datum; 191 uint32 datum;
189 EXPECT_EQ(true, subset1.stream(3)->ReadVarint32(&datum)); 192 EXPECT_EQ(true, subset1.stream(3)->ReadVarint32(&datum));
190 EXPECT_EQ(30000, datum); 193 EXPECT_EQ(30000U, datum);
191 EXPECT_EQ(true, subset1.stream(5)->ReadVarint32(&datum)); 194 EXPECT_EQ(true, subset1.stream(5)->ReadVarint32(&datum));
192 EXPECT_EQ(50000, datum); 195 EXPECT_EQ(50000U, datum);
193 EXPECT_EQ(true, subset1.Empty()); 196 EXPECT_EQ(true, subset1.Empty());
194 197
195 EXPECT_EQ(true, subset2.stream(2)->ReadVarint32(&datum)); 198 EXPECT_EQ(true, subset2.stream(2)->ReadVarint32(&datum));
196 EXPECT_EQ(20000, datum); 199 EXPECT_EQ(20000U, datum);
197 EXPECT_EQ(true, subset2.stream(6)->ReadVarint32(&datum)); 200 EXPECT_EQ(true, subset2.stream(6)->ReadVarint32(&datum));
198 EXPECT_EQ(60000, datum); 201 EXPECT_EQ(60000U, datum);
199 EXPECT_EQ(true, subset2.Empty()); 202 EXPECT_EQ(true, subset2.Empty());
200 } 203 }
OLDNEW
« no previous file with comments | « courgette/streams.cc ('k') | courgette/third_party/bsdiff_create.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698