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

Side by Side Diff: components/scheduler/child/nestable_task_runner_for_test.cc

Issue 1151353003: [scheduler]: Avoid waking up the scheduler to end long idle periods. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@end_idle_sync_2
Patch Set: Fix Win for realz hopefully... Created 5 years, 6 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 "components/scheduler/child/nestable_task_runner_for_test.h" 5 #include "components/scheduler/child/nestable_task_runner_for_test.h"
6 6
7 #include "base/bind.h"
8 #include "base/bind_helpers.h"
9
7 namespace scheduler { 10 namespace scheduler {
8 11
9 // static 12 // static
10 scoped_refptr<NestableTaskRunnerForTest> NestableTaskRunnerForTest::Create( 13 scoped_refptr<NestableTaskRunnerForTest> NestableTaskRunnerForTest::Create(
11 scoped_refptr<base::SingleThreadTaskRunner> task_runner) { 14 scoped_refptr<base::SingleThreadTaskRunner> task_runner) {
12 return make_scoped_refptr(new NestableTaskRunnerForTest(task_runner)); 15 return make_scoped_refptr(new NestableTaskRunnerForTest(task_runner));
13 } 16 }
14 17
15 NestableTaskRunnerForTest::NestableTaskRunnerForTest( 18 NestableTaskRunnerForTest::NestableTaskRunnerForTest(
16 scoped_refptr<base::SingleThreadTaskRunner> task_runner) 19 scoped_refptr<base::SingleThreadTaskRunner> task_runner)
17 : task_runner_(task_runner), is_nested_(false) { 20 : task_runner_(task_runner), is_nested_(false), weak_factory_(this) {
21 weak_nestable_task_runner_ptr_ = weak_factory_.GetWeakPtr();
18 } 22 }
19 23
20 NestableTaskRunnerForTest::~NestableTaskRunnerForTest() { 24 NestableTaskRunnerForTest::~NestableTaskRunnerForTest() {
21 } 25 }
22 26
27 void NestableTaskRunnerForTest::WrapTask(
28 const base::PendingTask* wrapped_task) {
29 scoped_refptr<NestableTaskRunnerForTest> protect(this);
30 FOR_EACH_OBSERVER(base::MessageLoop::TaskObserver, task_observers_,
31 DidProcessTask(*wrapped_task));
32 wrapped_task->task.Run();
33 FOR_EACH_OBSERVER(base::MessageLoop::TaskObserver, task_observers_,
34 WillProcessTask(*wrapped_task));
35 }
36
23 bool NestableTaskRunnerForTest::PostDelayedTask( 37 bool NestableTaskRunnerForTest::PostDelayedTask(
24 const tracked_objects::Location& from_here, 38 const tracked_objects::Location& from_here,
25 const base::Closure& task, 39 const base::Closure& task,
26 base::TimeDelta delay) { 40 base::TimeDelta delay) {
27 return task_runner_->PostDelayedTask(from_here, task, delay); 41 base::PendingTask* wrapped_task = new base::PendingTask(from_here, task);
42 return task_runner_->PostDelayedTask(
43 from_here,
44 base::Bind(&NestableTaskRunnerForTest::WrapTask,
45 weak_nestable_task_runner_ptr_, base::Owned(wrapped_task)),
46 delay);
28 } 47 }
29 48
30 bool NestableTaskRunnerForTest::PostNonNestableDelayedTask( 49 bool NestableTaskRunnerForTest::PostNonNestableDelayedTask(
31 const tracked_objects::Location& from_here, 50 const tracked_objects::Location& from_here,
32 const base::Closure& task, 51 const base::Closure& task,
33 base::TimeDelta delay) { 52 base::TimeDelta delay) {
34 return task_runner_->PostNonNestableDelayedTask(from_here, task, delay); 53 base::PendingTask* wrapped_task = new base::PendingTask(from_here, task);
54 return task_runner_->PostNonNestableDelayedTask(
55 from_here,
56 base::Bind(&NestableTaskRunnerForTest::WrapTask,
57 weak_nestable_task_runner_ptr_, base::Owned(wrapped_task)),
58 delay);
35 } 59 }
36 60
37 bool NestableTaskRunnerForTest::RunsTasksOnCurrentThread() const { 61 bool NestableTaskRunnerForTest::RunsTasksOnCurrentThread() const {
38 return task_runner_->RunsTasksOnCurrentThread(); 62 return task_runner_->RunsTasksOnCurrentThread();
39 } 63 }
40 64
41 bool NestableTaskRunnerForTest::IsNested() const { 65 bool NestableTaskRunnerForTest::IsNested() const {
42 return is_nested_; 66 return is_nested_;
43 } 67 }
44 68
45 void NestableTaskRunnerForTest::SetNested(bool is_nested) { 69 void NestableTaskRunnerForTest::SetNested(bool is_nested) {
46 is_nested_ = is_nested; 70 is_nested_ = is_nested;
47 } 71 }
48 72
49 void NestableTaskRunnerForTest::AddTaskObserver( 73 void NestableTaskRunnerForTest::AddTaskObserver(
50 base::MessageLoop::TaskObserver* task_observer) { 74 base::MessageLoop::TaskObserver* task_observer) {
75 task_observers_.AddObserver(task_observer);
51 } 76 }
52 77
53 void NestableTaskRunnerForTest::RemoveTaskObserver( 78 void NestableTaskRunnerForTest::RemoveTaskObserver(
54 base::MessageLoop::TaskObserver* task_observer) { 79 base::MessageLoop::TaskObserver* task_observer) {
80 task_observers_.RemoveObserver(task_observer);
55 } 81 }
56 82
57 } // namespace scheduler 83 } // namespace scheduler
OLDNEW
« no previous file with comments | « components/scheduler/child/nestable_task_runner_for_test.h ('k') | components/scheduler/child/null_idle_task_runner.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698