blob: 981c85918480c661aafea7444450e70cde0a9fb6 [file] [log] [blame]
George Keishing880f4e62017-04-20 01:10:17 -05001*** Settings ***
2Documentation 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 Keishing56114212019-07-22 02:27:42 -05007Resource ../../lib/rest_client.robot
8Resource ../../lib/utils.robot
9Resource ../../lib/openbmc_ffdc.robot
10Resource ../../lib/state_manager.robot
11Resource ../../lib/boot_utils.robot
George Keishing69436a32019-08-09 01:53:08 -050012Resource ../../lib/bmc_redfish_resource.robot
13Resource ../../lib/bmc_redfish_utils.robot
George Keishing56114212019-07-22 02:27:42 -050014Library ../../lib/state_map.py
George Keishing880f4e62017-04-20 01:10:17 -050015
George Keishing62c82672017-12-06 04:39:46 -060016Test Teardown Test Teardown Execution
17Suite Teardown Suite Teardown Execution
George Keishing880f4e62017-04-20 01:10:17 -050018
19Force Tags power_restore
20
21*** Variables ***
22
23*** Test Cases ***
24
George Keishing1c3a9662017-08-11 10:16:36 -050025Test Restore Policy ALWAYS_POWER_OFF With Host Off
George Keishing1c3a9662017-08-11 10:16:36 -050026 [Documentation] Validate ALWAYS_POWER_OFF restore policy functionality.
George Keishing880f4e62017-04-20 01:10:17 -050027 ... Policy:
George Keishing1c3a9662017-08-11 10:16:36 -050028 ... System policy set to ALWAYS_POWER_OFF.
George Keishing880f4e62017-04-20 01:10:17 -050029 ... 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 Keishing1c3a9662017-08-11 10:16:36 -050035 [Tags] Test_Restore_Policy_ALWAYS_POWER_OFF_With_Host_Off
George Keishing5abfe602018-07-05 11:54:37 -050036 [Template] Verify Restore Policy
37
38 # Policy Initial Host State Expected Host State
39 ${ALWAYS_POWER_OFF} Off Off
40
George Keishing880f4e62017-04-20 01:10:17 -050041
42
George Keishing1c3a9662017-08-11 10:16:36 -050043Test Restore Policy ALWAYS_POWER_OFF With Host Running
Joy Onyerikwuf4a807b2018-06-20 08:43:54 -050044 [Documentation] Verify that the BMC restore policy is ALWAYS_POWER_OFF while the Host is running.
George Keishing1c3a9662017-08-11 10:16:36 -050045 [Tags] Test_Restore_Policy_ALWAYS_POWER_OFF_With_Host_Running
George Keishing5abfe602018-07-05 11:54:37 -050046 [Template] Verify Restore Policy
47
48 # Policy Initial Host State Expected Host State
49 ${ALWAYS_POWER_OFF} Running Running
George Keishing450a5282017-05-05 03:13:37 -050050
51
52Test Restore Policy ALWAYS_POWER_ON With Host Off
George Keishing880f4e62017-04-20 01:10:17 -050053 [Documentation] Validate ALWAYS_POWER_ON restore policy functionality.
54 ... Policy:
George Keishing1c3a9662017-08-11 10:16:36 -050055 ... System policy set to ALWAYS_POWER_OFF.
George Keishing880f4e62017-04-20 01:10:17 -050056 ... 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 Keishing450a5282017-05-05 03:13:37 -050062 [Tags] Test_Restore_Policy_ALWAYS_POWER_ON_With_Host_Off
George Keishing5abfe602018-07-05 11:54:37 -050063 [Template] Verify Restore Policy
64
65 # Policy Initial Host State Expected Host State
66 ${ALWAYS_POWER_ON} Off Running
67
George Keishing880f4e62017-04-20 01:10:17 -050068
69
George Keishing450a5282017-05-05 03:13:37 -050070Test Restore Policy ALWAYS_POWER_ON With Host Running
George Keishing5abfe602018-07-05 11:54:37 -050071 [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 Keishing880f4e62017-04-20 01:10:17 -050074
George Keishing5abfe602018-07-05 11:54:37 -050075 # Policy Initial Host State Expected Host State
George Keishing1c3a9662017-08-11 10:16:36 -050076 ${ALWAYS_POWER_ON} Running Running
George Keishing450a5282017-05-05 03:13:37 -050077
George Keishing450a5282017-05-05 03:13:37 -050078
79
Rahul Maheshwarif0499592017-05-10 01:55:59 -050080Test Restore Policy Restore Last State With Host Running
George Keishing880f4e62017-04-20 01:10:17 -050081 [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 Maheshwarif0499592017-05-10 01:55:59 -050090 [Tags] Test_Restore_Policy_Restore_Last_State_With_Host_Running
George Keishing5abfe602018-07-05 11:54:37 -050091 [Template] Verify Restore Policy
92
93 # Policy Initial Host State Expected Host State
94 ${RESTORE_LAST_STATE} Running Running
95
George Keishing450a5282017-05-05 03:13:37 -050096
97
Rahul Maheshwarif0499592017-05-10 01:55:59 -050098Test Restore Policy Restore Last State With Host Off
Joy Onyerikwuf4a807b2018-06-20 08:43:54 -050099 [Documentation] Verify the RESTORE_LAST_STATE restore policy functionality while the Host is off.
Rahul Maheshwarif0499592017-05-10 01:55:59 -0500100 [Tags] Test_Restore_Policy_Restore_Last_State_With_Host_Off
George Keishing5abfe602018-07-05 11:54:37 -0500101 [Template] Verify Restore Policy
102
103 # Policy Initial Host State Expected Host State
104 ${RESTORE_LAST_STATE} Off Off
George Keishing450a5282017-05-05 03:13:37 -0500105
George Keishing880f4e62017-04-20 01:10:17 -0500106
107*** Keywords ***
108
109Verify 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 Keishingd45aae52017-12-11 09:38:37 -0600119 Set Initial Test State ${expectedState}
George Keishing880f4e62017-04-20 01:10:17 -0500120
George Keishing69436a32019-08-09 01:53:08 -0500121 Set BMC Power Policy ${policy}
122
123 Redfish BMC Reset Operation
124 Check If BMC is Up
George Keishing880f4e62017-04-20 01:10:17 -0500125
126 Wait Until Keyword Succeeds
George Keishing69436a32019-08-09 01:53:08 -0500127 ... 10 min 20 sec Valid Boot States ${nextState}
George Keishingd45aae52017-12-11 09:38:37 -0600128
129
130Valid Boot States
131 [Documentation] Verify boot states for a given system state.
132 [Arguments] ${sys_state}
133
134 # Description of argument(s):
135 # sys_state system state list
George Keishingb95aba22017-12-13 07:59:23 -0600136 # (e.g. "Off", "On", "Reboot", etc.).
George Keishingd45aae52017-12-11 09:38:37 -0600137
138 ${current_state}= Get Boot State
George Keishingb95aba22017-12-13 07:59:23 -0600139 Valid Boot State ${sys_state} ${current_state}
George Keishing880f4e62017-04-20 01:10:17 -0500140
141
142Set Initial Test State
143 [Documentation] Poweron if ON expected, Poweroff if OFF expected
144 ... to initial state of the test.
145
146 [Arguments] ${expectedState}
147 # Description of argument(s):
148 # expectedState Test initial host state.
149
150 Run Keyword If '${expectedState}' == 'Running'
George Keishing69436a32019-08-09 01:53:08 -0500151 ... Redfish Power On stack_mode=skip
George Keishing880f4e62017-04-20 01:10:17 -0500152
153 Run Keyword If '${expectedState}' == 'Off'
George Keishing69436a32019-08-09 01:53:08 -0500154 ... Redfish Power Off stack_mode=skip
155
156 Redfish.Login
George Keishing880f4e62017-04-20 01:10:17 -0500157
158
George Keishing62c82672017-12-06 04:39:46 -0600159Test Teardown Execution
George Keishing0ef6ece2017-05-05 02:57:16 -0500160 [Documentation] Do the post test teardown.
161 # 1. Capture FFDC on test failure.
162 # 2. Close all open SSH connections.
163
164 FFDC On Test Case Fail
165 Close All Connections
George Keishing69436a32019-08-09 01:53:08 -0500166 Redfish.Login
George Keishing0ef6ece2017-05-05 02:57:16 -0500167
168
George Keishing62c82672017-12-06 04:39:46 -0600169Suite Teardown Execution
George Keishing0ef6ece2017-05-05 02:57:16 -0500170 [Documentation] Do the post suite teardown.
171 # 1. Set policy to default.
172
George Keishingefc3ff22017-12-12 11:49:25 -0600173 Run Keyword And Ignore Error Set BMC Power Policy ${ALWAYS_POWER_OFF}
George Keishing69436a32019-08-09 01:53:08 -0500174 Redfish.Logout
George Keishing0ef6ece2017-05-05 02:57:16 -0500175