| Index: third_party/WebKit/Source/platform/scheduler/renderer/renderer_scheduler_impl_unittest.cc
|
| diff --git a/third_party/WebKit/Source/platform/scheduler/renderer/renderer_scheduler_impl_unittest.cc b/third_party/WebKit/Source/platform/scheduler/renderer/renderer_scheduler_impl_unittest.cc
|
| index 2cc3b00c162a0c25cb2b585c10eb99e4b3b7f249..37d17f8b83b262cd496e755559b64c1b72ab875a 100644
|
| --- a/third_party/WebKit/Source/platform/scheduler/renderer/renderer_scheduler_impl_unittest.cc
|
| +++ b/third_party/WebKit/Source/platform/scheduler/renderer/renderer_scheduler_impl_unittest.cc
|
| @@ -567,6 +567,17 @@ class RendererSchedulerImplTest : public testing::Test {
|
| scheduler_->seqlock_queueing_time_estimator_.seqlock.WriteEnd();
|
| }
|
|
|
| + void RunSlowCompositorTask() {
|
| + // Run a long compositor task so that compositor tasks appear to be running
|
| + // slow and thus compositor tasks will not be prioritized.
|
| + compositor_task_runner_->PostTask(
|
| + FROM_HERE,
|
| + base::Bind(&RendererSchedulerImplTest::SimulateMainThreadCompositorTask,
|
| + base::Unretained(this),
|
| + base::TimeDelta::FromMilliseconds(1000)));
|
| + RunUntilIdle();
|
| + }
|
| +
|
| // Helper for posting several tasks of specific types. |task_descriptor| is a
|
| // string with space delimited task identifiers. The first letter of each
|
| // task identifier specifies the task type:
|
| @@ -832,6 +843,21 @@ TEST_F(RendererSchedulerImplTest, TestDefaultPolicy) {
|
| std::vector<std::string> run_order;
|
| PostTestTasks(&run_order, "L1 I1 D1 C1 D2 C2");
|
|
|
| + EnableIdleTasks();
|
| + RunUntilIdle();
|
| + EXPECT_THAT(run_order,
|
| + testing::ElementsAre(std::string("C1"), std::string("C2"),
|
| + std::string("L1"), std::string("D1"),
|
| + std::string("D2"), std::string("I1")));
|
| + EXPECT_EQ(RendererSchedulerImpl::UseCase::NONE, CurrentUseCase());
|
| +}
|
| +
|
| +TEST_F(RendererSchedulerImplTest, TestDefaultPolicyWithSlowCompositor) {
|
| + RunSlowCompositorTask();
|
| +
|
| + std::vector<std::string> run_order;
|
| + PostTestTasks(&run_order, "L1 I1 D1 C1 D2 C2");
|
| +
|
| EnableIdleTasks();
|
| RunUntilIdle();
|
| EXPECT_THAT(run_order,
|
| @@ -1256,6 +1282,8 @@ TEST_F(RendererSchedulerImplTest, DISABLED_LoadingUseCase) {
|
|
|
| TEST_F(RendererSchedulerImplTest,
|
| EventConsumedOnCompositorThread_IgnoresMouseMove_WhenMouseUp) {
|
| + RunSlowCompositorTask();
|
| +
|
| std::vector<std::string> run_order;
|
| PostTestTasks(&run_order, "I1 D1 C1 D2 C2");
|
|
|
| @@ -1274,6 +1302,8 @@ TEST_F(RendererSchedulerImplTest,
|
|
|
| TEST_F(RendererSchedulerImplTest,
|
| EventForwardedToMainThread_IgnoresMouseMove_WhenMouseUp) {
|
| + RunSlowCompositorTask();
|
| +
|
| std::vector<std::string> run_order;
|
| PostTestTasks(&run_order, "I1 D1 C1 D2 C2");
|
|
|
| @@ -1494,6 +1524,8 @@ TEST_F(
|
|
|
| TEST_F(RendererSchedulerImplTest,
|
| EventConsumedOnCompositorThread_IgnoresKeyboardEvents) {
|
| + RunSlowCompositorTask();
|
| +
|
| std::vector<std::string> run_order;
|
| PostTestTasks(&run_order, "I1 D1 C1 D2 C2");
|
|
|
| @@ -1512,6 +1544,8 @@ TEST_F(RendererSchedulerImplTest,
|
|
|
| TEST_F(RendererSchedulerImplTest,
|
| EventForwardedToMainThread_IgnoresKeyboardEvents) {
|
| + RunSlowCompositorTask();
|
| +
|
| std::vector<std::string> run_order;
|
| PostTestTasks(&run_order, "I1 D1 C1 D2 C2");
|
|
|
| @@ -2381,7 +2415,7 @@ TEST_F(RendererSchedulerImplTest, SuspendRenderer) {
|
| EnableIdleTasks();
|
| RunUntilIdle();
|
| EXPECT_THAT(run_order,
|
| - testing::ElementsAre(std::string("D1"), std::string("C1"),
|
| + testing::ElementsAre(std::string("C1"), std::string("D1"),
|
| std::string("I1")));
|
|
|
| // The rest queued tasks fire when the tab goes foregrounded.
|
| @@ -2413,7 +2447,7 @@ TEST_F(RendererSchedulerImplTest, ResumeRenderer) {
|
| EnableIdleTasks();
|
| RunUntilIdle();
|
| EXPECT_THAT(run_order,
|
| - testing::ElementsAre(std::string("D1"), std::string("C1"),
|
| + testing::ElementsAre(std::string("C1"), std::string("D1"),
|
| std::string("I1")));
|
|
|
| // The rest queued tasks fire when the renderer is resumed.
|
| @@ -2431,7 +2465,7 @@ TEST_F(RendererSchedulerImplTest, ResumeRenderer) {
|
| EnableIdleTasks();
|
| RunUntilIdle();
|
| EXPECT_THAT(run_order,
|
| - testing::ElementsAre(std::string("D2"), std::string("C2"),
|
| + testing::ElementsAre(std::string("C2"), std::string("D2"),
|
| std::string("I2")));
|
|
|
| // The rest queued tasks fire when the renderer is resumed.
|
|
|