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

Side by Side Diff: net/quic/quartc/quartc_reliable_stream_test.cc

Issue 2324833004: Define Stable API for WebRTC/Quartc (Closed)
Patch Set: Create Quartc API Created 4 years, 3 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
OLDNEW
(Empty)
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "net/quic/quartc/quartc_reliable_stream.h"
6
7 #include "base/threading/thread_task_runner_handle.h"
8 #include "net/quic/core/quic_session.h"
9 #include "net/quic/quartc/quartc_alarm_factory.h"
10 #include "net/quic/quartc/quartc_connection_helper.h"
11 #include "net/quic/quartc/quartc_reliable_stream_interface.h"
12 #include "testing/gtest/include/gtest/gtest.h"
13
14 namespace net {
15 namespace test {
16 namespace {
17
18 static const SpdyPriority kDefaultPriority = 3;
19 static const QuicStreamId kStreamId = 5;
20 static const QuartcReliableStreamInterface::WriteParameters kDefaultParam;
21
22 // MockQuicSession that does not create streams and writes data from
23 // ReliableQuicStream to a string.
24 class MockQuicSession : public QuicSession {
25 public:
26 MockQuicSession(QuicConnection* connection,
27 const QuicConfig& config,
28 std::string* write_buffer)
29 : QuicSession(connection, config), write_buffer_(write_buffer) {}
30
31 // Writes outgoing data from ReliableQuicStream to a string.
32 QuicConsumedData WritevData(
33 ReliableQuicStream* stream,
34 QuicStreamId id,
35 QuicIOVector iovector,
36 QuicStreamOffset offset,
37 bool fin,
38 QuicAckListenerInterface* ack_notifier_delegate) override {
39 if (!writable_) {
40 return QuicConsumedData(0, false);
41 }
42
43 const char* data = reinterpret_cast<const char*>(iovector.iov->iov_base);
44 size_t len = iovector.total_length;
45 write_buffer_->append(data, len);
46 return QuicConsumedData(len, false);
skvlad-chromium 2016/09/22 01:54:25 shouldn't this return QuicConsumedData(len, fin)?
zhihuang1 2016/09/22 18:53:52 You're right.
47 }
48
49 QuartcReliableStream* CreateIncomingDynamicStream(QuicStreamId id) override {
50 return nullptr;
51 }
52
53 QuartcReliableStream* CreateOutgoingDynamicStream(
54 SpdyPriority priority) override {
55 return nullptr;
56 }
57
58 QuicCryptoStream* GetCryptoStream() override { return nullptr; }
59
60 // Called by ReliableQuicStream when they want to close stream.
61 void SendRstStream(QuicStreamId id,
62 QuicRstStreamErrorCode error,
63 QuicStreamOffset bytes_written) override {}
64
65 // Sets whether data is written to buffer, or else if this is write blocked.
66 void set_writable(bool writable) { writable_ = writable; }
67
68 // Tracks whether the stream is write blocked and its priority.
69 void RegisterReliableStream(QuicStreamId stream_id, SpdyPriority priority) {
70 write_blocked_streams()->RegisterStream(stream_id, priority);
71 }
72
73 // The session take ownership of the stream.
74 void ActivateReliableStream(ReliableQuicStream* stream) {
75 ActivateStream(stream);
76 }
77
78 private:
79 // Stores written data from ReliableQuicStreamAdapter.
80 std::string* write_buffer_;
81 // Whether data is written to write_buffer_.
82 bool writable_ = true;
83 };
84
85 // Packet writer that does nothing. This is required for QuicConnection but
86 // isn't used for writing data.
87 class DummyPacketWriter : public QuicPacketWriter {
88 public:
89 DummyPacketWriter() {}
90
91 // QuicPacketWriter overrides.
92 WriteResult WritePacket(const char* buffer,
93 size_t buf_len,
94 const IPAddress& self_address,
95 const IPEndPoint& peer_address,
96 PerPacketOptions* options) override {
97 return WriteResult(WRITE_STATUS_ERROR, 0);
98 }
99
100 bool IsWriteBlockedDataBuffered() const override { return false; }
101
102 bool IsWriteBlocked() const override { return false; };
103
104 void SetWritable() override {}
105
106 QuicByteCount GetMaxPacketSize(
107 const IPEndPoint& peer_address) const override {
108 return 0;
109 }
110 };
111
112 class MockQuartcReliableStreamObserver : public QuartcReliableStream::Observer {
113 public:
114 MockQuartcReliableStreamObserver(int id, std::string& read_buffer)
115 : id_(id), read_buffer_(read_buffer) {}
116
117 void OnBufferedAmountChanged(QuartcReliableStreamInterface* stream) override {
118 queued_bytes_amount_ = stream->buffered_amount();
119 }
120
121 void OnReceived(QuartcReliableStreamInterface* stream,
122 const char* data,
123 size_t size) override {
124 EXPECT_EQ(id_, stream->stream_id());
125 read_buffer_.append(data, size);
126 }
127
128 void OnClose(QuartcReliableStreamInterface* stream, int error_code) override {
129 closed_ = true;
130 }
131
132 bool closed() { return closed_; }
133
134 int queued_bytes_amount() { return queued_bytes_amount_; }
135
136 protected:
137 uint32_t id_;
138 // Data read by the ReliableQuicStream.
139 std::string& read_buffer_;
140 // Whether the ReliableQuicStream is closed.
141 bool closed_ = false;
142 int queued_bytes_amount_ = -1;
143 };
144
145 class QuartcReliableStreamTest : public ::testing::Test {
146 public:
147 void CreateReliableQuicStream() {
148 // Arbitrary values for QuicConnection.
149 QuicConnectionHelperInterface* quic_helper = new QuartcConnectionHelper;
150 Perspective perspective = Perspective::IS_SERVER;
151 IPAddress ip(0, 0, 0, 0);
152 bool owns_writer = true;
153 QuartcAlarmFactory* alarm_factory = new QuartcAlarmFactory(
skvlad-chromium 2016/09/22 01:54:25 Shouldn't the factory and the connection be owned
zhihuang1 2016/09/22 18:53:52 Yes. The connection will not own the factory. Done
154 base::ThreadTaskRunnerHandle::Get().get(), quic_helper->GetClock());
155
156 QuicConnection* connection =
157 new QuicConnection(0, IPEndPoint(ip, 0), quic_helper, alarm_factory,
158 new DummyPacketWriter(), owns_writer, perspective,
159 AllSupportedVersions());
160
161 session_.reset(
162 new MockQuicSession(connection, QuicConfig(), &write_buffer_));
163 mock_stream_observer_.reset(
164 new MockQuartcReliableStreamObserver(kStreamId, read_buffer_));
165 stream_ = new QuartcReliableStream(kStreamId, session_.get());
166 stream_->SetObserver(mock_stream_observer_.get());
167 session_->RegisterReliableStream(stream_->stream_id(), kDefaultPriority);
168 session_->ActivateReliableStream(stream_);
169 }
170
171 protected:
172 QuartcReliableStream* stream_ = nullptr;
173 std::unique_ptr<MockQuartcReliableStreamObserver> mock_stream_observer_;
174 std::unique_ptr<MockQuicSession> session_;
175 // Data written by the ReliableQuicStreamAdapterTest.
176 std::string write_buffer_;
177 // Data read by the ReliableQuicStreamAdapterTest.
178 std::string read_buffer_;
179 };
180
181 // Write an entire string.
182 TEST_F(QuartcReliableStreamTest, WriteDataWhole) {
183 CreateReliableQuicStream();
184 stream_->Write("Foo bar", 7, kDefaultParam);
185 EXPECT_EQ("Foo bar", write_buffer_);
186 }
187
188 // Write part of a string.
189 TEST_F(QuartcReliableStreamTest, WriteDataPartial) {
190 CreateReliableQuicStream();
191 stream_->Write("Foo bar", 5, kDefaultParam);
192 EXPECT_EQ("Foo b", write_buffer_);
193 }
194
195 // Test that strings are buffered correctly.
196 TEST_F(QuartcReliableStreamTest, BufferData) {
197 CreateReliableQuicStream();
198
199 session_->set_writable(false);
200 stream_->Write("Foo bar", 7, kDefaultParam);
201 // The data will be buffered.
202 EXPECT_EQ(0ul, write_buffer_.size());
203 EXPECT_TRUE(stream_->HasBufferedData());
204 EXPECT_EQ(-1, mock_stream_observer_->queued_bytes_amount());
205 // The session is writable and the buffered data amount will change.
206 session_->set_writable(true);
207 stream_->OnCanWrite();
208 EXPECT_EQ(0, mock_stream_observer_->queued_bytes_amount());
209 EXPECT_FALSE(stream_->HasBufferedData());
210 EXPECT_EQ("Foo bar", write_buffer_);
211
212 stream_->Write("xyzzy", 5, kDefaultParam);
213 EXPECT_EQ("Foo barxyzzy", write_buffer_);
214 }
215
216 // Read an entire string.
217 TEST_F(QuartcReliableStreamTest, ReadDataWhole) {
218 CreateReliableQuicStream();
219 QuicStreamFrame frame(kStreamId, false, 0, "Hello, World!");
220 stream_->OnStreamFrame(frame);
221
222 EXPECT_EQ("Hello, World!", read_buffer_);
223 }
224
225 // Read part of a string.
226 TEST_F(QuartcReliableStreamTest, ReadDataPartial) {
227 CreateReliableQuicStream();
228 QuicStreamFrame frame(kStreamId, false, 0, "Hello, World!");
229 frame.data_length = 5;
230 stream_->OnStreamFrame(frame);
231
232 EXPECT_EQ("Hello", read_buffer_);
233 }
234
235 // Test that closing the stream results in a callback.
236 TEST_F(QuartcReliableStreamTest, CloseStream) {
237 CreateReliableQuicStream();
238 EXPECT_FALSE(mock_stream_observer_->closed());
239 stream_->OnClose();
240 EXPECT_TRUE(mock_stream_observer_->closed());
241 }
242
243 } // namespace
244 } // namespace test
245 } // namespace net
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698