Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 "content/renderer/scheduler/task_queue_manager.h" | 5 #include "content/renderer/scheduler/task_queue_manager.h" |
| 6 | 6 |
| 7 #include "base/test/test_simple_task_runner.h" | 7 #include "base/test/test_simple_task_runner.h" |
| 8 #include "base/threading/thread.h" | 8 #include "base/threading/thread.h" |
| 9 #include "cc/test/test_now_source.h" | 9 #include "cc/test/test_now_source.h" |
| 10 #include "content/renderer/scheduler/task_queue_selector.h" | 10 #include "content/renderer/scheduler/task_queue_selector.h" |
| 11 #include "testing/gmock/include/gmock/gmock.h" | 11 #include "testing/gmock/include/gmock/gmock.h" |
| 12 | 12 |
| 13 using testing::ElementsAre; | 13 using testing::ElementsAre; |
| 14 using testing::_; | |
| 14 | 15 |
| 15 namespace content { | 16 namespace content { |
| 16 namespace { | 17 namespace { |
| 17 | 18 |
| 18 class SelectorForTest : public TaskQueueSelector { | 19 class SelectorForTest : public TaskQueueSelector { |
| 19 public: | 20 public: |
| 20 SelectorForTest() {} | 21 SelectorForTest() {} |
| 21 | 22 |
| 22 void RegisterWorkQueues( | 23 void RegisterWorkQueues( |
| 23 const std::vector<const base::TaskQueue*>& work_queues) override { | 24 const std::vector<const base::TaskQueue*>& work_queues) override { |
| (...skipping 551 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 575 // the work batch is interrupted by the pending delayed task. | 576 // the work batch is interrupted by the pending delayed task. |
| 576 EXPECT_EQ(test_task_runner_->GetPendingTasks().size(), 2u); | 577 EXPECT_EQ(test_task_runner_->GetPendingTasks().size(), 2u); |
| 577 test_task_runner_->RunPendingTasks(); | 578 test_task_runner_->RunPendingTasks(); |
| 578 EXPECT_THAT(run_order, ElementsAre(2)); | 579 EXPECT_THAT(run_order, ElementsAre(2)); |
| 579 | 580 |
| 580 // Running all remaining tasks should execute both pending tasks. | 581 // Running all remaining tasks should execute both pending tasks. |
| 581 test_task_runner_->RunUntilIdle(); | 582 test_task_runner_->RunUntilIdle(); |
| 582 EXPECT_THAT(run_order, ElementsAre(2, 3, 1)); | 583 EXPECT_THAT(run_order, ElementsAre(2, 3, 1)); |
| 583 } | 584 } |
| 584 | 585 |
| 586 class MockTaskObserver : public base::MessageLoop::TaskObserver { | |
| 587 public: | |
| 588 MOCK_METHOD1(DidProcessTask, void(const base::PendingTask& task)); | |
| 589 MOCK_METHOD1(WillProcessTask, void(const base::PendingTask& task)); | |
| 590 }; | |
| 591 | |
| 592 TEST_F(TaskQueueManagerTest, TaskObserverAdding) { | |
| 593 Initialize(1u); | |
| 594 MockTaskObserver observer; | |
| 595 | |
| 596 manager_->SetWorkBatchSize(2); | |
| 597 manager_->AddTaskObserver(&observer); | |
| 598 | |
| 599 std::vector<int> run_order; | |
| 600 scoped_refptr<base::SingleThreadTaskRunner> runner = | |
| 601 manager_->TaskRunnerForQueue(0); | |
| 602 | |
| 603 runner->PostTask(FROM_HERE, base::Bind(&TestTask, 1, &run_order)); | |
| 604 runner->PostTask(FROM_HERE, base::Bind(&TestTask, 2, &run_order)); | |
| 605 | |
| 606 selector_->AppendQueueToService(0); | |
| 607 selector_->AppendQueueToService(0); | |
| 608 | |
| 609 // The observer should be called once because the first and last | |
| 610 // notifications are filtered out. | |
|
rmcilroy
2015/02/23 22:41:43
These test results now look a bit strange - lookin
Sami
2015/02/24 14:39:20
Yeah, I suppose that would be clearer because gene
| |
| 611 EXPECT_CALL(observer, WillProcessTask(_)).Times(1); | |
| 612 EXPECT_CALL(observer, DidProcessTask(_)).Times(1); | |
| 613 test_task_runner_->RunUntilIdle(); | |
| 614 } | |
| 615 | |
| 616 TEST_F(TaskQueueManagerTest, TaskObserverRemoving) { | |
| 617 Initialize(1u); | |
| 618 MockTaskObserver observer; | |
| 619 manager_->SetWorkBatchSize(2); | |
| 620 manager_->AddTaskObserver(&observer); | |
| 621 manager_->RemoveTaskObserver(&observer); | |
| 622 | |
| 623 std::vector<int> run_order; | |
| 624 scoped_refptr<base::SingleThreadTaskRunner> runner = | |
| 625 manager_->TaskRunnerForQueue(0); | |
| 626 | |
| 627 runner->PostTask(FROM_HERE, base::Bind(&TestTask, 1, &run_order)); | |
| 628 | |
| 629 EXPECT_CALL(observer, WillProcessTask(_)).Times(0); | |
| 630 EXPECT_CALL(observer, DidProcessTask(_)).Times(0); | |
| 631 | |
| 632 selector_->AppendQueueToService(0); | |
| 633 test_task_runner_->RunUntilIdle(); | |
| 634 } | |
| 635 | |
| 636 void RemoveObserverTask(TaskQueueManager* manager, | |
| 637 base::MessageLoop::TaskObserver* observer) { | |
| 638 manager->RemoveTaskObserver(observer); | |
| 639 } | |
| 640 | |
| 641 void NoOpTask() { | |
| 642 } | |
| 643 | |
| 644 TEST_F(TaskQueueManagerTest, TaskObserverRemovingInsideTask) { | |
| 645 Initialize(1u); | |
| 646 MockTaskObserver observer; | |
| 647 manager_->SetWorkBatchSize(3); | |
| 648 manager_->AddTaskObserver(&observer); | |
| 649 | |
| 650 scoped_refptr<base::SingleThreadTaskRunner> runner = | |
| 651 manager_->TaskRunnerForQueue(0); | |
| 652 runner->PostTask(FROM_HERE, base::Bind(&NoOpTask)); | |
| 653 runner->PostTask(FROM_HERE, | |
| 654 base::Bind(&RemoveObserverTask, manager_.get(), &observer)); | |
| 655 runner->PostTask(FROM_HERE, base::Bind(&NoOpTask)); | |
| 656 | |
| 657 selector_->AppendQueueToService(0); | |
| 658 selector_->AppendQueueToService(0); | |
| 659 selector_->AppendQueueToService(0); | |
| 660 | |
| 661 // One call to DidProcessTask from the first no-op task and once call to | |
| 662 // WillProcessTask before the RemoveObserverTask. | |
| 663 EXPECT_CALL(observer, WillProcessTask(_)).Times(1); | |
| 664 EXPECT_CALL(observer, DidProcessTask(_)).Times(1); | |
| 665 test_task_runner_->RunUntilIdle(); | |
| 666 } | |
| 667 | |
| 585 } // namespace | 668 } // namespace |
| 586 } // namespace content | 669 } // namespace content |
| OLD | NEW |