| OLD | NEW |
| 1 // Copyright (c) 2009 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2009 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 "chrome/common/worker_thread_ticker.h" | 5 #include "chrome/common/worker_thread_ticker.h" |
| 6 | 6 |
| 7 #include "base/message_loop.h" | 7 #include "base/message_loop.h" |
| 8 #include "base/threading/platform_thread.h" | 8 #include "base/threading/platform_thread.h" |
| 9 #include "testing/gtest/include/gtest/gtest.h" | 9 #include "testing/gtest/include/gtest/gtest.h" |
| 10 | 10 |
| 11 namespace { | 11 namespace { |
| 12 | 12 |
| 13 class TestCallback : public WorkerThreadTicker::Callback { | 13 class TestCallback : public WorkerThreadTicker::Callback { |
| 14 public: | 14 public: |
| 15 TestCallback() : counter_(0), message_loop_(MessageLoop::current()) { | 15 TestCallback() : counter_(0), message_loop_(MessageLoop::current()) { |
| 16 } | 16 } |
| 17 | 17 |
| 18 virtual void OnTick() { | 18 virtual void OnTick() { |
| 19 counter_++; | 19 counter_++; |
| 20 | 20 |
| 21 // Finish the test faster. | 21 // Finish the test faster. |
| 22 message_loop_->PostTask(FROM_HERE, new MessageLoop::QuitTask()); | 22 message_loop_->PostTask(FROM_HERE, MessageLoop::QuitClosure()); |
| 23 } | 23 } |
| 24 | 24 |
| 25 int counter() const { return counter_; } | 25 int counter() const { return counter_; } |
| 26 | 26 |
| 27 private: | 27 private: |
| 28 int counter_; | 28 int counter_; |
| 29 MessageLoop* message_loop_; | 29 MessageLoop* message_loop_; |
| 30 }; | 30 }; |
| 31 | 31 |
| 32 class LongCallback : public WorkerThreadTicker::Callback { | 32 class LongCallback : public WorkerThreadTicker::Callback { |
| 33 public: | 33 public: |
| 34 virtual void OnTick() { | 34 virtual void OnTick() { |
| 35 base::PlatformThread::Sleep(1500); | 35 base::PlatformThread::Sleep(1500); |
| 36 } | 36 } |
| 37 }; | 37 }; |
| 38 | 38 |
| 39 void RunMessageLoopForAWhile() { | 39 void RunMessageLoopForAWhile() { |
| 40 MessageLoop::current()->PostDelayedTask(FROM_HERE, | 40 MessageLoop::current()->PostDelayedTask(FROM_HERE, |
| 41 new MessageLoop::QuitTask(), 500); | 41 MessageLoop::QuitClosure(), 500); |
| 42 MessageLoop::current()->Run(); | 42 MessageLoop::current()->Run(); |
| 43 } | 43 } |
| 44 | 44 |
| 45 } // namespace | 45 } // namespace |
| 46 | 46 |
| 47 TEST(WorkerThreadTickerTest, Basic) { | 47 TEST(WorkerThreadTickerTest, Basic) { |
| 48 MessageLoop loop; | 48 MessageLoop loop; |
| 49 | 49 |
| 50 TestCallback callback; | 50 TestCallback callback; |
| 51 WorkerThreadTicker ticker(50); | 51 WorkerThreadTicker ticker(50); |
| (...skipping 47 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 99 TEST(WorkerThreadTickerTest, LongCallback) { | 99 TEST(WorkerThreadTickerTest, LongCallback) { |
| 100 MessageLoop loop; | 100 MessageLoop loop; |
| 101 | 101 |
| 102 LongCallback callback; | 102 LongCallback callback; |
| 103 WorkerThreadTicker ticker(50); | 103 WorkerThreadTicker ticker(50); |
| 104 ASSERT_TRUE(ticker.RegisterTickHandler(&callback)); | 104 ASSERT_TRUE(ticker.RegisterTickHandler(&callback)); |
| 105 | 105 |
| 106 ASSERT_TRUE(ticker.Start()); | 106 ASSERT_TRUE(ticker.Start()); |
| 107 RunMessageLoopForAWhile(); | 107 RunMessageLoopForAWhile(); |
| 108 } | 108 } |
| OLD | NEW |