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. |