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

Unified 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 side-by-side diff with in-line comments
Download patch
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

Powered by Google App Engine
This is Rietveld 408576698