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

Side by Side Diff: components/scheduler/renderer/web_view_scheduler_impl_unittest.cc

Issue 1441073006: Move throttling of background timers into the renderer scheduler (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Last few changes Sami requested Created 5 years 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 "components/scheduler/renderer/web_view_scheduler_impl.h" 5 #include "components/scheduler/renderer/web_view_scheduler_impl.h"
6 6
7 #include "base/callback.h" 7 #include "base/callback.h"
8 #include "base/memory/scoped_ptr.h" 8 #include "base/memory/scoped_ptr.h"
9 #include "base/test/simple_test_tick_clock.h" 9 #include "base/test/simple_test_tick_clock.h"
10 #include "cc/test/ordered_simple_task_runner.h" 10 #include "cc/test/ordered_simple_task_runner.h"
11 #include "components/scheduler/base/test_time_source.h" 11 #include "components/scheduler/base/test_time_source.h"
12 #include "components/scheduler/child/scheduler_tqm_delegate_for_test.h" 12 #include "components/scheduler/child/scheduler_tqm_delegate_for_test.h"
13 #include "components/scheduler/renderer/renderer_scheduler_impl.h" 13 #include "components/scheduler/renderer/renderer_scheduler_impl.h"
14 #include "components/scheduler/renderer/web_frame_scheduler_impl.h" 14 #include "components/scheduler/renderer/web_frame_scheduler_impl.h"
15 #include "testing/gtest/include/gtest/gtest.h" 15 #include "testing/gtest/include/gtest/gtest.h"
16 #include "third_party/WebKit/public/platform/WebTaskRunner.h"
17 #include "third_party/WebKit/public/platform/WebTraceLocation.h"
16 18
17 namespace scheduler { 19 namespace scheduler {
18 20
19 class WebViewSchedulerImplTest : public testing::Test { 21 class WebViewSchedulerImplTest : public testing::Test {
20 public: 22 public:
21 WebViewSchedulerImplTest() {} 23 WebViewSchedulerImplTest() {}
22 ~WebViewSchedulerImplTest() override {} 24 ~WebViewSchedulerImplTest() override {}
23 25
24 void SetUp() override { 26 void SetUp() override {
25 clock_.reset(new base::SimpleTestTickClock()); 27 clock_.reset(new base::SimpleTestTickClock());
26 clock_->Advance(base::TimeDelta::FromMicroseconds(5000)); 28 clock_->Advance(base::TimeDelta::FromMicroseconds(5000));
27 mock_task_runner_ = make_scoped_refptr( 29 mock_task_runner_ =
28 new cc::OrderedSimpleTaskRunner(clock_.get(), false)); 30 make_scoped_refptr(new cc::OrderedSimpleTaskRunner(clock_.get(), true));
29 main_task_runner_ = SchedulerTqmDelegateForTest::Create( 31 delagate_ = SchedulerTqmDelegateForTest::Create(
30 mock_task_runner_, make_scoped_ptr(new TestTimeSource(clock_.get()))); 32 mock_task_runner_, make_scoped_ptr(new TestTimeSource(clock_.get())));
31 scheduler_.reset(new RendererSchedulerImpl(main_task_runner_)); 33 scheduler_.reset(new RendererSchedulerImpl(delagate_));
32 web_view_scheduler_.reset( 34 web_view_scheduler_.reset(
33 new WebViewSchedulerImpl(nullptr, scheduler_.get())); 35 new WebViewSchedulerImpl(nullptr, scheduler_.get()));
36 web_frame_scheduler_ = web_view_scheduler_->createWebFrameSchedulerImpl();
34 } 37 }
35 38
36 void TearDown() override { scheduler_->Shutdown(); } 39 void TearDown() override {
40 web_frame_scheduler_.reset();
41 web_view_scheduler_.reset();
42 scheduler_->Shutdown();
43 scheduler_.reset();
44 }
37 45
38 scoped_ptr<base::SimpleTestTickClock> clock_; 46 scoped_ptr<base::SimpleTestTickClock> clock_;
39 scoped_refptr<cc::OrderedSimpleTaskRunner> mock_task_runner_; 47 scoped_refptr<cc::OrderedSimpleTaskRunner> mock_task_runner_;
40 scoped_refptr<SchedulerTqmDelegate> main_task_runner_; 48 scoped_refptr<SchedulerTqmDelegate> delagate_;
41 scoped_ptr<RendererSchedulerImpl> scheduler_; 49 scoped_ptr<RendererSchedulerImpl> scheduler_;
42 scoped_ptr<WebViewSchedulerImpl> web_view_scheduler_; 50 scoped_ptr<WebViewSchedulerImpl> web_view_scheduler_;
51 scoped_ptr<WebFrameSchedulerImpl> web_frame_scheduler_;
43 }; 52 };
44 53
45 TEST_F(WebViewSchedulerImplTest, TestDestructionOfFrameSchedulersBefore) { 54 TEST_F(WebViewSchedulerImplTest, TestDestructionOfFrameSchedulersBefore) {
46 blink::WebPassOwnPtr<blink::WebFrameScheduler> frame1( 55 blink::WebPassOwnPtr<blink::WebFrameScheduler> frame1(
47 web_view_scheduler_->createFrameScheduler()); 56 web_view_scheduler_->createFrameScheduler());
48 blink::WebPassOwnPtr<blink::WebFrameScheduler> frame2( 57 blink::WebPassOwnPtr<blink::WebFrameScheduler> frame2(
49 web_view_scheduler_->createFrameScheduler()); 58 web_view_scheduler_->createFrameScheduler());
50 } 59 }
51 60
52 TEST_F(WebViewSchedulerImplTest, TestDestructionOfFrameSchedulersAfter) { 61 TEST_F(WebViewSchedulerImplTest, TestDestructionOfFrameSchedulersAfter) {
53 blink::WebPassOwnPtr<blink::WebFrameScheduler> frame1( 62 blink::WebPassOwnPtr<blink::WebFrameScheduler> frame1(
54 web_view_scheduler_->createFrameScheduler()); 63 web_view_scheduler_->createFrameScheduler());
55 blink::WebPassOwnPtr<blink::WebFrameScheduler> frame2( 64 blink::WebPassOwnPtr<blink::WebFrameScheduler> frame2(
56 web_view_scheduler_->createFrameScheduler()); 65 web_view_scheduler_->createFrameScheduler());
57 web_view_scheduler_.reset(); 66 web_view_scheduler_.reset();
58 } 67 }
59 68
69 namespace {
70 class RepeatingTask : public blink::WebTaskRunner::Task {
71 public:
72 RepeatingTask(blink::WebTaskRunner* web_task_runner, int* run_count)
73 : web_task_runner_(web_task_runner), run_count_(run_count) {}
74
75 ~RepeatingTask() override {}
76
77 void run() override {
78 (*run_count_)++;
79 web_task_runner_->postDelayedTask(
80 BLINK_FROM_HERE, new RepeatingTask(web_task_runner_, run_count_), 1.0);
81 }
82
83 private:
84 blink::WebTaskRunner* web_task_runner_; // NOT OWNED
85 int* run_count_; // NOT OWNED
86 };
87 } // namespace
88
89 TEST_F(WebViewSchedulerImplTest, RepeatingTimer_PageInForeground) {
90 web_view_scheduler_->setPageInBackground(false);
91
92 int run_count = 0;
93 web_frame_scheduler_->timerTaskRunner()->postDelayedTask(
94 BLINK_FROM_HERE,
95 new RepeatingTask(web_frame_scheduler_->timerTaskRunner(), &run_count),
96 1.0);
97
98 mock_task_runner_->RunForPeriod(base::TimeDelta::FromSeconds(1));
99 EXPECT_EQ(1000, run_count);
100 }
101
102 TEST_F(WebViewSchedulerImplTest, RepeatingTimer_PageInBackground) {
103 web_view_scheduler_->setPageInBackground(true);
104
105 int run_count = 0;
106 web_frame_scheduler_->timerTaskRunner()->postDelayedTask(
107 BLINK_FROM_HERE,
108 new RepeatingTask(web_frame_scheduler_->timerTaskRunner(), &run_count),
109 1.0);
110
111 mock_task_runner_->RunForPeriod(base::TimeDelta::FromSeconds(1));
112 EXPECT_EQ(1, run_count);
113 }
114
115 TEST_F(WebViewSchedulerImplTest, RepeatingLoadingTask_PageInBackground) {
116 web_view_scheduler_->setPageInBackground(true);
117
118 int run_count = 0;
119 web_frame_scheduler_->loadingTaskRunner()->postDelayedTask(
120 BLINK_FROM_HERE,
121 new RepeatingTask(web_frame_scheduler_->loadingTaskRunner(), &run_count),
122 1.0);
123
124 mock_task_runner_->RunForPeriod(base::TimeDelta::FromSeconds(1));
125 EXPECT_EQ(1000, run_count); // Loading tasks should not be throttled
126 }
127
128 TEST_F(WebViewSchedulerImplTest, RepeatingTimers_OneBackgroundOneForeground) {
129 scoped_ptr<WebViewSchedulerImpl> web_view_scheduler2(
130 new WebViewSchedulerImpl(nullptr, scheduler_.get()));
131 scoped_ptr<WebFrameSchedulerImpl> web_frame_scheduler2 =
132 web_view_scheduler2->createWebFrameSchedulerImpl();
133
134 web_view_scheduler_->setPageInBackground(false);
135 web_view_scheduler2->setPageInBackground(true);
136
137 int run_count1 = 0;
138 int run_count2 = 0;
139 web_frame_scheduler_->timerTaskRunner()->postDelayedTask(
140 BLINK_FROM_HERE,
141 new RepeatingTask(web_frame_scheduler_->timerTaskRunner(), &run_count1),
142 1.0);
143 web_frame_scheduler2->timerTaskRunner()->postDelayedTask(
144 BLINK_FROM_HERE,
145 new RepeatingTask(web_frame_scheduler2->timerTaskRunner(), &run_count2),
146 1.0);
147
148 mock_task_runner_->RunForPeriod(base::TimeDelta::FromSeconds(1));
149 EXPECT_EQ(1000, run_count1);
150 EXPECT_EQ(1, run_count2);
151 }
152
60 } // namespace scheduler 153 } // namespace scheduler
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698