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

Side by Side Diff: net/filter/mock_source_stream.cc

Issue 2251853002: Add net::SourceStream and net::FilterSourceStream (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: self review Created 4 years, 4 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 2015 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/filter/mock_source_stream.h"
6
7 #include "base/logging.h"
8 #include "net/base/io_buffer.h"
9
10 namespace net {
11
12 MockSourceStream::MockSourceStream()
13 : SourceStream(SourceStream::TYPE_NONE),
14 awaiting_completion_(false),
15 dest_buffer_(nullptr),
16 dest_buffer_size_(0) {}
17
18 MockSourceStream::~MockSourceStream() {
19 DCHECK(results_.empty());
20 }
21
22 int MockSourceStream::Read(IOBuffer* dest_buffer,
23 int buffer_size,
24 const CompletionCallback& callback) {
25 DCHECK(!awaiting_completion_);
26 DCHECK(!results_.empty());
Randy Smith (Not in Mondays) 2016/08/22 22:37:16 I'd vote gently against these DCHECKs. My rule of
mmenke 2016/08/22 22:46:42 I tend to prefer this, just because if something u
xunjieli 2016/08/29 16:25:29 Acknowledged. Thanks for the suggestions and the d
27
28 if (results_.empty())
29 return ERR_UNEXPECTED;
30
31 QueuedResult r = results_.front();
32 DCHECK_GE(buffer_size, r.len);
Randy Smith (Not in Mondays) 2016/08/22 22:37:17 Same comment here--this could be the result of an
xunjieli 2016/08/29 16:25:29 Acknowledged.
33 if (r.mode == ASYNC) {
34 awaiting_completion_ = true;
35 dest_buffer_ = dest_buffer;
36 dest_buffer_size_ = buffer_size;
37 callback_ = callback;
38 return ERR_IO_PENDING;
39 }
40
41 results_.pop();
42 memcpy(dest_buffer->data(), r.data, r.len);
43 return r.error == OK ? r.len : r.error;
44 }
45
46 std::string MockSourceStream::OrderedTypeStringList() const {
47 return "";
48 }
49
50 MockSourceStream::QueuedResult::QueuedResult(const char* data,
51 int len,
52 Error error,
53 Mode mode)
54 : data(data), len(len), error(error), mode(mode) {}
55
56 void MockSourceStream::AddReadResult(const char* data,
57 int len,
58 Error error,
59 Mode mode) {
60 QueuedResult result(data, len, error, mode);
61 results_.push(result);
62 }
63
64 void MockSourceStream::CompleteNextRead() {
65 DCHECK(awaiting_completion_);
Randy Smith (Not in Mondays) 2016/08/22 22:37:16 And here, unless its part of the contract that the
xunjieli 2016/08/29 16:25:29 Done. I added documentation in the header file.
66
67 awaiting_completion_ = false;
68 QueuedResult r = results_.front();
69 DCHECK_EQ(ASYNC, r.mode);
70 results_.pop();
71 DCHECK_GE(dest_buffer_size_, r.len);
72 memcpy(dest_buffer_->data(), r.data, r.len);
73 dest_buffer_ = nullptr;
74 callback_.Run(r.error == OK ? r.len : r.error);
75 }
76
77 } // namespace net
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698