| OLD | NEW |
| (Empty) | |
| 1 // Copyright 2016 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 "modules/fetch/BytesConsumerForDataConsumerHandle.h" |
| 6 |
| 7 #include "modules/fetch/BytesConsumer.h" |
| 8 #include "modules/fetch/DataConsumerHandleTestUtil.h" |
| 9 #include "modules/fetch/DataConsumerHandleUtil.h" |
| 10 #include "platform/testing/UnitTestHelpers.h" |
| 11 #include "testing/gmock/include/gmock/gmock.h" |
| 12 #include "testing/gtest/include/gtest/gtest.h" |
| 13 |
| 14 namespace blink { |
| 15 |
| 16 namespace { |
| 17 |
| 18 using Command = DataConsumerHandleTestUtil::Command; |
| 19 using Checkpoint = ::testing::StrictMock<::testing::MockFunction<void(int)>>; |
| 20 using ReplayingHandle = DataConsumerHandleTestUtil::ReplayingHandle; |
| 21 using Result = BytesConsumer::Result; |
| 22 using ::testing::InSequence; |
| 23 using ::testing::Return; |
| 24 |
| 25 class BytesConsumerForDataConsumerHandleTest : public ::testing::Test { |
| 26 protected: |
| 27 ~BytesConsumerForDataConsumerHandleTest() |
| 28 { |
| 29 ThreadHeap::collectAllGarbage(); |
| 30 } |
| 31 }; |
| 32 |
| 33 class MockClient : public GarbageCollectedFinalized<MockClient>, public BytesCon
sumer::Client { |
| 34 USING_GARBAGE_COLLECTED_MIXIN(MockClient); |
| 35 public: |
| 36 static MockClient* create() { return new ::testing::StrictMock<MockClient>()
; } |
| 37 MOCK_METHOD0(onReadable, void()); |
| 38 MOCK_METHOD0(onClose, void()); |
| 39 MOCK_METHOD1(onError, void(const BytesConsumer::Error&)); |
| 40 |
| 41 protected: |
| 42 MockClient() {} |
| 43 }; |
| 44 |
| 45 class MockDataConsumerHandle final : public FetchDataConsumerHandle { |
| 46 public: |
| 47 class MockReaderProxy : public GarbageCollectedFinalized<MockReaderProxy> { |
| 48 public: |
| 49 MOCK_METHOD4(read, WebDataConsumerHandle::Result(void*, size_t, WebDataC
onsumerHandle::Flags, size_t*)); |
| 50 MOCK_METHOD3(beginRead, WebDataConsumerHandle::Result(const void**, WebD
ataConsumerHandle::Flags, size_t*)); |
| 51 MOCK_METHOD1(endRead, WebDataConsumerHandle::Result(size_t)); |
| 52 MOCK_METHOD1(drainAsBlobDataHandle, PassRefPtr<BlobDataHandle>(FetchData
ConsumerHandle::Reader::BlobSizePolicy)); |
| 53 MOCK_METHOD0(drainAsFormData, PassRefPtr<EncodedFormData>()); |
| 54 |
| 55 DEFINE_INLINE_TRACE() {} |
| 56 }; |
| 57 |
| 58 MockDataConsumerHandle() : m_proxy(new MockReaderProxy) {} |
| 59 MockReaderProxy* proxy() { return m_proxy; } |
| 60 const char* debugName() const { return "MockDataConsumerHandle"; } |
| 61 |
| 62 private: |
| 63 class Reader final : public FetchDataConsumerHandle::Reader { |
| 64 public: |
| 65 explicit Reader(MockReaderProxy* proxy) : m_proxy(proxy) {} |
| 66 Result read(void* buffer, size_t size, WebDataConsumerHandle::Flags flag
s, size_t* read) override |
| 67 { |
| 68 return m_proxy->read(buffer, size, flags, read); |
| 69 } |
| 70 Result beginRead(const void** buffer, Flags flags, size_t* available) ov
erride |
| 71 { |
| 72 return m_proxy->beginRead(buffer, flags, available); |
| 73 } |
| 74 Result endRead(size_t readSize) override |
| 75 { |
| 76 return m_proxy->endRead(readSize); |
| 77 } |
| 78 PassRefPtr<BlobDataHandle> drainAsBlobDataHandle(BlobSizePolicy policy)
override |
| 79 { |
| 80 return m_proxy->drainAsBlobDataHandle(policy); |
| 81 } |
| 82 PassRefPtr<EncodedFormData> drainAsFormData() override |
| 83 { |
| 84 return m_proxy->drainAsFormData(); |
| 85 } |
| 86 |
| 87 private: |
| 88 Persistent<MockReaderProxy> m_proxy; |
| 89 }; |
| 90 |
| 91 Reader* obtainReaderInternal(Client*) { return new Reader(m_proxy); } |
| 92 Persistent<MockReaderProxy> m_proxy; |
| 93 }; |
| 94 |
| 95 } // namespace |
| 96 |
| 97 TEST_F(BytesConsumerForDataConsumerHandleTest, Create) |
| 98 { |
| 99 OwnPtr<ReplayingHandle> handle = ReplayingHandle::create(); |
| 100 handle->add(Command(Command::Data, "hello")); |
| 101 handle->add(Command(Command::Done)); |
| 102 Persistent<BytesConsumer> consumer = new BytesConsumerForDataConsumerHandle(
createFetchDataConsumerHandleFromWebHandle(std::move(handle))); |
| 103 } |
| 104 |
| 105 TEST_F(BytesConsumerForDataConsumerHandleTest, BecomeReadable) |
| 106 { |
| 107 Checkpoint checkpoint; |
| 108 Persistent<MockClient> client = MockClient::create(); |
| 109 |
| 110 InSequence s; |
| 111 EXPECT_CALL(checkpoint, Call(1)); |
| 112 EXPECT_CALL(*client, onReadable()); |
| 113 EXPECT_CALL(checkpoint, Call(2)); |
| 114 |
| 115 OwnPtr<ReplayingHandle> handle = ReplayingHandle::create(); |
| 116 handle->add(Command(Command::Data, "hello")); |
| 117 Persistent<BytesConsumer> consumer = new BytesConsumerForDataConsumerHandle(
createFetchDataConsumerHandleFromWebHandle(std::move(handle))); |
| 118 consumer->setClient(client); |
| 119 |
| 120 checkpoint.Call(1); |
| 121 testing::runPendingTasks(); |
| 122 checkpoint.Call(2); |
| 123 } |
| 124 |
| 125 TEST_F(BytesConsumerForDataConsumerHandleTest, BecomeClosed) |
| 126 { |
| 127 Checkpoint checkpoint; |
| 128 Persistent<MockClient> client = MockClient::create(); |
| 129 |
| 130 InSequence s; |
| 131 EXPECT_CALL(checkpoint, Call(1)); |
| 132 EXPECT_CALL(*client, onClose()); |
| 133 EXPECT_CALL(checkpoint, Call(2)); |
| 134 |
| 135 OwnPtr<ReplayingHandle> handle = ReplayingHandle::create(); |
| 136 handle->add(Command(Command::Done)); |
| 137 Persistent<BytesConsumer> consumer = new BytesConsumerForDataConsumerHandle(
createFetchDataConsumerHandleFromWebHandle(std::move(handle))); |
| 138 consumer->setClient(client); |
| 139 |
| 140 checkpoint.Call(1); |
| 141 testing::runPendingTasks(); |
| 142 checkpoint.Call(2); |
| 143 } |
| 144 |
| 145 TEST_F(BytesConsumerForDataConsumerHandleTest, BecomeErrored) |
| 146 { |
| 147 Checkpoint checkpoint; |
| 148 Persistent<MockClient> client = MockClient::create(); |
| 149 |
| 150 InSequence s; |
| 151 EXPECT_CALL(checkpoint, Call(1)); |
| 152 EXPECT_CALL(*client, onError(BytesConsumer::Error("error"))); |
| 153 EXPECT_CALL(checkpoint, Call(2)); |
| 154 |
| 155 OwnPtr<ReplayingHandle> handle = ReplayingHandle::create(); |
| 156 handle->add(Command(Command::Error)); |
| 157 Persistent<BytesConsumer> consumer = new BytesConsumerForDataConsumerHandle(
createFetchDataConsumerHandleFromWebHandle(std::move(handle))); |
| 158 consumer->setClient(client); |
| 159 |
| 160 checkpoint.Call(1); |
| 161 testing::runPendingTasks(); |
| 162 checkpoint.Call(2); |
| 163 } |
| 164 |
| 165 TEST_F(BytesConsumerForDataConsumerHandleTest, ClearClient) |
| 166 { |
| 167 Checkpoint checkpoint; |
| 168 Persistent<MockClient> client = MockClient::create(); |
| 169 |
| 170 InSequence s; |
| 171 EXPECT_CALL(checkpoint, Call(1)); |
| 172 EXPECT_CALL(checkpoint, Call(2)); |
| 173 |
| 174 OwnPtr<ReplayingHandle> handle = ReplayingHandle::create(); |
| 175 handle->add(Command(Command::Error)); |
| 176 Persistent<BytesConsumer> consumer = new BytesConsumerForDataConsumerHandle(
createFetchDataConsumerHandleFromWebHandle(std::move(handle))); |
| 177 consumer->setClient(client); |
| 178 consumer->clearClient(); |
| 179 |
| 180 checkpoint.Call(1); |
| 181 testing::runPendingTasks(); |
| 182 checkpoint.Call(2); |
| 183 } |
| 184 |
| 185 TEST_F(BytesConsumerForDataConsumerHandleTest, ReadWhenReadable) |
| 186 { |
| 187 OwnPtr<ReplayingHandle> handle = ReplayingHandle::create(); |
| 188 handle->add(Command(Command::Data, "hello")); |
| 189 Persistent<BytesConsumer> consumer = new BytesConsumerForDataConsumerHandle(
createFetchDataConsumerHandleFromWebHandle(std::move(handle))); |
| 190 |
| 191 char buffer[16]; |
| 192 size_t read; |
| 193 Result r = consumer->read(buffer, sizeof(buffer), &read); |
| 194 ASSERT_EQ(Result::Ok, r); |
| 195 EXPECT_EQ("hello", String(buffer, read)); |
| 196 } |
| 197 |
| 198 TEST_F(BytesConsumerForDataConsumerHandleTest, ReadWhenWaiting) |
| 199 { |
| 200 OwnPtr<ReplayingHandle> handle = ReplayingHandle::create(); |
| 201 Persistent<BytesConsumer> consumer = new BytesConsumerForDataConsumerHandle(
createFetchDataConsumerHandleFromWebHandle(std::move(handle))); |
| 202 |
| 203 char buffer[16]; |
| 204 size_t read; |
| 205 Result r = consumer->read(buffer, sizeof(buffer), &read); |
| 206 ASSERT_EQ(Result::ShouldWait, r); |
| 207 } |
| 208 |
| 209 TEST_F(BytesConsumerForDataConsumerHandleTest, ReadWhenClosed) |
| 210 { |
| 211 OwnPtr<ReplayingHandle> handle = ReplayingHandle::create(); |
| 212 handle->add(Command(Command::Done)); |
| 213 Persistent<BytesConsumer> consumer = new BytesConsumerForDataConsumerHandle(
createFetchDataConsumerHandleFromWebHandle(std::move(handle))); |
| 214 |
| 215 char buffer[16]; |
| 216 size_t read; |
| 217 Result r = consumer->read(buffer, sizeof(buffer), &read); |
| 218 ASSERT_EQ(Result::Done, r); |
| 219 } |
| 220 |
| 221 TEST_F(BytesConsumerForDataConsumerHandleTest, ReadWhenErrored) |
| 222 { |
| 223 OwnPtr<ReplayingHandle> handle = ReplayingHandle::create(); |
| 224 handle->add(Command(Command::Error)); |
| 225 Persistent<BytesConsumer> consumer = new BytesConsumerForDataConsumerHandle(
createFetchDataConsumerHandleFromWebHandle(std::move(handle))); |
| 226 |
| 227 char buffer[16]; |
| 228 size_t read; |
| 229 Result r = consumer->read(buffer, sizeof(buffer), &read); |
| 230 ASSERT_EQ(Result::Error, r); |
| 231 EXPECT_EQ(BytesConsumer::Error("error"), consumer->getError()); |
| 232 } |
| 233 |
| 234 TEST_F(BytesConsumerForDataConsumerHandleTest, TwoPhaseReadWhenReadable) |
| 235 { |
| 236 OwnPtr<ReplayingHandle> handle = ReplayingHandle::create(); |
| 237 handle->add(Command(Command::Data, "hello")); |
| 238 Persistent<BytesConsumer> consumer = new BytesConsumerForDataConsumerHandle(
createFetchDataConsumerHandleFromWebHandle(std::move(handle))); |
| 239 |
| 240 const char* buffer = nullptr; |
| 241 size_t available = 0; |
| 242 ASSERT_EQ(Result::Ok, consumer->beginRead(&buffer, &available)); |
| 243 EXPECT_EQ("hello", String(buffer, available)); |
| 244 |
| 245 ASSERT_EQ(Result::Ok, consumer->endRead(1)); |
| 246 ASSERT_EQ(Result::Ok, consumer->beginRead(&buffer, &available)); |
| 247 EXPECT_EQ("ello", String(buffer, available)); |
| 248 |
| 249 ASSERT_EQ(Result::Ok, consumer->endRead(4)); |
| 250 ASSERT_EQ(Result::ShouldWait, consumer->beginRead(&buffer, &available)); |
| 251 } |
| 252 |
| 253 TEST_F(BytesConsumerForDataConsumerHandleTest, TwoPhaseReadWhenWaiting) |
| 254 { |
| 255 OwnPtr<ReplayingHandle> handle = ReplayingHandle::create(); |
| 256 Persistent<BytesConsumer> consumer = new BytesConsumerForDataConsumerHandle(
createFetchDataConsumerHandleFromWebHandle(std::move(handle))); |
| 257 const char* buffer = nullptr; |
| 258 size_t available = 0; |
| 259 ASSERT_EQ(Result::ShouldWait, consumer->beginRead(&buffer, &available)); |
| 260 } |
| 261 |
| 262 TEST_F(BytesConsumerForDataConsumerHandleTest, TwoPhaseReadWhenClosed) |
| 263 { |
| 264 OwnPtr<ReplayingHandle> handle = ReplayingHandle::create(); |
| 265 handle->add(Command(Command::Done)); |
| 266 Persistent<BytesConsumer> consumer = new BytesConsumerForDataConsumerHandle(
createFetchDataConsumerHandleFromWebHandle(std::move(handle))); |
| 267 const char* buffer = nullptr; |
| 268 size_t available = 0; |
| 269 ASSERT_EQ(Result::Done, consumer->beginRead(&buffer, &available)); |
| 270 } |
| 271 |
| 272 TEST_F(BytesConsumerForDataConsumerHandleTest, TwoPhaseReadWhenErrored) |
| 273 { |
| 274 OwnPtr<ReplayingHandle> handle = ReplayingHandle::create(); |
| 275 handle->add(Command(Command::Error)); |
| 276 Persistent<BytesConsumer> consumer = new BytesConsumerForDataConsumerHandle(
createFetchDataConsumerHandleFromWebHandle(std::move(handle))); |
| 277 const char* buffer = nullptr; |
| 278 size_t available = 0; |
| 279 ASSERT_EQ(Result::Error, consumer->beginRead(&buffer, &available)); |
| 280 EXPECT_EQ(BytesConsumer::Error("error"), consumer->getError()); |
| 281 } |
| 282 |
| 283 TEST_F(BytesConsumerForDataConsumerHandleTest, Cancel) |
| 284 { |
| 285 OwnPtr<ReplayingHandle> handle = ReplayingHandle::create(); |
| 286 Persistent<BytesConsumer> consumer = new BytesConsumerForDataConsumerHandle(
createFetchDataConsumerHandleFromWebHandle(std::move(handle))); |
| 287 consumer->cancel(); |
| 288 const char* buffer = nullptr; |
| 289 size_t available = 0; |
| 290 ASSERT_EQ(Result::Done, consumer->beginRead(&buffer, &available)); |
| 291 } |
| 292 |
| 293 TEST_F(BytesConsumerForDataConsumerHandleTest, drainAsBlobDataHandle) |
| 294 { |
| 295 // FetchDataConsumerHandle::Reader::drainAsBlobDataHandle should return |
| 296 // nullptr from the second time, but we don't care that here. |
| 297 OwnPtr<MockDataConsumerHandle> handle = adoptPtr(new MockDataConsumerHandle)
; |
| 298 Persistent<MockDataConsumerHandle::MockReaderProxy> proxy = handle->proxy(); |
| 299 Persistent<BytesConsumer> consumer = new BytesConsumerForDataConsumerHandle(
std::move(handle)); |
| 300 RefPtr<BlobDataHandle> blobDataHandle = BlobDataHandle::create(); |
| 301 |
| 302 Checkpoint checkpoint; |
| 303 InSequence s; |
| 304 EXPECT_CALL(*proxy, drainAsBlobDataHandle(FetchDataConsumerHandle::Reader::D
isallowBlobWithInvalidSize)).WillOnce(Return(nullptr)); |
| 305 EXPECT_CALL(*proxy, drainAsBlobDataHandle(FetchDataConsumerHandle::Reader::A
llowBlobWithInvalidSize)).WillOnce(Return(nullptr)); |
| 306 EXPECT_CALL(*proxy, drainAsBlobDataHandle(FetchDataConsumerHandle::Reader::A
llowBlobWithInvalidSize)).WillOnce(Return(blobDataHandle)); |
| 307 |
| 308 EXPECT_FALSE(consumer->drainAsBlobDataHandle(BytesConsumer::BlobSizePolicy::
DisallowBlobWithInvalidSize)); |
| 309 EXPECT_FALSE(consumer->drainAsBlobDataHandle(BytesConsumer::BlobSizePolicy::
AllowBlobWithInvalidSize)); |
| 310 EXPECT_TRUE(blobDataHandle); |
| 311 EXPECT_EQ(blobDataHandle, consumer->drainAsBlobDataHandle(BytesConsumer::Blo
bSizePolicy::AllowBlobWithInvalidSize)); |
| 312 } |
| 313 |
| 314 TEST_F(BytesConsumerForDataConsumerHandleTest, drainAsFormData) |
| 315 { |
| 316 OwnPtr<MockDataConsumerHandle> handle = adoptPtr(new MockDataConsumerHandle)
; |
| 317 Persistent<MockDataConsumerHandle::MockReaderProxy> proxy = handle->proxy(); |
| 318 Persistent<BytesConsumer> consumer = new BytesConsumerForDataConsumerHandle(
std::move(handle)); |
| 319 RefPtr<EncodedFormData> formData = EncodedFormData::create(); |
| 320 |
| 321 Checkpoint checkpoint; |
| 322 InSequence s; |
| 323 EXPECT_CALL(*proxy, drainAsFormData()).WillOnce(Return(formData)); |
| 324 |
| 325 EXPECT_EQ(formData, consumer->drainAsFormData()); |
| 326 } |
| 327 |
| 328 } // namespace blink |
| OLD | NEW |