Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | 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 | 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 "net/filter/mock_source_stream.h" | 5 #include "net/filter/mock_source_stream.h" |
| 6 | 6 |
| 7 #include "base/logging.h" | 7 #include "base/logging.h" |
| 8 #include "net/base/io_buffer.h" | 8 #include "net/base/io_buffer.h" |
| 9 #include "testing/gtest/include/gtest/gtest.h" | |
| 9 | 10 |
| 10 namespace net { | 11 namespace net { |
| 11 | 12 |
| 12 MockSourceStream::MockSourceStream() | 13 MockSourceStream::MockSourceStream() |
| 13 : SourceStream(SourceStream::TYPE_NONE), | 14 : SourceStream(SourceStream::TYPE_NONE), |
| 15 read_one_byte_at_a_time_(false), | |
| 14 awaiting_completion_(false), | 16 awaiting_completion_(false), |
| 15 dest_buffer_(nullptr), | 17 dest_buffer_(nullptr), |
| 16 dest_buffer_size_(0) {} | 18 dest_buffer_size_(0) {} |
| 17 | 19 |
| 18 MockSourceStream::~MockSourceStream() { | 20 MockSourceStream::~MockSourceStream() { |
| 19 DCHECK(!awaiting_completion_); | 21 DCHECK(!awaiting_completion_); |
| 20 DCHECK(results_.empty()); | 22 // All data should have been consumed. |
| 23 EXPECT_TRUE(results_.empty()); | |
|
mmenke
2016/12/29 22:39:31
Generally, DCHECKs should check for test fixture b
xunjieli
2017/01/03 16:21:18
Acknowledged.
| |
| 21 } | 24 } |
| 22 | 25 |
| 23 int MockSourceStream::Read(IOBuffer* dest_buffer, | 26 int MockSourceStream::Read(IOBuffer* dest_buffer, |
| 24 int buffer_size, | 27 int buffer_size, |
| 25 const CompletionCallback& callback) { | 28 const CompletionCallback& callback) { |
| 26 DCHECK(!awaiting_completion_); | 29 DCHECK(!awaiting_completion_); |
| 27 DCHECK(!results_.empty()); | 30 DCHECK(!results_.empty()); |
| 28 | 31 |
| 29 if (results_.empty()) | 32 if (results_.empty()) |
| 30 return ERR_UNEXPECTED; | 33 return ERR_UNEXPECTED; |
| (...skipping 24 matching lines...) Expand all Loading... | |
| 55 : data(data), len(len), error(error), mode(mode) {} | 58 : data(data), len(len), error(error), mode(mode) {} |
| 56 | 59 |
| 57 void MockSourceStream::AddReadResult(const char* data, | 60 void MockSourceStream::AddReadResult(const char* data, |
| 58 int len, | 61 int len, |
| 59 Error error, | 62 Error error, |
| 60 Mode mode) { | 63 Mode mode) { |
| 61 // The read result must be between 0 and 32k (inclusive) because the read | 64 // The read result must be between 0 and 32k (inclusive) because the read |
| 62 // buffer used in FilterSourceStream is 32k. | 65 // buffer used in FilterSourceStream is 32k. |
| 63 DCHECK_GE(32 * 1024, len); | 66 DCHECK_GE(32 * 1024, len); |
| 64 DCHECK_LE(0, len); | 67 DCHECK_LE(0, len); |
| 68 // Doesn't make any sense to have both an error and data. | |
|
xunjieli
2017/01/03 16:21:17
It makes sense to check |len| when error != OK. Co
mmenke
2017/01/03 18:25:42
I think you mean add them to an else clause for th
| |
| 69 if (error != OK) | |
| 70 DCHECK_GE(len, 0); | |
| 71 | |
| 72 if (len > 0 && read_one_byte_at_a_time_) { | |
| 73 for (int i = 0; i < len; ++i) { | |
| 74 QueuedResult result(data + i, 1, OK, mode); | |
| 75 results_.push(result); | |
| 76 } | |
| 77 return; | |
| 78 } | |
| 79 | |
| 65 QueuedResult result(data, len, error, mode); | 80 QueuedResult result(data, len, error, mode); |
| 66 results_.push(result); | 81 results_.push(result); |
| 67 } | 82 } |
| 68 | 83 |
| 69 void MockSourceStream::CompleteNextRead() { | 84 void MockSourceStream::CompleteNextRead() { |
| 70 DCHECK(awaiting_completion_); | 85 DCHECK(awaiting_completion_); |
| 71 | 86 |
| 72 awaiting_completion_ = false; | 87 awaiting_completion_ = false; |
| 73 QueuedResult r = results_.front(); | 88 QueuedResult r = results_.front(); |
| 74 DCHECK_EQ(ASYNC, r.mode); | 89 DCHECK_EQ(ASYNC, r.mode); |
| 75 results_.pop(); | 90 results_.pop(); |
| 76 DCHECK_GE(dest_buffer_size_, r.len); | 91 DCHECK_GE(dest_buffer_size_, r.len); |
| 77 memcpy(dest_buffer_->data(), r.data, r.len); | 92 memcpy(dest_buffer_->data(), r.data, r.len); |
| 78 dest_buffer_ = nullptr; | 93 dest_buffer_ = nullptr; |
| 79 callback_.Run(r.error == OK ? r.len : r.error); | 94 callback_.Run(r.error == OK ? r.len : r.error); |
| 80 } | 95 } |
| 81 | 96 |
| 82 } // namespace net | 97 } // namespace net |
| OLD | NEW |