OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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 // This file tests the chrome.alarms extension API. | 5 // This file tests the chrome.alarms extension API. |
6 | 6 |
7 #include "base/test/mock_time_provider.h" | 7 #include "base/test/mock_time_provider.h" |
8 #include "base/values.h" | 8 #include "base/values.h" |
9 #include "chrome/browser/extensions/api/alarms/alarm_manager.h" | 9 #include "chrome/browser/extensions/api/alarms/alarm_manager.h" |
10 #include "chrome/browser/extensions/api/alarms/alarms_api.h" | 10 #include "chrome/browser/extensions/api/alarms/alarms_api.h" |
(...skipping 40 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
51 | 51 |
52 TestExtensionSystem* system = static_cast<TestExtensionSystem*>( | 52 TestExtensionSystem* system = static_cast<TestExtensionSystem*>( |
53 ExtensionSystem::Get(browser()->profile())); | 53 ExtensionSystem::Get(browser()->profile())); |
54 system->CreateAlarmManager(&base::MockTimeProvider::StaticNow); | 54 system->CreateAlarmManager(&base::MockTimeProvider::StaticNow); |
55 alarm_manager_ = system->alarm_manager(); | 55 alarm_manager_ = system->alarm_manager(); |
56 | 56 |
57 alarm_delegate_ = new AlarmDelegate(); | 57 alarm_delegate_ = new AlarmDelegate(); |
58 alarm_manager_->set_delegate(alarm_delegate_); | 58 alarm_manager_->set_delegate(alarm_delegate_); |
59 | 59 |
60 extension_ = utils::CreateEmptyExtensionWithLocation( | 60 extension_ = utils::CreateEmptyExtensionWithLocation( |
61 extensions::Extension::LOAD); | 61 extensions::Manifest::LOAD); |
62 | 62 |
63 // Make sure there's a RenderViewHost for alarms to warn into. | 63 // Make sure there's a RenderViewHost for alarms to warn into. |
64 AddTab(browser(), extension_->GetBackgroundURL()); | 64 AddTab(browser(), extension_->GetBackgroundURL()); |
65 contents_ = browser()->tab_strip_model()->GetActiveWebContents(); | 65 contents_ = browser()->tab_strip_model()->GetActiveWebContents(); |
66 | 66 |
67 current_time_ = base::Time::FromDoubleT(10); | 67 current_time_ = base::Time::FromDoubleT(10); |
68 ON_CALL(mock_time_, Now()) | 68 ON_CALL(mock_time_, Now()) |
69 .WillByDefault(testing::ReturnPointee(¤t_time_)); | 69 .WillByDefault(testing::ReturnPointee(¤t_time_)); |
70 } | 70 } |
71 | 71 |
(...skipping 412 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
484 alarm_manager_->AddAlarmImpl(extension_->id(), alarm3); | 484 alarm_manager_->AddAlarmImpl(extension_->id(), alarm3); |
485 MessageLoop::current()->Run(); | 485 MessageLoop::current()->Run(); |
486 EXPECT_EQ(alarm_manager_->last_poll_time_ + base::TimeDelta::FromMinutes(4), | 486 EXPECT_EQ(alarm_manager_->last_poll_time_ + base::TimeDelta::FromMinutes(4), |
487 alarm_manager_->next_poll_time_); | 487 alarm_manager_->next_poll_time_); |
488 alarm_manager_->RemoveAllAlarms(extension_->id()); | 488 alarm_manager_->RemoveAllAlarms(extension_->id()); |
489 } | 489 } |
490 } | 490 } |
491 | 491 |
492 TEST_F(ExtensionAlarmsSchedulingTest, ReleasedExtensionPollsInfrequently) { | 492 TEST_F(ExtensionAlarmsSchedulingTest, ReleasedExtensionPollsInfrequently) { |
493 extension_ = utils::CreateEmptyExtensionWithLocation( | 493 extension_ = utils::CreateEmptyExtensionWithLocation( |
494 extensions::Extension::INTERNAL); | 494 extensions::Manifest::INTERNAL); |
495 current_time_ = base::Time::FromJsTime(300000); | 495 current_time_ = base::Time::FromJsTime(300000); |
496 CreateAlarm("[\"a\", {\"when\": 300010}]"); | 496 CreateAlarm("[\"a\", {\"when\": 300010}]"); |
497 CreateAlarm("[\"b\", {\"when\": 340000}]"); | 497 CreateAlarm("[\"b\", {\"when\": 340000}]"); |
498 | 498 |
499 // On startup (when there's no "last poll"), we let alarms fire as | 499 // On startup (when there's no "last poll"), we let alarms fire as |
500 // soon as they're scheduled. | 500 // soon as they're scheduled. |
501 EXPECT_DOUBLE_EQ(300010, alarm_manager_->next_poll_time_.ToJsTime()); | 501 EXPECT_DOUBLE_EQ(300010, alarm_manager_->next_poll_time_.ToJsTime()); |
502 | 502 |
503 alarm_manager_->last_poll_time_ = base::Time::FromJsTime(290000); | 503 alarm_manager_->last_poll_time_ = base::Time::FromJsTime(290000); |
504 // In released extensions, we set the granularity to at least 5 | 504 // In released extensions, we set the granularity to at least 5 |
(...skipping 11 matching lines...) Expand all Loading... |
516 EXPECT_TRUE(alarm_manager_->timer_.IsRunning()); | 516 EXPECT_TRUE(alarm_manager_->timer_.IsRunning()); |
517 MessageLoop::current()->Run(); | 517 MessageLoop::current()->Run(); |
518 EXPECT_FALSE(alarm_manager_->timer_.IsRunning()); | 518 EXPECT_FALSE(alarm_manager_->timer_.IsRunning()); |
519 CreateAlarm("[\"bb\", {\"delayInMinutes\": 10}]"); | 519 CreateAlarm("[\"bb\", {\"delayInMinutes\": 10}]"); |
520 EXPECT_TRUE(alarm_manager_->timer_.IsRunning()); | 520 EXPECT_TRUE(alarm_manager_->timer_.IsRunning()); |
521 alarm_manager_->RemoveAllAlarms(extension_->id()); | 521 alarm_manager_->RemoveAllAlarms(extension_->id()); |
522 EXPECT_FALSE(alarm_manager_->timer_.IsRunning()); | 522 EXPECT_FALSE(alarm_manager_->timer_.IsRunning()); |
523 } | 523 } |
524 | 524 |
525 } // namespace extensions | 525 } // namespace extensions |
OLD | NEW |