/* * Copyright (c) 2021-2024 Huawei Device Co., Ltd. * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #include #include #include #include #include #include #include #include #include #include "common_event_manager.h" #include "ipower_mode_callback.h" #include "power_common.h" #include "power_mgr_client.h" #include "power_mgr_powersavemode_test.h" #include "power_mgr_service.h" #include "power_state_machine.h" #include "power_state_machine_info.h" #include "running_lock.h" #include "running_lock_info.h" using namespace testing::ext; using namespace OHOS::PowerMgr; using namespace OHOS::EventFwk; using namespace OHOS; using namespace std; namespace { std::condition_variable g_cv; std::mutex g_mtx; std::string g_action = ""; constexpr int64_t TIME_OUT = 1; } // namespace static uint32_t g_i = 0; static int g_judgeNum = 2; void PowerMgrPowerSavemodeTest::PowerModeTest1Callback::OnPowerModeChanged(PowerMode mode) { POWER_HILOGI(LABEL_TEST, "PowerModeTest1Callback::OnPowerModeChanged."); } void PowerMgrPowerSavemodeTest::SetUpTestCase(void) { auto pms = DelayedSpSingleton::GetInstance(); pms->OnStart(); SystemAbility::MakeAndRegisterAbility(pms.GetRefPtr()); } namespace { /** * @tc.name: PowerSavemode_001 * @tc.desc: test SetDeviceMode in proxy * @tc.type: FUNC * @tc.require: issueI5MJZJ */ HWTEST_F(PowerMgrPowerSavemodeTest, PowerSavemode_001, TestSize.Level2) { GTEST_LOG_(INFO) << "PowerSavemode_001: SetDeviceMode start."; POWER_HILOGI(LABEL_TEST, "PowerSavemode_001 function start!"); auto& powerMgrClient = PowerMgrClient::GetInstance(); PowerMode modeFirst = PowerMode::POWER_SAVE_MODE; PowerMode modeSecond = PowerMode::POWER_SAVE_MODE; powerMgrClient.SetDeviceMode(modeFirst); modeFirst = powerMgrClient.GetDeviceMode(); EXPECT_EQ(modeFirst, modeSecond) << "PowerSavemode_001 fail to SetDeviceMode"; POWER_HILOGI(LABEL_TEST, "PowerSavemode_001 function end!"); GTEST_LOG_(INFO) << "PowerSavemode_001: SetDeviceMode end."; } /** * @tc.name: PowerSavemode_002 * @tc.desc: test SetDeviceMode in proxy * @tc.type: FUNC * @tc.require: issueI5MJZJ */ HWTEST_F(PowerMgrPowerSavemodeTest, PowerSavemode_002, TestSize.Level2) { GTEST_LOG_(INFO) << "PowerSavemode_002: SetDeviceMode start."; POWER_HILOGI(LABEL_TEST, "PowerSavemode_002 function start!"); auto& powerMgrClient = PowerMgrClient::GetInstance(); PowerMode modeFirst = PowerMode::PERFORMANCE_MODE; PowerMode modeSecond = PowerMode::PERFORMANCE_MODE; powerMgrClient.SetDeviceMode(modeFirst); modeFirst = powerMgrClient.GetDeviceMode(); EXPECT_EQ(modeFirst, modeSecond) << "PowerSavemode_002 fail to SetDeviceMode"; POWER_HILOGI(LABEL_TEST, "PowerSavemode_002 function end!"); GTEST_LOG_(INFO) << "PowerSavemode_002: SetDeviceMode end."; } /** * @tc.name: PowerSavemode_003 * @tc.desc: test SetDeviceMode in proxy * @tc.type: FUNC * @tc.require: issueI5MJZJ */ HWTEST_F(PowerMgrPowerSavemodeTest, PowerSavemode_003, TestSize.Level2) { GTEST_LOG_(INFO) << "PowerSavemode_003: SetDeviceMode start."; POWER_HILOGI(LABEL_TEST, "PowerSavemode_003 function start!"); int PARM_ONE = 1; auto& powerMgrClient = PowerMgrClient::GetInstance(); PowerMode modeFirst = static_cast(PARM_ONE); // modeFirst equal to 1 PowerMode modeSecond = static_cast(PARM_ONE); powerMgrClient.SetDeviceMode(modeFirst); modeFirst = powerMgrClient.GetDeviceMode(); EXPECT_NE(modeFirst, modeSecond) << "PowerSavemode_003 fail to SetDeviceMode abnormal"; POWER_HILOGI(LABEL_TEST, "PowerSavemode_003 function end!"); GTEST_LOG_(INFO) << "PowerSavemode_003: SetDeviceMode end."; } /** * @tc.name: PowerSavemode_004 * @tc.desc: test GetDeviceMode in proxy * @tc.type: FUNC * @tc.require: issueI5MJZJ */ HWTEST_F(PowerMgrPowerSavemodeTest, PowerSavemode_004, TestSize.Level2) { GTEST_LOG_(INFO) << "PowerSavemode_004: GetDeviceMode start."; POWER_HILOGI(LABEL_TEST, "PowerSavemode_004 function start!"); int PARM_ZERO = 0; auto& powerMgrClient = PowerMgrClient::GetInstance(); PowerMode modeFirst = static_cast(PARM_ZERO); PowerMode modeSecond = PowerMode::POWER_SAVE_MODE; modeFirst = powerMgrClient.GetDeviceMode(); EXPECT_NE(modeFirst, modeSecond) << "PowerSavemode_004 fail to GetDeviceMode"; POWER_HILOGI(LABEL_TEST, "PowerSavemode_004 function end!"); GTEST_LOG_(INFO) << "PowerSavemode_004: GetDeviceMode end."; } /** * @tc.name: PowerSavemode_005 * @tc.desc: test GetDeviceMode in proxy * @tc.type: FUNC * @tc.require: issueI5MJZJ */ HWTEST_F(PowerMgrPowerSavemodeTest, PowerSavemode_005, TestSize.Level2) { GTEST_LOG_(INFO) << "PowerSavemode_005: GetDeviceMode start."; POWER_HILOGI(LABEL_TEST, "PowerSavemode_005 function start!"); auto& powerMgrClient = PowerMgrClient::GetInstance(); PowerMode modeFirst = PowerMode::POWER_SAVE_MODE; PowerMode modeSecond = PowerMode::POWER_SAVE_MODE; powerMgrClient.SetDeviceMode(modeFirst); for (int i = 0; i < 100; i++) { modeFirst = powerMgrClient.GetDeviceMode(); } EXPECT_EQ(modeFirst, modeSecond) << "PowerSavemode_005 fail to GetDeviceMode"; POWER_HILOGI(LABEL_TEST, "PowerSavemode_005 function end!"); GTEST_LOG_(INFO) << "PowerSavemode_005: GetDeviceMode end."; } /** * @tc.name: PowerSavemode_006 * @tc.desc: test PowerModeCallback * @tc.type: FUNC * @tc.require: issueI5MJZJ */ HWTEST_F(PowerMgrPowerSavemodeTest, PowerSavemode_006, TestSize.Level1) { GTEST_LOG_(INFO) << "PowerSavemode_006: RegisterPowerModeCallback start."; POWER_HILOGI(LABEL_TEST, "PowerSavemode_006 function start!"); auto& powerMgrClient = PowerMgrClient::GetInstance(); const sptr callBack = new PowerModeTest1Callback(); powerMgrClient.RegisterPowerModeCallback(callBack); PowerMode modeFirst = PowerMode::POWER_SAVE_MODE; PowerMode modeSecond = PowerMode::POWER_SAVE_MODE; powerMgrClient.SetDeviceMode(modeFirst); modeFirst = powerMgrClient.GetDeviceMode(); EXPECT_EQ(modeFirst, modeSecond) << "PowerSavemode_006 fail to PowerModeCallback"; POWER_HILOGI(LABEL_TEST, "PowerSavemode_006 function end!"); GTEST_LOG_(INFO) << "PowerSavemode_006: RegisterPowerModeCallback end."; } /** * @tc.name: PowerSavemode_007 * @tc.desc: test PowerModeCallback * @tc.type: FUNC * @tc.require: issueI5MJZJ */ HWTEST_F(PowerMgrPowerSavemodeTest, PowerSavemode_007, TestSize.Level1) { GTEST_LOG_(INFO) << "PowerSavemode_007: RegisterPowerModeCallback start."; POWER_HILOGI(LABEL_TEST, "PowerSavemode_007 function start!"); int PARM_ONE = 1; auto& powerMgrClient = PowerMgrClient::GetInstance(); const sptr callBack = new PowerModeTest1Callback(); powerMgrClient.RegisterPowerModeCallback(callBack); PowerMode modeFirst = static_cast(PARM_ONE); PowerMode modeSecond = static_cast(PARM_ONE); powerMgrClient.SetDeviceMode(modeFirst); modeFirst = powerMgrClient.GetDeviceMode(); EXPECT_NE(modeFirst, modeSecond) << "PowerSavemode_007 fail to PowerModeCallback"; POWER_HILOGI(LABEL_TEST, "PowerSavemode_007 function end!"); GTEST_LOG_(INFO) << "PowerSavemode_007: RegisterPowerModeCallback end."; } /** * @tc.name: PowerSavemode_008 * @tc.desc: test PowerModeCallback * @tc.type: FUNC * @tc.require: issueI5MJZJ */ HWTEST_F(PowerMgrPowerSavemodeTest, PowerSavemode_008, TestSize.Level1) { GTEST_LOG_(INFO) << "PowerSavemode_008: RegisterPowerModeCallback start."; POWER_HILOGI(LABEL_TEST, "PowerSavemode_008 function start!"); auto& powerMgrClient = PowerMgrClient::GetInstance(); const sptr callBack = new PowerModeTest1Callback(); for (int i = 0; i < 100; i++) { powerMgrClient.RegisterPowerModeCallback(callBack); } PowerMode modeFirst = PowerMode::POWER_SAVE_MODE; PowerMode modeSecond = PowerMode::POWER_SAVE_MODE; powerMgrClient.SetDeviceMode(modeFirst); modeFirst = powerMgrClient.GetDeviceMode(); EXPECT_EQ(modeFirst, modeSecond) << "PowerSavemode_008 fail to PowerModeCallback"; POWER_HILOGI(LABEL_TEST, "PowerSavemode_008 function end!"); GTEST_LOG_(INFO) << "PowerSavemode_008: RegisterPowerModeCallback end."; } /** * @tc.name: PowerSavemode_009 * @tc.desc: test PowerModeCallback * @tc.type: FUNC * @tc.require: issueI5MJZJ */ HWTEST_F(PowerMgrPowerSavemodeTest, PowerSavemode_009, TestSize.Level1) { GTEST_LOG_(INFO) << "PowerSavemode_009: UnRegisterPowerModeCallback start."; POWER_HILOGI(LABEL_TEST, "PowerSavemode_009 function start!"); auto& powerMgrClient = PowerMgrClient::GetInstance(); const sptr callBack = new PowerModeTest1Callback(); powerMgrClient.UnRegisterPowerModeCallback(callBack); PowerMode modeFirst = PowerMode::POWER_SAVE_MODE; PowerMode modeSecond = PowerMode::POWER_SAVE_MODE; powerMgrClient.SetDeviceMode(modeFirst); modeFirst = powerMgrClient.GetDeviceMode(); EXPECT_EQ(modeFirst, modeSecond) << "PowerSavemode_009 fail to PowerModeCallback"; POWER_HILOGI(LABEL_TEST, "PowerSavemode_009 function end!"); GTEST_LOG_(INFO) << "PowerSavemode_009: UnRegisterPowerModeCallback end."; } /** * @tc.name: PowerSavemode_010 * @tc.desc: test PowerModeCallback * @tc.type: FUNC * @tc.require: issueI5MJZJ */ HWTEST_F(PowerMgrPowerSavemodeTest, PowerSavemode_010, TestSize.Level1) { GTEST_LOG_(INFO) << "PowerSavemode_010: UnRegisterPowerModeCallback start."; POWER_HILOGI(LABEL_TEST, "PowerSavemode_010 function start!"); int PARM_ONE = 1; auto& powerMgrClient = PowerMgrClient::GetInstance(); const sptr callBack = new PowerModeTest1Callback(); powerMgrClient.UnRegisterPowerModeCallback(callBack); PowerMode modeFirst = static_cast(PARM_ONE); PowerMode modeSecond = static_cast(PARM_ONE); powerMgrClient.SetDeviceMode(modeFirst); modeFirst = powerMgrClient.GetDeviceMode(); EXPECT_NE(modeFirst, modeSecond) << "PowerSavemode_010 fail to PowerModeCallback"; POWER_HILOGI(LABEL_TEST, "PowerSavemode_010 function end!"); GTEST_LOG_(INFO) << "PowerSavemode_010: UnRegisterPowerModeCallback end."; } /** * @tc.name: PowerSavemode_011 * @tc.desc: test PowerModeCallback * @tc.type: FUNC * @tc.require: issueI5MJZJ */ HWTEST_F(PowerMgrPowerSavemodeTest, PowerSavemode_011, TestSize.Level1) { GTEST_LOG_(INFO) << "PowerSavemode_011: UnRegisterPowerModeCallback start."; POWER_HILOGI(LABEL_TEST, "PowerSavemode_011 function start!"); auto& powerMgrClient = PowerMgrClient::GetInstance(); const sptr callBack = new PowerModeTest1Callback(); for (int i = 0; i < 100; i++) { powerMgrClient.UnRegisterPowerModeCallback(callBack); } PowerMode modeFirst = PowerMode::POWER_SAVE_MODE; PowerMode modeSecond = PowerMode::POWER_SAVE_MODE; powerMgrClient.SetDeviceMode(modeFirst); modeFirst = powerMgrClient.GetDeviceMode(); EXPECT_EQ(modeFirst, modeSecond) << "PowerSavemode_011 fail to PowerModeCallback"; POWER_HILOGI(LABEL_TEST, "PowerSavemode_011 function end!"); GTEST_LOG_(INFO) << "PowerSavemode_011: UnRegisterPowerModeCallback end."; } /** * @tc.name: PowerSavemode_012 * @tc.desc: test SetDeviceMode in proxy * @tc.type: FUNC * @tc.require: issueI5MJZJ */ HWTEST_F(PowerMgrPowerSavemodeTest, PowerSavemode_012, TestSize.Level2) { GTEST_LOG_(INFO) << "PowerSavemode_012: SetDeviceMode start."; POWER_HILOGI(LABEL_TEST, "PowerSavemode_012 function start!"); auto& powerMgrClient = PowerMgrClient::GetInstance(); PowerMode modeFirst = PowerMode::CUSTOM_POWER_SAVE_MODE; PowerMode modeSecond = PowerMode::CUSTOM_POWER_SAVE_MODE; powerMgrClient.SetDeviceMode(modeFirst); modeFirst = powerMgrClient.GetDeviceMode(); EXPECT_EQ(modeFirst, modeSecond) << "PowerSavemode_012 fail to SetDeviceMode"; POWER_HILOGI(LABEL_TEST, "PowerSavemode_012 function end!"); GTEST_LOG_(INFO) << "PowerSavemode_012: SetDeviceMode end."; } /** * @tc.name: PowerSavemode_013 * @tc.desc: test SetDeviceMode in proxy * @tc.type: FUNC * @tc.require: issueI5MJZJ */ HWTEST_F(PowerMgrPowerSavemodeTest, PowerSavemode_013, TestSize.Level2) { GTEST_LOG_(INFO) << "PowerSavemode_013: SetDeviceMode start."; POWER_HILOGI(LABEL_TEST, "PowerSavemode_013 function start!"); int PARM_ONE = 606; auto& powerMgrClient = PowerMgrClient::GetInstance(); const sptr callBack = new PowerModeTest1Callback(); powerMgrClient.UnRegisterPowerModeCallback(callBack); PowerMode modeFirst = static_cast(PARM_ONE); PowerMode modeSecond = static_cast(PARM_ONE); powerMgrClient.SetDeviceMode(modeFirst); modeFirst = powerMgrClient.GetDeviceMode(); EXPECT_NE(modeFirst, modeSecond) << "PowerSavemode_013 fail to PowerModeCallback"; POWER_HILOGI(LABEL_TEST, "PowerSavemode_013 function end!"); GTEST_LOG_(INFO) << "PowerSavemode_013: SetDeviceMode end."; } /** * @tc.name: PowerSavemode_014 * @tc.desc: test SetDeviceMode in proxy * @tc.type: FUNC * @tc.require: issueI5MJZJ */ HWTEST_F(PowerMgrPowerSavemodeTest, PowerSavemode_014, TestSize.Level2) { GTEST_LOG_(INFO) << "PowerSavemode_014: SetDeviceMode start."; POWER_HILOGI(LABEL_TEST, "PowerSavemode_014 function start!"); auto& powerMgrClient = PowerMgrClient::GetInstance(); PowerMode modeFirst = PowerMode::EXTREME_POWER_SAVE_MODE; PowerMode modeSecond = PowerMode::EXTREME_POWER_SAVE_MODE; powerMgrClient.SetDeviceMode(modeFirst); modeFirst = powerMgrClient.GetDeviceMode(); PowerMode normalMode = PowerMode::NORMAL_MODE; // Depends on the battery capacity EXPECT_TRUE(modeFirst == modeSecond || modeFirst == normalMode) << "PowerSavemode_014 fail to SetDeviceMode"; POWER_HILOGI(LABEL_TEST, "PowerSavemode_014 function end!"); GTEST_LOG_(INFO) << "PowerSavemode_014: SetDeviceMode end."; } /** * @tc.name: PowerSavemode_015 * @tc.desc: test SetDeviceMode in proxy * @tc.type: FUNC * @tc.require: issueI5MJZJ */ HWTEST_F(PowerMgrPowerSavemodeTest, PowerSavemode_015, TestSize.Level2) { GTEST_LOG_(INFO) << "PowerSavemode_015: SetDeviceMode start."; POWER_HILOGI(LABEL_TEST, "PowerSavemode_015 function start!"); auto& powerMgrClient = PowerMgrClient::GetInstance(); PowerMode modeFirst = PowerMode::EXTREME_POWER_SAVE_MODE; PowerMode modeSecond = PowerMode::EXTREME_POWER_SAVE_MODE; for (int i = 0; i < 100; i++) { powerMgrClient.SetDeviceMode(modeFirst); } modeFirst = powerMgrClient.GetDeviceMode(); PowerMode normalMode = PowerMode::NORMAL_MODE; // Depends on the battery capacity EXPECT_TRUE(modeFirst == modeSecond || modeFirst == normalMode) << "PowerSavemode_015 fail to SetDeviceMode"; POWER_HILOGI(LABEL_TEST, "PowerSavemode_015 function end!"); GTEST_LOG_(INFO) << "PowerSavemode_015: SetDeviceMode end."; } } // namespace