blob: 74d43aaf76726b4f149d5ffdc4bd538d6c92cb01 [file] [log] [blame]
Carol Wang4ca6f3f2020-02-19 16:28:59 +08001#include "scheduled_host_transition.hpp"
2
Carol Wang4ca6f3f2020-02-19 16:28:59 +08003#include <sdbusplus/bus.hpp>
4#include <sdbusplus/test/sdbus_mock.hpp>
Carol Wang6a5db3d2020-02-21 10:12:01 +08005#include <sdeventplus/event.hpp>
Carol Wang4ca6f3f2020-02-19 16:28:59 +08006#include <xyz/openbmc_project/ScheduledTime/error.hpp>
7
Andrew Geisslere426b582020-05-28 12:40:55 -05008#include <gmock/gmock.h>
9#include <gtest/gtest.h>
10
Carol Wang4ca6f3f2020-02-19 16:28:59 +080011namespace phosphor
12{
13namespace state
14{
15namespace manager
16{
17
18using namespace std::chrono;
19using InvalidTimeError =
20 sdbusplus::xyz::openbmc_project::ScheduledTime::Error::InvalidTime;
Carol Wangef7abe12020-02-25 16:19:34 +080021using HostTransition =
Patrick Williams7e969cb2023-08-23 16:24:23 -050022 sdbusplus::server::xyz::openbmc_project::state::ScheduledHostTransition;
Carol Wang4ca6f3f2020-02-19 16:28:59 +080023
24class TestScheduledHostTransition : public testing::Test
25{
26 public:
Carol Wang6a5db3d2020-02-21 10:12:01 +080027 sdeventplus::Event event;
Carol Wang4ca6f3f2020-02-19 16:28:59 +080028 sdbusplus::SdBusMock sdbusMock;
Patrick Williamsf053e6f2022-07-22 19:26:54 -050029 sdbusplus::bus_t mockedBus = sdbusplus::get_mocked_new(&sdbusMock);
Carol Wang4ca6f3f2020-02-19 16:28:59 +080030 ScheduledHostTransition scheduledHostTransition;
31
Carol Wang6a5db3d2020-02-21 10:12:01 +080032 TestScheduledHostTransition() :
33 event(sdeventplus::Event::get_default()),
Patrick Williams211d9722022-04-07 21:24:33 -050034 scheduledHostTransition(mockedBus, "", 0, event)
Carol Wang4ca6f3f2020-02-19 16:28:59 +080035 {
36 // Empty
37 }
38
39 seconds getCurrentTime()
40 {
41 return scheduledHostTransition.getTime();
42 }
Carol Wang6a5db3d2020-02-21 10:12:01 +080043
44 bool isTimerEnabled()
45 {
46 return scheduledHostTransition.timer.isEnabled();
47 }
Carol Wangef7abe12020-02-25 16:19:34 +080048
49 void bmcTimeChange()
50 {
51 scheduledHostTransition.handleTimeUpdates();
52 }
Carol Wang4ca6f3f2020-02-19 16:28:59 +080053};
54
55TEST_F(TestScheduledHostTransition, disableHostTransition)
56{
57 EXPECT_EQ(scheduledHostTransition.scheduledTime(0), 0);
Carol Wang6a5db3d2020-02-21 10:12:01 +080058 EXPECT_FALSE(isTimerEnabled());
Carol Wang4ca6f3f2020-02-19 16:28:59 +080059}
60
61TEST_F(TestScheduledHostTransition, invalidScheduledTime)
62{
63 // scheduled time is 1 min earlier than current time
64 uint64_t schTime =
65 static_cast<uint64_t>((getCurrentTime() - seconds(60)).count());
66 EXPECT_THROW(scheduledHostTransition.scheduledTime(schTime),
67 InvalidTimeError);
68}
69
Carol Wang6a5db3d2020-02-21 10:12:01 +080070TEST_F(TestScheduledHostTransition, validScheduledTime)
71{
72 // scheduled time is 1 min later than current time
73 uint64_t schTime =
74 static_cast<uint64_t>((getCurrentTime() + seconds(60)).count());
75 EXPECT_EQ(scheduledHostTransition.scheduledTime(schTime), schTime);
76 EXPECT_TRUE(isTimerEnabled());
77}
78
79TEST_F(TestScheduledHostTransition, hostTransitionStatus)
80{
81 // set requested transition to be on
82 scheduledHostTransition.scheduledTransition(Transition::On);
83 EXPECT_EQ(scheduledHostTransition.scheduledTransition(), Transition::On);
84 // set requested transition to be off
85 scheduledHostTransition.scheduledTransition(Transition::Off);
86 EXPECT_EQ(scheduledHostTransition.scheduledTransition(), Transition::Off);
87}
88
Carol Wangef7abe12020-02-25 16:19:34 +080089TEST_F(TestScheduledHostTransition, bmcTimeChangeWithDisabledHostTransition)
90{
91 // Disable host transition
92 scheduledHostTransition.scheduledTime(0);
93 bmcTimeChange();
94 // Check timer
95 EXPECT_FALSE(isTimerEnabled());
96 // Check scheduled time
97 EXPECT_EQ(scheduledHostTransition.HostTransition::scheduledTime(), 0);
98}
99
100TEST_F(TestScheduledHostTransition, bmcTimeChangeBackward)
101{
102 // Current time is earlier than scheduled time due to BMC time changing
103 uint64_t schTime =
104 static_cast<uint64_t>((getCurrentTime() + seconds(60)).count());
105 // Set scheduled time, which is the same as bmc time is changed.
106 // But can't use this method to write another case like
107 // bmcTimeChangeForward, because set a scheduled time earlier than current
108 // time will throw an error.
109 scheduledHostTransition.scheduledTime(schTime);
110 bmcTimeChange();
111 // Check timer
112 EXPECT_TRUE(isTimerEnabled());
113}
114
Carol Wang4ca6f3f2020-02-19 16:28:59 +0800115} // namespace manager
116} // namespace state
117} // namespace phosphor