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

Side by Side Diff: components/scheduler/base/task_queue_manager_perftest.cc

Issue 1424053002: Adds a flag to support "Virtual Time" to the blink scheduler (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Rebased Created 5 years, 1 month 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/base/task_queue_manager.h" 5 #include "components/scheduler/base/task_queue_manager.h"
6 6
7 #include "base/bind.h" 7 #include "base/bind.h"
8 #include "base/threading/thread.h" 8 #include "base/threading/thread.h"
9 #include "components/scheduler/base/nestable_task_runner_for_test.h" 9 #include "base/time/default_tick_clock.h"
10 #include "components/scheduler/base/task_queue_impl.h" 10 #include "components/scheduler/base/task_queue_impl.h"
11 #include "components/scheduler/base/task_queue_manager_delegate_for_test.h"
11 #include "components/scheduler/base/task_queue_selector.h" 12 #include "components/scheduler/base/task_queue_selector.h"
12 #include "components/scheduler/base/task_queue_sets.h" 13 #include "components/scheduler/base/task_queue_sets.h"
13 #include "testing/gtest/include/gtest/gtest.h" 14 #include "testing/gtest/include/gtest/gtest.h"
14 #include "testing/perf/perf_test.h" 15 #include "testing/perf/perf_test.h"
15 16
16 namespace scheduler { 17 namespace scheduler {
17 18
18 class TaskQueueManagerPerfTest : public testing::Test { 19 class TaskQueueManagerPerfTest : public testing::Test {
19 public: 20 public:
20 TaskQueueManagerPerfTest() 21 TaskQueueManagerPerfTest()
21 : num_queues_(0), 22 : num_queues_(0),
22 max_tasks_in_flight_(0), 23 max_tasks_in_flight_(0),
23 num_tasks_in_flight_(0), 24 num_tasks_in_flight_(0),
24 num_tasks_to_post_(0), 25 num_tasks_to_post_(0),
25 num_tasks_to_run_(0) {} 26 num_tasks_to_run_(0) {}
26 27
27 void SetUp() override { 28 void SetUp() override {
28 if (base::ThreadTicks::IsSupported()) 29 if (base::ThreadTicks::IsSupported())
29 base::ThreadTicks::WaitUntilInitialized(); 30 base::ThreadTicks::WaitUntilInitialized();
30 } 31 }
31 32
32 void Initialize(size_t num_queues) { 33 void Initialize(size_t num_queues) {
33 num_queues_ = num_queues; 34 num_queues_ = num_queues;
34 message_loop_.reset(new base::MessageLoop()); 35 message_loop_.reset(new base::MessageLoop());
35 manager_ = make_scoped_ptr(new TaskQueueManager( 36 manager_ = make_scoped_ptr(new TaskQueueManager(
36 NestableTaskRunnerForTest::Create(message_loop_->task_runner()), 37 TaskQueueManagerDelegateForTest::Create(
38 message_loop_->task_runner(),
39 make_scoped_ptr(new base::DefaultTickClock())),
37 "fake.category", "fake.category", "fake.category.debug")); 40 "fake.category", "fake.category", "fake.category.debug"));
38 for (size_t i = 0; i < num_queues; i++) 41 for (size_t i = 0; i < num_queues; i++)
39 queues_.push_back(manager_->NewTaskQueue(TaskQueue::Spec("test"))); 42 queues_.push_back(manager_->NewTaskQueue(TaskQueue::Spec("test")));
40 } 43 }
41 44
42 void TestDelayedTask() { 45 void TestDelayedTask() {
43 if (--num_tasks_to_run_ == 0) { 46 if (--num_tasks_to_run_ == 0) {
44 message_loop_->QuitWhenIdle(); 47 message_loop_->QuitWhenIdle();
45 } 48 }
46 49
(...skipping 90 matching lines...) Expand 10 before | Expand all | Expand 10 after
137 max_tasks_in_flight_ = 200; 140 max_tasks_in_flight_ = 200;
138 Benchmark("run 10000 delayed tasks with eight queues", 141 Benchmark("run 10000 delayed tasks with eight queues",
139 base::Bind(&TaskQueueManagerPerfTest::ResetAndCallTestDelayedTask, 142 base::Bind(&TaskQueueManagerPerfTest::ResetAndCallTestDelayedTask,
140 base::Unretained(this), 10000)); 143 base::Unretained(this), 10000));
141 } 144 }
142 145
143 // TODO(alexclarke): Add additional tests with different mixes of non-delayed vs 146 // TODO(alexclarke): Add additional tests with different mixes of non-delayed vs
144 // delayed tasks. 147 // delayed tasks.
145 148
146 } // namespace scheduler 149 } // namespace scheduler
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698