| 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 "modules/fetch/CompositeDataConsumerHandle.h" | 5 #include "modules/fetch/CompositeDataConsumerHandle.h" |
| 6 | 6 |
| 7 #include "modules/fetch/DataConsumerHandleTestUtil.h" | 7 #include "modules/fetch/DataConsumerHandleTestUtil.h" |
| 8 #include "platform/CrossThreadFunctional.h" | 8 #include "platform/CrossThreadFunctional.h" |
| 9 #include "platform/WaitableEvent.h" | 9 #include "platform/WaitableEvent.h" |
| 10 #include "platform/heap/Handle.h" | 10 #include "platform/heap/Handle.h" |
| 11 #include "public/platform/Platform.h" | 11 #include "public/platform/Platform.h" |
| 12 #include "public/platform/WebThread.h" | 12 #include "public/platform/WebThread.h" |
| 13 #include "public/platform/WebTraceLocation.h" | 13 #include "public/platform/WebTraceLocation.h" |
| 14 #include "testing/gmock/include/gmock/gmock.h" | 14 #include "testing/gmock/include/gmock/gmock.h" |
| 15 #include "testing/gtest/include/gtest/gtest.h" | 15 #include "testing/gtest/include/gtest/gtest.h" |
| 16 #include "wtf/Locker.h" | 16 #include "wtf/Locker.h" |
| 17 #include "wtf/PtrUtil.h" | 17 #include "wtf/PtrUtil.h" |
| 18 #include <memory> | 18 #include <memory> |
| 19 | 19 |
| 20 namespace blink { | 20 namespace blink { |
| 21 | 21 |
| 22 namespace { | 22 namespace { |
| 23 | 23 |
| 24 using ::testing::ByMove; |
| 24 using ::testing::InSequence; | 25 using ::testing::InSequence; |
| 25 using ::testing::Return; | 26 using ::testing::Return; |
| 26 using ::testing::StrictMock; | 27 using ::testing::StrictMock; |
| 27 using Checkpoint = StrictMock<::testing::MockFunction<void(int)>>; | 28 using Checkpoint = StrictMock<::testing::MockFunction<void(int)>>; |
| 28 | 29 |
| 29 const WebDataConsumerHandle::Result kShouldWait = WebDataConsumerHandle::ShouldW
ait; | 30 const WebDataConsumerHandle::Result kShouldWait = WebDataConsumerHandle::ShouldW
ait; |
| 30 const WebDataConsumerHandle::Result kOk = WebDataConsumerHandle::Ok; | 31 const WebDataConsumerHandle::Result kOk = WebDataConsumerHandle::Ok; |
| 31 const WebDataConsumerHandle::Flags kNone = WebDataConsumerHandle::FlagNone; | 32 const WebDataConsumerHandle::Flags kNone = WebDataConsumerHandle::FlagNone; |
| 32 | 33 |
| 33 class MockReader : public WebDataConsumerHandle::Reader { | 34 class MockReader : public WebDataConsumerHandle::Reader { |
| 34 public: | 35 public: |
| 35 static std::unique_ptr<StrictMock<MockReader>> create() { return wrapUnique(
new StrictMock<MockReader>); } | 36 static std::unique_ptr<StrictMock<MockReader>> create() { return wrapUnique(
new StrictMock<MockReader>); } |
| 36 | 37 |
| 37 using Result = WebDataConsumerHandle::Result; | 38 using Result = WebDataConsumerHandle::Result; |
| 38 using Flags = WebDataConsumerHandle::Flags; | 39 using Flags = WebDataConsumerHandle::Flags; |
| 39 MOCK_METHOD4(read, Result(void*, size_t, Flags, size_t*)); | 40 MOCK_METHOD4(read, Result(void*, size_t, Flags, size_t*)); |
| 40 MOCK_METHOD3(beginRead, Result(const void**, Flags, size_t*)); | 41 MOCK_METHOD3(beginRead, Result(const void**, Flags, size_t*)); |
| 41 MOCK_METHOD1(endRead, Result(size_t)); | 42 MOCK_METHOD1(endRead, Result(size_t)); |
| 42 }; | 43 }; |
| 43 | 44 |
| 44 class MockHandle : public WebDataConsumerHandle { | 45 class MockHandle : public WebDataConsumerHandle { |
| 45 public: | 46 public: |
| 46 static std::unique_ptr<StrictMock<MockHandle>> create() { return wrapUnique(
new StrictMock<MockHandle>); } | 47 static std::unique_ptr<StrictMock<MockHandle>> create() { return wrapUnique(
new StrictMock<MockHandle>); } |
| 47 | 48 |
| 48 MOCK_METHOD1(obtainReaderInternal, Reader*(Client*)); | 49 MOCK_METHOD1(obtainReader, std::unique_ptr<Reader>(Client*)); |
| 49 | 50 |
| 50 private: | 51 private: |
| 51 const char* debugName() const override { return "MockHandle in CompositeData
ConsumerHandleTest"; } | 52 const char* debugName() const override { return "MockHandle in CompositeData
ConsumerHandleTest"; } |
| 52 }; | 53 }; |
| 53 | 54 |
| 54 class ThreadingRegistrationTest : public DataConsumerHandleTestUtil::ThreadingTe
stBase { | 55 class ThreadingRegistrationTest : public DataConsumerHandleTestUtil::ThreadingTe
stBase { |
| 55 public: | 56 public: |
| 56 using Self = ThreadingRegistrationTest; | 57 using Self = ThreadingRegistrationTest; |
| 57 static PassRefPtr<Self> create() { return adoptRef(new Self); } | 58 static PassRefPtr<Self> create() { return adoptRef(new Self); } |
| 58 | 59 |
| (...skipping 213 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 272 | 273 |
| 273 TEST(CompositeDataConsumerHandleTest, Read) | 274 TEST(CompositeDataConsumerHandleTest, Read) |
| 274 { | 275 { |
| 275 char buffer[20]; | 276 char buffer[20]; |
| 276 size_t size = 0; | 277 size_t size = 0; |
| 277 DataConsumerHandleTestUtil::NoopClient client; | 278 DataConsumerHandleTestUtil::NoopClient client; |
| 278 Checkpoint checkpoint; | 279 Checkpoint checkpoint; |
| 279 | 280 |
| 280 std::unique_ptr<MockHandle> handle1 = MockHandle::create(); | 281 std::unique_ptr<MockHandle> handle1 = MockHandle::create(); |
| 281 std::unique_ptr<MockHandle> handle2 = MockHandle::create(); | 282 std::unique_ptr<MockHandle> handle2 = MockHandle::create(); |
| 282 std::unique_ptr<MockReader> reader1 = MockReader::create(); | 283 |
| 283 std::unique_ptr<MockReader> reader2 = MockReader::create(); | 284 // They will be adopted by |obtainReader|. |
| 285 MockReader* reader1 = MockReader::create().release(); |
| 286 MockReader* reader2 = MockReader::create().release(); |
| 284 | 287 |
| 285 InSequence s; | 288 InSequence s; |
| 286 EXPECT_CALL(checkpoint, Call(0)); | 289 EXPECT_CALL(checkpoint, Call(0)); |
| 287 EXPECT_CALL(*handle1, obtainReaderInternal(&client)).WillOnce(Return(reader1
.get())); | 290 EXPECT_CALL(*handle1, obtainReader(&client)).WillOnce(Return(ByMove(WTF::wra
pUnique(reader1)))); |
| 288 EXPECT_CALL(checkpoint, Call(1)); | 291 EXPECT_CALL(checkpoint, Call(1)); |
| 289 EXPECT_CALL(*reader1, read(buffer, sizeof(buffer), kNone, &size)).WillOnce(R
eturn(kOk)); | 292 EXPECT_CALL(*reader1, read(buffer, sizeof(buffer), kNone, &size)).WillOnce(R
eturn(kOk)); |
| 290 EXPECT_CALL(checkpoint, Call(2)); | 293 EXPECT_CALL(checkpoint, Call(2)); |
| 291 EXPECT_CALL(*handle2, obtainReaderInternal(&client)).WillOnce(Return(reader2
.get())); | 294 EXPECT_CALL(*handle2, obtainReader(&client)).WillOnce(Return(ByMove(WTF::wra
pUnique(reader2)))); |
| 292 EXPECT_CALL(checkpoint, Call(3)); | 295 EXPECT_CALL(checkpoint, Call(3)); |
| 293 EXPECT_CALL(*reader2, read(buffer, sizeof(buffer), kNone, &size)).WillOnce(R
eturn(kOk)); | 296 EXPECT_CALL(*reader2, read(buffer, sizeof(buffer), kNone, &size)).WillOnce(R
eturn(kOk)); |
| 294 EXPECT_CALL(checkpoint, Call(4)); | 297 EXPECT_CALL(checkpoint, Call(4)); |
| 295 | 298 |
| 296 // They are adopted by |obtainReader|. | |
| 297 ASSERT_TRUE(reader1.release()); | |
| 298 ASSERT_TRUE(reader2.release()); | |
| 299 | |
| 300 CompositeDataConsumerHandle::Updater* updater = nullptr; | 299 CompositeDataConsumerHandle::Updater* updater = nullptr; |
| 301 std::unique_ptr<WebDataConsumerHandle> handle = CompositeDataConsumerHandle:
:create(std::move(handle1), &updater); | 300 std::unique_ptr<WebDataConsumerHandle> handle = CompositeDataConsumerHandle:
:create(std::move(handle1), &updater); |
| 302 checkpoint.Call(0); | 301 checkpoint.Call(0); |
| 303 std::unique_ptr<WebDataConsumerHandle::Reader> reader = handle->obtainReader
(&client); | 302 std::unique_ptr<WebDataConsumerHandle::Reader> reader = handle->obtainReader
(&client); |
| 304 checkpoint.Call(1); | 303 checkpoint.Call(1); |
| 305 EXPECT_EQ(kOk, reader->read(buffer, sizeof(buffer), kNone, &size)); | 304 EXPECT_EQ(kOk, reader->read(buffer, sizeof(buffer), kNone, &size)); |
| 306 checkpoint.Call(2); | 305 checkpoint.Call(2); |
| 307 updater->update(std::move(handle2)); | 306 updater->update(std::move(handle2)); |
| 308 checkpoint.Call(3); | 307 checkpoint.Call(3); |
| 309 EXPECT_EQ(kOk, reader->read(buffer, sizeof(buffer), kNone, &size)); | 308 EXPECT_EQ(kOk, reader->read(buffer, sizeof(buffer), kNone, &size)); |
| 310 checkpoint.Call(4); | 309 checkpoint.Call(4); |
| 311 } | 310 } |
| 312 | 311 |
| 313 TEST(CompositeDataConsumerHandleTest, TwoPhaseRead) | 312 TEST(CompositeDataConsumerHandleTest, TwoPhaseRead) |
| 314 { | 313 { |
| 315 const void* p = nullptr; | 314 const void* p = nullptr; |
| 316 size_t size = 0; | 315 size_t size = 0; |
| 317 Checkpoint checkpoint; | 316 Checkpoint checkpoint; |
| 318 | 317 |
| 319 std::unique_ptr<MockHandle> handle1 = MockHandle::create(); | 318 std::unique_ptr<MockHandle> handle1 = MockHandle::create(); |
| 320 std::unique_ptr<MockHandle> handle2 = MockHandle::create(); | 319 std::unique_ptr<MockHandle> handle2 = MockHandle::create(); |
| 321 std::unique_ptr<MockReader> reader1 = MockReader::create(); | 320 |
| 322 std::unique_ptr<MockReader> reader2 = MockReader::create(); | 321 // They are adopted by |obtainReader|. |
| 322 MockReader* reader1 = MockReader::create().release(); |
| 323 MockReader* reader2 = MockReader::create().release(); |
| 323 | 324 |
| 324 InSequence s; | 325 InSequence s; |
| 325 EXPECT_CALL(checkpoint, Call(0)); | 326 EXPECT_CALL(checkpoint, Call(0)); |
| 326 EXPECT_CALL(*handle1, obtainReaderInternal(nullptr)).WillOnce(Return(reader1
.get())); | 327 EXPECT_CALL(*handle1, obtainReader(nullptr)).WillOnce(Return(ByMove(WTF::wra
pUnique(reader1)))); |
| 327 EXPECT_CALL(checkpoint, Call(1)); | 328 EXPECT_CALL(checkpoint, Call(1)); |
| 328 EXPECT_CALL(*reader1, beginRead(&p, kNone, &size)).WillOnce(Return(kOk)); | 329 EXPECT_CALL(*reader1, beginRead(&p, kNone, &size)).WillOnce(Return(kOk)); |
| 329 EXPECT_CALL(checkpoint, Call(2)); | 330 EXPECT_CALL(checkpoint, Call(2)); |
| 330 EXPECT_CALL(*reader1, endRead(0)).WillOnce(Return(kOk)); | 331 EXPECT_CALL(*reader1, endRead(0)).WillOnce(Return(kOk)); |
| 331 EXPECT_CALL(checkpoint, Call(3)); | 332 EXPECT_CALL(checkpoint, Call(3)); |
| 332 EXPECT_CALL(*handle2, obtainReaderInternal(nullptr)).WillOnce(Return(reader2
.get())); | 333 EXPECT_CALL(*handle2, obtainReader(nullptr)).WillOnce(Return(ByMove(WTF::wra
pUnique(reader2)))); |
| 333 EXPECT_CALL(checkpoint, Call(4)); | 334 EXPECT_CALL(checkpoint, Call(4)); |
| 334 EXPECT_CALL(*reader2, beginRead(&p, kNone, &size)).WillOnce(Return(kOk)); | 335 EXPECT_CALL(*reader2, beginRead(&p, kNone, &size)).WillOnce(Return(kOk)); |
| 335 EXPECT_CALL(checkpoint, Call(5)); | 336 EXPECT_CALL(checkpoint, Call(5)); |
| 336 EXPECT_CALL(*reader2, endRead(0)).WillOnce(Return(kOk)); | 337 EXPECT_CALL(*reader2, endRead(0)).WillOnce(Return(kOk)); |
| 337 EXPECT_CALL(checkpoint, Call(6)); | 338 EXPECT_CALL(checkpoint, Call(6)); |
| 338 | 339 |
| 339 // They are adopted by |obtainReader|. | |
| 340 ASSERT_TRUE(reader1.release()); | |
| 341 ASSERT_TRUE(reader2.release()); | |
| 342 | |
| 343 CompositeDataConsumerHandle::Updater* updater = nullptr; | 340 CompositeDataConsumerHandle::Updater* updater = nullptr; |
| 344 std::unique_ptr<WebDataConsumerHandle> handle = CompositeDataConsumerHandle:
:create(std::move(handle1), &updater); | 341 std::unique_ptr<WebDataConsumerHandle> handle = CompositeDataConsumerHandle:
:create(std::move(handle1), &updater); |
| 345 checkpoint.Call(0); | 342 checkpoint.Call(0); |
| 346 std::unique_ptr<WebDataConsumerHandle::Reader> reader = handle->obtainReader
(nullptr); | 343 std::unique_ptr<WebDataConsumerHandle::Reader> reader = handle->obtainReader
(nullptr); |
| 347 checkpoint.Call(1); | 344 checkpoint.Call(1); |
| 348 EXPECT_EQ(kOk, reader->beginRead(&p, kNone, &size)); | 345 EXPECT_EQ(kOk, reader->beginRead(&p, kNone, &size)); |
| 349 checkpoint.Call(2); | 346 checkpoint.Call(2); |
| 350 EXPECT_EQ(kOk, reader->endRead(0)); | 347 EXPECT_EQ(kOk, reader->endRead(0)); |
| 351 checkpoint.Call(3); | 348 checkpoint.Call(3); |
| 352 updater->update(std::move(handle2)); | 349 updater->update(std::move(handle2)); |
| 353 checkpoint.Call(4); | 350 checkpoint.Call(4); |
| 354 EXPECT_EQ(kOk, reader->beginRead(&p, kNone, &size)); | 351 EXPECT_EQ(kOk, reader->beginRead(&p, kNone, &size)); |
| 355 checkpoint.Call(5); | 352 checkpoint.Call(5); |
| 356 EXPECT_EQ(kOk, reader->endRead(0)); | 353 EXPECT_EQ(kOk, reader->endRead(0)); |
| 357 checkpoint.Call(6); | 354 checkpoint.Call(6); |
| 358 } | 355 } |
| 359 | 356 |
| 360 TEST(CompositeDataConsumerHandleTest, HangingTwoPhaseRead) | 357 TEST(CompositeDataConsumerHandleTest, HangingTwoPhaseRead) |
| 361 { | 358 { |
| 362 const void* p = nullptr; | 359 const void* p = nullptr; |
| 363 size_t size = 0; | 360 size_t size = 0; |
| 364 Checkpoint checkpoint; | 361 Checkpoint checkpoint; |
| 365 | 362 |
| 366 std::unique_ptr<MockHandle> handle1 = MockHandle::create(); | 363 std::unique_ptr<MockHandle> handle1 = MockHandle::create(); |
| 367 std::unique_ptr<MockHandle> handle2 = MockHandle::create(); | 364 std::unique_ptr<MockHandle> handle2 = MockHandle::create(); |
| 368 std::unique_ptr<MockHandle> handle3 = MockHandle::create(); | 365 std::unique_ptr<MockHandle> handle3 = MockHandle::create(); |
| 369 std::unique_ptr<MockReader> reader1 = MockReader::create(); | 366 |
| 370 std::unique_ptr<MockReader> reader2 = MockReader::create(); | 367 // They are adopted by |obtainReader|. |
| 371 std::unique_ptr<MockReader> reader3 = MockReader::create(); | 368 MockReader* reader1 = MockReader::create().release(); |
| 369 MockReader* reader2 = MockReader::create().release(); |
| 370 MockReader* reader3 = MockReader::create().release(); |
| 372 | 371 |
| 373 InSequence s; | 372 InSequence s; |
| 374 EXPECT_CALL(checkpoint, Call(0)); | 373 EXPECT_CALL(checkpoint, Call(0)); |
| 375 EXPECT_CALL(*handle1, obtainReaderInternal(nullptr)).WillOnce(Return(reader1
.get())); | 374 EXPECT_CALL(*handle1, obtainReader(nullptr)).WillOnce(Return(ByMove(WTF::wra
pUnique(reader1)))); |
| 376 EXPECT_CALL(checkpoint, Call(1)); | 375 EXPECT_CALL(checkpoint, Call(1)); |
| 377 EXPECT_CALL(*reader1, beginRead(&p, kNone, &size)).WillOnce(Return(kOk)); | 376 EXPECT_CALL(*reader1, beginRead(&p, kNone, &size)).WillOnce(Return(kOk)); |
| 378 EXPECT_CALL(checkpoint, Call(2)); | 377 EXPECT_CALL(checkpoint, Call(2)); |
| 379 EXPECT_CALL(checkpoint, Call(3)); | 378 EXPECT_CALL(checkpoint, Call(3)); |
| 380 EXPECT_CALL(*reader1, endRead(0)).WillOnce(Return(kOk)); | 379 EXPECT_CALL(*reader1, endRead(0)).WillOnce(Return(kOk)); |
| 381 EXPECT_CALL(*handle2, obtainReaderInternal(nullptr)).WillOnce(Return(reader2
.get())); | 380 EXPECT_CALL(*handle2, obtainReader(nullptr)).WillOnce(Return(ByMove(WTF::wra
pUnique(reader2)))); |
| 382 EXPECT_CALL(checkpoint, Call(4)); | 381 EXPECT_CALL(checkpoint, Call(4)); |
| 383 EXPECT_CALL(*reader2, beginRead(&p, kNone, &size)).WillOnce(Return(kShouldWa
it)); | 382 EXPECT_CALL(*reader2, beginRead(&p, kNone, &size)).WillOnce(Return(kShouldWa
it)); |
| 384 EXPECT_CALL(checkpoint, Call(5)); | 383 EXPECT_CALL(checkpoint, Call(5)); |
| 385 EXPECT_CALL(*handle3, obtainReaderInternal(nullptr)).WillOnce(Return(reader3
.get())); | 384 EXPECT_CALL(*handle3, obtainReader(nullptr)).WillOnce(Return(ByMove(WTF::wra
pUnique(reader3)))); |
| 386 EXPECT_CALL(checkpoint, Call(6)); | 385 EXPECT_CALL(checkpoint, Call(6)); |
| 387 EXPECT_CALL(*reader3, beginRead(&p, kNone, &size)).WillOnce(Return(kOk)); | 386 EXPECT_CALL(*reader3, beginRead(&p, kNone, &size)).WillOnce(Return(kOk)); |
| 388 EXPECT_CALL(checkpoint, Call(7)); | 387 EXPECT_CALL(checkpoint, Call(7)); |
| 389 EXPECT_CALL(*reader3, endRead(0)).WillOnce(Return(kOk)); | 388 EXPECT_CALL(*reader3, endRead(0)).WillOnce(Return(kOk)); |
| 390 EXPECT_CALL(checkpoint, Call(8)); | 389 EXPECT_CALL(checkpoint, Call(8)); |
| 391 | 390 |
| 392 // They are adopted by |obtainReader|. | |
| 393 ASSERT_TRUE(reader1.release()); | |
| 394 ASSERT_TRUE(reader2.release()); | |
| 395 ASSERT_TRUE(reader3.release()); | |
| 396 | |
| 397 CompositeDataConsumerHandle::Updater* updater = nullptr; | 391 CompositeDataConsumerHandle::Updater* updater = nullptr; |
| 398 std::unique_ptr<WebDataConsumerHandle> handle = CompositeDataConsumerHandle:
:create(std::move(handle1), &updater); | 392 std::unique_ptr<WebDataConsumerHandle> handle = CompositeDataConsumerHandle:
:create(std::move(handle1), &updater); |
| 399 checkpoint.Call(0); | 393 checkpoint.Call(0); |
| 400 std::unique_ptr<WebDataConsumerHandle::Reader> reader = handle->obtainReader
(nullptr); | 394 std::unique_ptr<WebDataConsumerHandle::Reader> reader = handle->obtainReader
(nullptr); |
| 401 checkpoint.Call(1); | 395 checkpoint.Call(1); |
| 402 EXPECT_EQ(kOk, reader->beginRead(&p, kNone, &size)); | 396 EXPECT_EQ(kOk, reader->beginRead(&p, kNone, &size)); |
| 403 checkpoint.Call(2); | 397 checkpoint.Call(2); |
| 404 updater->update(std::move(handle2)); | 398 updater->update(std::move(handle2)); |
| 405 checkpoint.Call(3); | 399 checkpoint.Call(3); |
| 406 EXPECT_EQ(kOk, reader->endRead(0)); | 400 EXPECT_EQ(kOk, reader->endRead(0)); |
| (...skipping 83 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 490 { | 484 { |
| 491 RefPtr<DataConsumerHandleTestUtil::ThreadingHandleNoNotificationTest> test =
DataConsumerHandleTestUtil::ThreadingHandleNoNotificationTest::create(); | 485 RefPtr<DataConsumerHandleTestUtil::ThreadingHandleNoNotificationTest> test =
DataConsumerHandleTestUtil::ThreadingHandleNoNotificationTest::create(); |
| 492 CompositeDataConsumerHandle::Updater* updater = nullptr; | 486 CompositeDataConsumerHandle::Updater* updater = nullptr; |
| 493 // Test this function doesn't crash. | 487 // Test this function doesn't crash. |
| 494 test->run(CompositeDataConsumerHandle::create(createDoneDataConsumerHandle()
, &updater)); | 488 test->run(CompositeDataConsumerHandle::create(createDoneDataConsumerHandle()
, &updater)); |
| 495 } | 489 } |
| 496 | 490 |
| 497 } // namespace | 491 } // namespace |
| 498 | 492 |
| 499 } // namespace blink | 493 } // namespace blink |
| OLD | NEW |