| George Keishing | 880f4e6 | 2017-04-20 01:10:17 -0500 | [diff] [blame] | 1 | *** Settings *** | 
|  | 2 | Documentation   This suite verifies the power restore policy supported by | 
|  | 3 | ...             REST Interfaces. | 
|  | 4 | ...             Refer here for documentation on the REST interfaces | 
|  | 5 | ...             https://github.com/openbmc/docs/blob/master/rest-api.md | 
|  | 6 |  | 
| George Keishing | 5611421 | 2019-07-22 02:27:42 -0500 | [diff] [blame] | 7 | Resource        ../../lib/rest_client.robot | 
|  | 8 | Resource        ../../lib/utils.robot | 
|  | 9 | Resource        ../../lib/openbmc_ffdc.robot | 
|  | 10 | Resource        ../../lib/state_manager.robot | 
|  | 11 | Resource        ../../lib/boot_utils.robot | 
| George Keishing | 69436a3 | 2019-08-09 01:53:08 -0500 | [diff] [blame] | 12 | Resource        ../../lib/bmc_redfish_resource.robot | 
|  | 13 | Resource        ../../lib/bmc_redfish_utils.robot | 
| aravinth0510 | 67b409b | 2022-07-13 10:41:26 +0000 | [diff] [blame] | 14 | Resource        ../../lib/pdu/pdu.robot | 
| George Keishing | 5611421 | 2019-07-22 02:27:42 -0500 | [diff] [blame] | 15 | Library         ../../lib/state_map.py | 
| George Keishing | 880f4e6 | 2017-04-20 01:10:17 -0500 | [diff] [blame] | 16 |  | 
| George Keishing | 62c8267 | 2017-12-06 04:39:46 -0600 | [diff] [blame] | 17 | Test Teardown   Test Teardown Execution | 
|  | 18 | Suite Teardown  Suite Teardown Execution | 
| George Keishing | 880f4e6 | 2017-04-20 01:10:17 -0500 | [diff] [blame] | 19 |  | 
| Matt Fischer | 6fb70d9 | 2023-10-24 19:06:33 -0600 | [diff] [blame] | 20 | Test Tags      Power_Restore | 
| George Keishing | 880f4e6 | 2017-04-20 01:10:17 -0500 | [diff] [blame] | 21 |  | 
| George Keishing | 880f4e6 | 2017-04-20 01:10:17 -0500 | [diff] [blame] | 22 |  | 
|  | 23 | *** Test Cases *** | 
|  | 24 |  | 
| George Keishing | 1c3a966 | 2017-08-11 10:16:36 -0500 | [diff] [blame] | 25 | Test Restore Policy ALWAYS_POWER_OFF With Host Off | 
| George Keishing | 1c3a966 | 2017-08-11 10:16:36 -0500 | [diff] [blame] | 26 | [Documentation]  Validate ALWAYS_POWER_OFF restore policy functionality. | 
| George Keishing | 880f4e6 | 2017-04-20 01:10:17 -0500 | [diff] [blame] | 27 | ...              Policy: | 
| George Keishing | 1c3a966 | 2017-08-11 10:16:36 -0500 | [diff] [blame] | 28 | ...                    System policy set to ALWAYS_POWER_OFF. | 
| George Keishing | 880f4e6 | 2017-04-20 01:10:17 -0500 | [diff] [blame] | 29 | ...              Initial Host State: | 
|  | 30 | ...                    State where system should be before running the | 
|  | 31 | ...                    test case. | 
|  | 32 | ...              Expected Host State: | 
|  | 33 | ...                    After BMC reset, system should reach this | 
|  | 34 | ...                    specific state. | 
| George Keishing | 1c3a966 | 2017-08-11 10:16:36 -0500 | [diff] [blame] | 35 | [Tags]  Test_Restore_Policy_ALWAYS_POWER_OFF_With_Host_Off | 
| George Keishing | 5abfe60 | 2018-07-05 11:54:37 -0500 | [diff] [blame] | 36 | [Template]  Verify Restore Policy | 
|  | 37 |  | 
|  | 38 | # Policy                Initial Host State     Expected Host State | 
| George Keishing | 90b555a | 2021-05-20 11:54:16 -0500 | [diff] [blame] | 39 | AlwaysOff               Off                    Off | 
| George Keishing | 5abfe60 | 2018-07-05 11:54:37 -0500 | [diff] [blame] | 40 |  | 
| George Keishing | 880f4e6 | 2017-04-20 01:10:17 -0500 | [diff] [blame] | 41 |  | 
|  | 42 |  | 
| George Keishing | 1c3a966 | 2017-08-11 10:16:36 -0500 | [diff] [blame] | 43 | Test Restore Policy ALWAYS_POWER_OFF With Host Running | 
| Joy Onyerikwu | f4a807b | 2018-06-20 08:43:54 -0500 | [diff] [blame] | 44 | [Documentation]  Verify that the BMC restore policy is ALWAYS_POWER_OFF while the Host is running. | 
| George Keishing | 1c3a966 | 2017-08-11 10:16:36 -0500 | [diff] [blame] | 45 | [Tags]  Test_Restore_Policy_ALWAYS_POWER_OFF_With_Host_Running | 
| George Keishing | 5abfe60 | 2018-07-05 11:54:37 -0500 | [diff] [blame] | 46 | [Template]  Verify Restore Policy | 
|  | 47 |  | 
|  | 48 | # Policy                Initial Host State     Expected Host State | 
| George Keishing | 90b555a | 2021-05-20 11:54:16 -0500 | [diff] [blame] | 49 | AlwaysOff               Running                Running | 
| George Keishing | 450a528 | 2017-05-05 03:13:37 -0500 | [diff] [blame] | 50 |  | 
|  | 51 |  | 
|  | 52 | Test Restore Policy ALWAYS_POWER_ON With Host Off | 
| George Keishing | 880f4e6 | 2017-04-20 01:10:17 -0500 | [diff] [blame] | 53 | [Documentation]  Validate ALWAYS_POWER_ON restore policy functionality. | 
|  | 54 | ...              Policy: | 
| George Keishing | 1c3a966 | 2017-08-11 10:16:36 -0500 | [diff] [blame] | 55 | ...                    System policy set to ALWAYS_POWER_OFF. | 
| George Keishing | 880f4e6 | 2017-04-20 01:10:17 -0500 | [diff] [blame] | 56 | ...              Initial Host State: | 
|  | 57 | ...                    State where system should be before running the | 
|  | 58 | ...                    test case. | 
|  | 59 | ...              Expected Host State: | 
|  | 60 | ...                    After BMC reset, system should reach this | 
|  | 61 | ...                    specific state. | 
| George Keishing | 450a528 | 2017-05-05 03:13:37 -0500 | [diff] [blame] | 62 | [Tags]  Test_Restore_Policy_ALWAYS_POWER_ON_With_Host_Off | 
| George Keishing | 5abfe60 | 2018-07-05 11:54:37 -0500 | [diff] [blame] | 63 | [Template]  Verify Restore Policy | 
|  | 64 |  | 
|  | 65 | # Policy                Initial Host State     Expected Host State | 
| George Keishing | 90b555a | 2021-05-20 11:54:16 -0500 | [diff] [blame] | 66 | AlwaysOn                Off                    Running | 
| George Keishing | 5abfe60 | 2018-07-05 11:54:37 -0500 | [diff] [blame] | 67 |  | 
| George Keishing | 880f4e6 | 2017-04-20 01:10:17 -0500 | [diff] [blame] | 68 |  | 
|  | 69 |  | 
| George Keishing | 450a528 | 2017-05-05 03:13:37 -0500 | [diff] [blame] | 70 | Test Restore Policy ALWAYS_POWER_ON With Host Running | 
| George Keishing | 5abfe60 | 2018-07-05 11:54:37 -0500 | [diff] [blame] | 71 | [Documentation]  Verify the BMC restore policy is ALWAYS_POWER_ON while the Host is running. | 
|  | 72 | [Tags]  Test_Restore_Policy_ALWAYS_POWER_ON_With_Host_Running | 
|  | 73 | [Template]  Verify Restore Policy | 
| George Keishing | 880f4e6 | 2017-04-20 01:10:17 -0500 | [diff] [blame] | 74 |  | 
| George Keishing | 5abfe60 | 2018-07-05 11:54:37 -0500 | [diff] [blame] | 75 | # Policy                Initial Host State     Expected Host State | 
| George Keishing | 90b555a | 2021-05-20 11:54:16 -0500 | [diff] [blame] | 76 | AlwaysOn                Running                Running | 
| George Keishing | 450a528 | 2017-05-05 03:13:37 -0500 | [diff] [blame] | 77 |  | 
| George Keishing | 450a528 | 2017-05-05 03:13:37 -0500 | [diff] [blame] | 78 |  | 
|  | 79 |  | 
| Rahul Maheshwari | f049959 | 2017-05-10 01:55:59 -0500 | [diff] [blame] | 80 | Test Restore Policy Restore Last State With Host Running | 
| George Keishing | 880f4e6 | 2017-04-20 01:10:17 -0500 | [diff] [blame] | 81 | [Documentation]  Validate RESTORE_LAST_STATE restore policy functionality. | 
|  | 82 | ...              Policy: | 
|  | 83 | ...                    System policy set to RESTORE_LAST_STATE. | 
|  | 84 | ...              Initial Host State: | 
|  | 85 | ...                    State where system should be before running the | 
|  | 86 | ...                    test case. | 
|  | 87 | ...              Expected Host State: | 
|  | 88 | ...                    After BMC reset, system should reach this | 
|  | 89 | ...                    specific state. | 
| Rahul Maheshwari | f049959 | 2017-05-10 01:55:59 -0500 | [diff] [blame] | 90 | [Tags]  Test_Restore_Policy_Restore_Last_State_With_Host_Running | 
| George Keishing | 5abfe60 | 2018-07-05 11:54:37 -0500 | [diff] [blame] | 91 | [Template]  Verify Restore Policy | 
|  | 92 |  | 
|  | 93 | # Policy                Initial Host State     Expected Host State | 
| George Keishing | 90b555a | 2021-05-20 11:54:16 -0500 | [diff] [blame] | 94 | LastState               Running                Running | 
| George Keishing | 5abfe60 | 2018-07-05 11:54:37 -0500 | [diff] [blame] | 95 |  | 
| George Keishing | 450a528 | 2017-05-05 03:13:37 -0500 | [diff] [blame] | 96 |  | 
|  | 97 |  | 
| Rahul Maheshwari | f049959 | 2017-05-10 01:55:59 -0500 | [diff] [blame] | 98 | Test Restore Policy Restore Last State With Host Off | 
| Joy Onyerikwu | f4a807b | 2018-06-20 08:43:54 -0500 | [diff] [blame] | 99 | [Documentation]  Verify the RESTORE_LAST_STATE restore policy functionality while the Host is off. | 
| Rahul Maheshwari | f049959 | 2017-05-10 01:55:59 -0500 | [diff] [blame] | 100 | [Tags]  Test_Restore_Policy_Restore_Last_State_With_Host_Off | 
| George Keishing | 5abfe60 | 2018-07-05 11:54:37 -0500 | [diff] [blame] | 101 | [Template]  Verify Restore Policy | 
|  | 102 |  | 
|  | 103 | # Policy                Initial Host State     Expected Host State | 
| George Keishing | 90b555a | 2021-05-20 11:54:16 -0500 | [diff] [blame] | 104 | LastState               Off                    Off | 
| George Keishing | 450a528 | 2017-05-05 03:13:37 -0500 | [diff] [blame] | 105 |  | 
| George Keishing | 880f4e6 | 2017-04-20 01:10:17 -0500 | [diff] [blame] | 106 |  | 
|  | 107 | *** Keywords *** | 
|  | 108 |  | 
|  | 109 | Verify Restore Policy | 
|  | 110 | [Documentation]  Set given policy, reset BMC and expect specified end | 
|  | 111 | ...              state. | 
|  | 112 | [Arguments]  ${policy}  ${expectedState}  ${nextState} | 
|  | 113 |  | 
|  | 114 | # Description of argument(s): | 
|  | 115 | # policy           System policy state string. | 
|  | 116 | # expectedState    Test initial host state. | 
|  | 117 | # nextState        Test end host state. | 
|  | 118 |  | 
| George Keishing | d45aae5 | 2017-12-11 09:38:37 -0600 | [diff] [blame] | 119 | Set Initial Test State  ${expectedState} | 
| George Keishing | 880f4e6 | 2017-04-20 01:10:17 -0500 | [diff] [blame] | 120 |  | 
| George Keishing | 90b555a | 2021-05-20 11:54:16 -0500 | [diff] [blame] | 121 | Redfish Set Power Restore Policy  ${policy} | 
| George Keishing | 69436a3 | 2019-08-09 01:53:08 -0500 | [diff] [blame] | 122 |  | 
| aravinth0510 | 67b409b | 2022-07-13 10:41:26 +0000 | [diff] [blame] | 123 | PDU Power Cycle | 
| George Keishing | 90b555a | 2021-05-20 11:54:16 -0500 | [diff] [blame] | 124 | Sleep  20s | 
|  | 125 | Wait For BMC Online | 
| George Keishing | 880f4e6 | 2017-04-20 01:10:17 -0500 | [diff] [blame] | 126 |  | 
|  | 127 | Wait Until Keyword Succeeds | 
| George Keishing | 69436a3 | 2019-08-09 01:53:08 -0500 | [diff] [blame] | 128 | ...  10 min  20 sec  Valid Boot States  ${nextState} | 
| George Keishing | d45aae5 | 2017-12-11 09:38:37 -0600 | [diff] [blame] | 129 |  | 
|  | 130 |  | 
|  | 131 | Valid Boot States | 
|  | 132 | [Documentation]  Verify boot states for a given system state. | 
|  | 133 | [Arguments]  ${sys_state} | 
|  | 134 |  | 
|  | 135 | # Description of argument(s): | 
|  | 136 | # sys_state    system state list | 
| George Keishing | b95aba2 | 2017-12-13 07:59:23 -0600 | [diff] [blame] | 137 | #              (e.g. "Off", "On", "Reboot", etc.). | 
| George Keishing | d45aae5 | 2017-12-11 09:38:37 -0600 | [diff] [blame] | 138 |  | 
| George Keishing | 90b555a | 2021-05-20 11:54:16 -0500 | [diff] [blame] | 139 | ${current_state}=  Redfish Get States | 
|  | 140 | Redfish Valid Boot State  ${sys_state}  ${current_state} | 
| George Keishing | 880f4e6 | 2017-04-20 01:10:17 -0500 | [diff] [blame] | 141 |  | 
|  | 142 |  | 
|  | 143 | Set Initial Test State | 
|  | 144 | [Documentation]  Poweron if ON expected, Poweroff if OFF expected | 
|  | 145 | ...              to initial state of the test. | 
|  | 146 |  | 
|  | 147 | [Arguments]  ${expectedState} | 
|  | 148 | # Description of argument(s): | 
|  | 149 | # expectedState    Test initial host state. | 
|  | 150 |  | 
| George Keishing | 9e1a30e | 2021-05-25 23:15:41 -0500 | [diff] [blame] | 151 | Redfish.Login | 
|  | 152 |  | 
| George Keishing | 7dc4847 | 2025-05-07 20:23:47 +0530 | [diff] [blame] | 153 | IF  '${expectedState}' == 'Running' | 
|  | 154 | Redfish Power On  stack_mode=skip | 
|  | 155 | END | 
| George Keishing | 880f4e6 | 2017-04-20 01:10:17 -0500 | [diff] [blame] | 156 |  | 
| George Keishing | 7dc4847 | 2025-05-07 20:23:47 +0530 | [diff] [blame] | 157 | IF  '${expectedState}' == 'Off' | 
|  | 158 | Redfish Power Off  stack_mode=skip | 
|  | 159 | END | 
| George Keishing | 69436a3 | 2019-08-09 01:53:08 -0500 | [diff] [blame] | 160 |  | 
| George Keishing | 880f4e6 | 2017-04-20 01:10:17 -0500 | [diff] [blame] | 161 |  | 
| George Keishing | 62c8267 | 2017-12-06 04:39:46 -0600 | [diff] [blame] | 162 | Test Teardown Execution | 
| George Keishing | 0ef6ece | 2017-05-05 02:57:16 -0500 | [diff] [blame] | 163 | [Documentation]  Do the post test teardown. | 
|  | 164 | # 1. Capture FFDC on test failure. | 
|  | 165 | # 2. Close all open SSH connections. | 
|  | 166 |  | 
|  | 167 | FFDC On Test Case Fail | 
|  | 168 | Close All Connections | 
|  | 169 |  | 
|  | 170 |  | 
| George Keishing | 62c8267 | 2017-12-06 04:39:46 -0600 | [diff] [blame] | 171 | Suite Teardown Execution | 
| George Keishing | 0ef6ece | 2017-05-05 02:57:16 -0500 | [diff] [blame] | 172 | [Documentation]  Do the post suite teardown. | 
|  | 173 | # 1. Set policy to default. | 
|  | 174 |  | 
| George Keishing | 90b555a | 2021-05-20 11:54:16 -0500 | [diff] [blame] | 175 | Run Keyword And Ignore Error  Redfish Set Power Restore Policy  AlwaysOff | 
| George Keishing | 69436a3 | 2019-08-09 01:53:08 -0500 | [diff] [blame] | 176 | Redfish.Logout | 
| George Keishing | 0ef6ece | 2017-05-05 02:57:16 -0500 | [diff] [blame] | 177 |  | 
| George Keishing | 90b555a | 2021-05-20 11:54:16 -0500 | [diff] [blame] | 178 |  | 
|  | 179 | Wait For BMC Online | 
|  | 180 | [Documentation]  Wait for Host to be online. Checks every X seconds | 
|  | 181 | ...              interval for Y minutes and fails if timed out. | 
|  | 182 | ...              Default MAX timedout is 10 min, interval 10 seconds. | 
|  | 183 | [Arguments]      ${max_timeout}=${OPENBMC_REBOOT_TIMEOUT} min | 
|  | 184 | ...              ${interval}=10 sec | 
|  | 185 |  | 
|  | 186 | # Description of argument(s): | 
|  | 187 | # max_timeout   Maximum time to wait. | 
|  | 188 | #               This should be expressed in Robot Framework's time format | 
|  | 189 | #               (e.g. "10 minutes"). | 
|  | 190 | # interval      Interval to wait between status checks. | 
|  | 191 | #               This should be expressed in Robot Framework's time format | 
|  | 192 | #               (e.g. "5 seconds"). | 
|  | 193 |  | 
|  | 194 | Wait Until Keyword Succeeds | 
|  | 195 | ...   ${max_timeout}  ${interval}  Verify Ping SSH And Redfish Authentication |