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

Side by Side Diff: third_party/WebKit/Source/modules/fetch/CompositeDataConsumerHandleTest.cpp

Issue 2172183003: Return unique_ptr<WebDataConsumerHandle::Reader> directly from obtainReader (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@gmock_cxx11
Patch Set: rebase 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 unified diff | Download patch
OLDNEW
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
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
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
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698