Chromium Code Reviews| Index: net/filter/mock_source_stream.cc |
| diff --git a/net/filter/mock_source_stream.cc b/net/filter/mock_source_stream.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..9811eb52cda84096c8cd7ece254e1a4a0b6342e8 |
| --- /dev/null |
| +++ b/net/filter/mock_source_stream.cc |
| @@ -0,0 +1,77 @@ |
| +// Copyright 2015 The Chromium Authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +#include "net/filter/mock_source_stream.h" |
| + |
| +#include "base/logging.h" |
| +#include "net/base/io_buffer.h" |
| + |
| +namespace net { |
| + |
| +MockSourceStream::MockSourceStream() |
| + : SourceStream(SourceStream::TYPE_NONE), |
| + awaiting_completion_(false), |
| + dest_buffer_(nullptr), |
| + dest_buffer_size_(0) {} |
| + |
| +MockSourceStream::~MockSourceStream() { |
| + DCHECK(results_.empty()); |
| +} |
| + |
| +int MockSourceStream::Read(IOBuffer* dest_buffer, |
| + int buffer_size, |
| + const CompletionCallback& callback) { |
| + DCHECK(!awaiting_completion_); |
| + 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
|
| + |
| + if (results_.empty()) |
| + return ERR_UNEXPECTED; |
| + |
| + QueuedResult r = results_.front(); |
| + 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.
|
| + if (r.mode == ASYNC) { |
| + awaiting_completion_ = true; |
| + dest_buffer_ = dest_buffer; |
| + dest_buffer_size_ = buffer_size; |
| + callback_ = callback; |
| + return ERR_IO_PENDING; |
| + } |
| + |
| + results_.pop(); |
| + memcpy(dest_buffer->data(), r.data, r.len); |
| + return r.error == OK ? r.len : r.error; |
| +} |
| + |
| +std::string MockSourceStream::OrderedTypeStringList() const { |
| + return ""; |
| +} |
| + |
| +MockSourceStream::QueuedResult::QueuedResult(const char* data, |
| + int len, |
| + Error error, |
| + Mode mode) |
| + : data(data), len(len), error(error), mode(mode) {} |
| + |
| +void MockSourceStream::AddReadResult(const char* data, |
| + int len, |
| + Error error, |
| + Mode mode) { |
| + QueuedResult result(data, len, error, mode); |
| + results_.push(result); |
| +} |
| + |
| +void MockSourceStream::CompleteNextRead() { |
| + 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.
|
| + |
| + awaiting_completion_ = false; |
| + QueuedResult r = results_.front(); |
| + DCHECK_EQ(ASYNC, r.mode); |
| + results_.pop(); |
| + DCHECK_GE(dest_buffer_size_, r.len); |
| + memcpy(dest_buffer_->data(), r.data, r.len); |
| + dest_buffer_ = nullptr; |
| + callback_.Run(r.error == OK ? r.len : r.error); |
| +} |
| + |
| +} // namespace net |