| Index: ash/system/chromeos/power/tray_power_unittest.cc
|
| diff --git a/ash/system/chromeos/power/tray_power_unittest.cc b/ash/system/chromeos/power/tray_power_unittest.cc
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..6fcadabad441836177b88985ebc9831882b44b45
|
| --- /dev/null
|
| +++ b/ash/system/chromeos/power/tray_power_unittest.cc
|
| @@ -0,0 +1,152 @@
|
| +// Copyright 2013 The Chromium Authors. All rights reserved.
|
| +// Use of this source code is governed by a BSD-style license that can be
|
| +// found in the LICENSE file.
|
| +
|
| +#include "ash/system/chromeos/power/tray_power.h"
|
| +
|
| +#include "ash/ash_switches.h"
|
| +#include "base/memory/scoped_ptr.h"
|
| +#include "testing/gtest/include/gtest/gtest.h"
|
| +#include "ui/message_center/fake_message_center.h"
|
| +
|
| +using chromeos::PowerSupplyStatus;
|
| +using message_center::Notification;
|
| +
|
| +namespace {
|
| +
|
| +class MockMessageCenter : public message_center::FakeMessageCenter {
|
| + public:
|
| + MockMessageCenter() : add_count_(0), remove_count_(0) {}
|
| + virtual ~MockMessageCenter() {}
|
| +
|
| + int add_count() const { return add_count_; }
|
| + int remove_count() const { return remove_count_; }
|
| +
|
| + // message_center::FakeMessageCenter overrides:
|
| + virtual void AddNotification(scoped_ptr<Notification> notification) OVERRIDE {
|
| + add_count_++;
|
| + }
|
| + virtual void RemoveNotification(const std::string& id, bool by_user)
|
| + OVERRIDE {
|
| + remove_count_++;
|
| + }
|
| +
|
| + private:
|
| + int add_count_;
|
| + int remove_count_;
|
| +
|
| + DISALLOW_COPY_AND_ASSIGN(MockMessageCenter);
|
| +};
|
| +
|
| +} // namespace
|
| +
|
| +namespace ash {
|
| +namespace internal {
|
| +
|
| +class TrayPowerTest : public testing::Test {
|
| + public:
|
| + TrayPowerTest() {}
|
| + virtual ~TrayPowerTest() {}
|
| +
|
| + MockMessageCenter* message_center() { return message_center_.get(); }
|
| + TrayPower* tray_power() { return tray_power_.get(); }
|
| +
|
| + // testing::Test overrides:
|
| + virtual void SetUp() OVERRIDE {
|
| + message_center_.reset(new MockMessageCenter());
|
| + tray_power_.reset(new TrayPower(NULL, message_center_.get()));
|
| + }
|
| +
|
| + TrayPower::NotificationState notification_state() const {
|
| + return tray_power_->notification_state_;
|
| + }
|
| +
|
| + bool MaybeShowUsbChargerNotification(const PowerSupplyStatus& old_status,
|
| + const PowerSupplyStatus& new_status) {
|
| + return tray_power_->MaybeShowUsbChargerNotification(old_status, new_status);
|
| + }
|
| +
|
| + bool UpdateNotificationState(const PowerSupplyStatus& status) {
|
| + return tray_power_->UpdateNotificationState(status);
|
| + }
|
| +
|
| + void SetLastPowerStatus(const PowerSupplyStatus& status) {
|
| + tray_power_->last_power_supply_status_ = status;
|
| + }
|
| +
|
| + // Returns a discharging PowerSupplyStatus more appropriate for testing.
|
| + static PowerSupplyStatus DefaultPowerSupplyStatus() {
|
| + PowerSupplyStatus status;
|
| + status.line_power_on = false;
|
| + status.battery_is_present = true;
|
| + status.battery_is_full = false;
|
| + status.battery_seconds_to_empty = 3 * 60 * 60;
|
| + status.battery_seconds_to_full = 2 * 60 * 60;
|
| + status.battery_percentage = 50.0;
|
| + status.is_calculating_battery_time = false;
|
| + status.battery_state = PowerSupplyStatus::DISCHARGING;
|
| + return status;
|
| + }
|
| +
|
| + private:
|
| + scoped_ptr<MockMessageCenter> message_center_;
|
| + scoped_ptr<TrayPower> tray_power_;
|
| +
|
| + DISALLOW_COPY_AND_ASSIGN(TrayPowerTest);
|
| +};
|
| +
|
| +TEST_F(TrayPowerTest, MaybeShowUsbChargerNotification) {
|
| + // Notification shows when connecting a USB charger.
|
| + PowerSupplyStatus discharging = DefaultPowerSupplyStatus();
|
| + PowerSupplyStatus usb_connected = DefaultPowerSupplyStatus();
|
| + usb_connected.line_power_on = true;
|
| + usb_connected.battery_state = PowerSupplyStatus::CONNECTED_TO_USB;
|
| + EXPECT_TRUE(MaybeShowUsbChargerNotification(discharging, usb_connected));
|
| + EXPECT_EQ(1, message_center()->add_count());
|
| +
|
| + // Change in charge does not trigger the notification again.
|
| + PowerSupplyStatus more_charge = DefaultPowerSupplyStatus();
|
| + more_charge.line_power_on = true;
|
| + more_charge.battery_seconds_to_full = 60 * 60;
|
| + more_charge.battery_percentage = 75.0;
|
| + more_charge.battery_state = PowerSupplyStatus::CONNECTED_TO_USB;
|
| + EXPECT_FALSE(MaybeShowUsbChargerNotification(usb_connected, more_charge));
|
| + EXPECT_EQ(1, message_center()->add_count());
|
| + EXPECT_EQ(0, message_center()->remove_count());
|
| +
|
| + // Disconnecting a USB charger with the notification showing should close
|
| + // the notification.
|
| + EXPECT_TRUE(MaybeShowUsbChargerNotification(usb_connected, discharging));
|
| + EXPECT_EQ(1, message_center()->remove_count());
|
| +}
|
| +
|
| +TEST_F(TrayPowerTest, UpdateNotificationState) {
|
| + // No notifications when no battery present.
|
| + PowerSupplyStatus no_battery = DefaultPowerSupplyStatus();
|
| + no_battery.battery_is_present = false;
|
| + EXPECT_FALSE(UpdateNotificationState(no_battery));
|
| + EXPECT_EQ(TrayPower::NOTIFICATION_NONE, notification_state());
|
| +
|
| + // No notification when calculating remaining battery time.
|
| + PowerSupplyStatus calculating = DefaultPowerSupplyStatus();
|
| + calculating.is_calculating_battery_time = true;
|
| + EXPECT_FALSE(UpdateNotificationState(calculating));
|
| + EXPECT_EQ(TrayPower::NOTIFICATION_NONE, notification_state());
|
| +
|
| + // No notification when charging.
|
| + PowerSupplyStatus charging = DefaultPowerSupplyStatus();
|
| + charging.line_power_on = true;
|
| + charging.battery_state = PowerSupplyStatus::CHARGING;
|
| + EXPECT_FALSE(UpdateNotificationState(charging));
|
| + EXPECT_EQ(TrayPower::NOTIFICATION_NONE, notification_state());
|
| +
|
| + // Critical low battery notification.
|
| + PowerSupplyStatus critical = DefaultPowerSupplyStatus();
|
| + critical.battery_seconds_to_empty = 60;
|
| + critical.battery_percentage = 2.0;
|
| + EXPECT_TRUE(UpdateNotificationState(critical));
|
| + EXPECT_EQ(TrayPower::NOTIFICATION_CRITICAL, notification_state());
|
| +}
|
| +
|
| +} // namespace internal
|
| +} // namespace ash
|
|
|