blob: 56c6985f62a9af81a7000b58467266cc09653ecf [file] [log] [blame]
Sushil Singh87dcee12019-08-07 13:13:13 -05001*** Settings ***
2Documentation Update the BMC code on a target BMC via Redifsh.
3
4# Test Parameters:
5# IMAGE_FILE_PATH The path to the BMC image file.
6#
7# Firmware update states:
8# Enabled Image is installed and either functional or active.
9# Disabled Image installation failed or ready for activation.
10# Updating Image installation currently in progress.
11
12Resource ../../lib/resource.robot
13Resource ../../lib/bmc_redfish_resource.robot
14Resource ../../lib/openbmc_ffdc.robot
15Resource ../../lib/common_utils.robot
16Resource ../../lib/code_update_utils.robot
17Resource ../../lib/redfish_code_update_utils.robot
Sushil Singh6624ce52020-01-22 00:53:41 -060018Resource ../../lib/utils.robot
Sushil Singh87dcee12019-08-07 13:13:13 -050019Library ../../lib/gen_robot_valid.py
20Library ../../lib/var_funcs.py
Sushil Singh8f48c8f2020-01-16 04:36:25 -060021Library ../../lib/gen_robot_keyword.py
Sushil Singh8469a482020-07-30 04:19:10 -050022Library ../../lib/code_update_utils.py
Sushil Singh87dcee12019-08-07 13:13:13 -050023
Sushil Singhb2162d82019-09-27 07:22:04 -050024Suite Setup Suite Setup Execution
25Suite Teardown Redfish.Logout
26Test Setup Printn
27Test Teardown FFDC On Test Case Fail
Sushil Singh87dcee12019-08-07 13:13:13 -050028
George Keishing7e854712021-03-17 13:18:10 -050029# Force the test to timedout to prevent test hanging.
George Keishing15d4b202023-11-20 11:35:38 +053030Test Timeout 45 minutes
George Keishing7e854712021-03-17 13:18:10 -050031
Matt Fischer6fb70d92023-10-24 19:06:33 -060032Test Tags Bmc_Code_Update
Sushil Singh87dcee12019-08-07 13:13:13 -050033
Sushil Singh65878cb2020-02-27 03:43:44 -060034*** Variables ***
35
George Keishing4d2c0052023-12-04 21:21:12 +053036${FORCE_UPDATE} ${0}
37${LOOP_COUNT} ${2}
38${DELETE_ERRLOGS} ${1}
39# Refer: https://github.com/open-power/guard
40${DELETE_OLD_GUARD_FILE} ${0}
Sushil Singh65878cb2020-02-27 03:43:44 -060041
George Keishing2e078ae2022-02-03 09:13:23 -060042${ACTIVATION_WAIT_TIMEOUT} 8 min
43
George Keishing57ab7cc2023-02-13 01:18:42 -060044# New code update path.
45${REDFISH_UPDATE_URI} /redfish/v1/UpdateService/update
46
Sushil Singh87dcee12019-08-07 13:13:13 -050047*** Test Cases ***
48
49Redfish BMC Code Update
50 [Documentation] Update the firmware image.
51 [Tags] Redfish_BMC_Code_Update
52
George Keishingaa027222021-11-17 06:37:57 -060053 # Python module: get_version_tar(tar_file_path)
54 ${image_version}= code_update_utils.Get Version Tar ${IMAGE_FILE_PATH}
Sushil Singh87dcee12019-08-07 13:13:13 -050055 Rprint Vars image_version
56
George Keishingaa027222021-11-17 06:37:57 -060057 # Python module: get_bmc_release_info()
58 ${bmc_release_info}= utils.Get BMC Release Info
George Keishingfedd5ce2020-07-24 02:25:08 -050059 ${functional_version}= Set Variable ${bmc_release_info['version_id']}
60 Rprint Vars functional_version
61
Sushil Singh76650912020-12-10 23:48:05 -060062 ${post_code_update_actions}= Get Post Boot Action
63 ${state}= Get Pre Reboot State
64 Rprint Vars state
65
George Keishing78903952020-07-24 07:04:53 -050066 # Check if the existing firmware is functional.
67 Pass Execution If '${functional_version}' == '${image_version}'
68 ... The existing ${image_version} firmware is already functional.
69
Sushil Singh76650912020-12-10 23:48:05 -060070 ${sw_inv}= Get Functional Firmware BMC image
71 ${nonfunctional_sw_inv}= Get Non Functional Firmware ${sw_inv} False
72
73 # Redfish active software image API.
Sridevi Rameshe54be142025-05-05 00:52:45 -050074 IF ${num_records} > 0
75 IF '${nonfunctional_sw_inv['version']}' == '${image_version}'
76 Set Backup Firmware To Functional ${image_version} ${state}
77 END
78 END
Sushil Singh52859242020-10-09 07:28:22 -050079
Sushil Singhaad1da22021-06-21 04:19:18 -050080 Print Timen Performing firmware update ${image_version}.
Sushil Singh52859242020-10-09 07:28:22 -050081
Sushil Singh87dcee12019-08-07 13:13:13 -050082 Redfish Update Firmware
83
Sushil Singh8469a482020-07-30 04:19:10 -050084
George Keishingb695a902022-05-11 09:26:21 -050085Redfish BMC Code Update Running And Backup Image With Same Firmware
86 [Documentation] Perform the firmware update with same image back to back, so that
87 ... the running (functional Image) and backup image (alternate image)
88 ... with same firmware.
89 [Tags] Redfish_BMC_Code_Update_Running_And_Backup_Image_With_Same_Firmware
90
91 # Python module: get_version_tar(tar_file_path)
92 ${image_version}= code_update_utils.Get Version Tar ${IMAGE_FILE_PATH}
93 Rprint Vars image_version
94
95 # Python module: get_bmc_release_info()
96 ${bmc_release_info}= utils.Get BMC Release Info
97 ${functional_version}= Set Variable ${bmc_release_info['version_id']}
98 Rprint Vars functional_version
99
100 # First update.
101 Print Timen Performing firmware update ${image_version}.
102 Redfish Update Firmware
103
104 # Second update.
105 Print Timen Performing firmware update ${image_version}.
106 Redfish Update Firmware
107
108
Sushil Singh8469a482020-07-30 04:19:10 -0500109Redfish Firmware Update Loop
George Keishing98cf8af2022-07-14 11:13:49 -0500110 [Documentation] Update the same firmware image in loop.
Sushil Singh8469a482020-07-30 04:19:10 -0500111 [Tags] Redfish_Firmware_Update_Loop
112 [Template] Redfish Firmware Update In Loop
George Keishing98cf8af2022-07-14 11:13:49 -0500113 [Timeout] NONE
114 # Override default 30 minutes, Disabling timeout with NONE explicitly
115 # else this test will fail for longer loop runs.
Sushil Singh8469a482020-07-30 04:19:10 -0500116
117 ${LOOP_COUNT}
118
119
Sushil Singh87dcee12019-08-07 13:13:13 -0500120*** Keywords ***
121
122Suite Setup Execution
123 [Documentation] Do the suite setup.
124
125 Redfish.Login
Sushil Singh87dcee12019-08-07 13:13:13 -0500126 # Delete BMC dump and Error logs.
George Keishingc1954452020-10-14 07:44:17 -0500127 Run Keyword And Ignore Error Redfish Delete All BMC Dumps
George Keishingcad841d2022-02-24 01:02:20 -0600128 Run Keyword If ${DELETE_ERRLOGS} == ${1}
129 ... Run Keyword And Ignore Error Redfish Purge Event Log
George Keishing4d2c0052023-12-04 21:21:12 +0530130 # To invalidate all the guard records.
131 Run Keyword If '${DELETE_OLD_GUARD_FILE}' == '${1}'
132 ... BMC Execute Command guard -I
133
Sushil Singh87dcee12019-08-07 13:13:13 -0500134 # Checking for file existence.
135 Valid File Path IMAGE_FILE_PATH
136
George Keishing57ab7cc2023-02-13 01:18:42 -0600137 # Check and set the update path.
138 # Old - /redfish/v1/UpdateService/
139 # New - /redfish/v1/UpdateService/update
140 ${resp}= Redfish.Get /redfish/v1/UpdateService/update
141 ... valid_status_codes=[${HTTP_OK},${HTTP_NOT_FOUND},${HTTP_METHOD_NOT_ALLOWED}]
142
143 # If the method is not found, set update URI to old method.
144 Run Keyword If ${resp.status} == ${HTTP_NOT_FOUND}
145 ... Set Suite Variable ${REDFISH_UPDATE_URI} /redfish/v1/UpdateService
146
147 Log To Console Update URI: ${REDFISH_UPDATE_URI}
148
George Keishing4574ec42021-10-06 11:45:33 -0500149 Redfish Power Off stack_mode=skip
150
Sushil Singh8469a482020-07-30 04:19:10 -0500151
152Redfish Firmware Update In Loop
153 [Documentation] Update the firmware in loop.
154 [Arguments] ${update_loop_count}
155
156 # Description of argument(s):
157 # update_loop_count This value is used to run the firmware update in loop.
158
George Keishing98cf8af2022-07-14 11:13:49 -0500159 # Python module: get_version_tar(tar_file_path)
160 ${image_version}= code_update_utils.Get Version Tar ${IMAGE_FILE_PATH}
161 Rprint Vars image_version
162
163 # Python module: get_bmc_release_info()
164 ${bmc_release_info}= utils.Get BMC Release Info
165 ${functional_version}= Set Variable ${bmc_release_info['version_id']}
166 Print Timen Starting firmware information:
167 Rprint Vars functional_version
168
Sushil Singh53c2dde2020-09-18 05:53:20 -0500169 ${temp_update_loop_count}= Evaluate ${update_loop_count} + 1
Sushil Singh8469a482020-07-30 04:19:10 -0500170
Sushil Singh53c2dde2020-09-18 05:53:20 -0500171 FOR ${count} IN RANGE 1 ${temp_update_loop_count}
George Keishing98cf8af2022-07-14 11:13:49 -0500172 Print Timen **************************************
173 Print Timen * The Current Loop Count is ${count} of ${update_loop_count} *
174 Print Timen **************************************
175 Print Timen Performing firmware update ${image_version}.
176 Redfish Update Firmware
Sushil Singh8469a482020-07-30 04:19:10 -0500177 END
178
Sushil Singh8469a482020-07-30 04:19:10 -0500179
Sushil Singh8469a482020-07-30 04:19:10 -0500180Delete BMC Image
181 [Documentation] Delete a BMC image from the BMC flash chip.
182
183 ${software_object}= Get Non Running BMC Software Object
184 Delete Image And Verify ${software_object} ${VERSION_PURPOSE_BMC}
185
186
Sushil Singh87dcee12019-08-07 13:13:13 -0500187Activate Existing Firmware
George Keishing16b3c7b2021-01-28 09:23:37 -0600188 [Documentation] Set firmware image to lower priority.
Sushil Singh87dcee12019-08-07 13:13:13 -0500189 [Arguments] ${image_version}
190
191 # Description of argument(s):
192 # image_version Version of image.
193
194 ${software_inventory_record}= Get Software Inventory State By Version
195 ... ${image_version}
196 ${num_keys}= Get Length ${software_inventory_record}
197
198 Rprint Vars software_inventory_record
199
200 # If no software inventory record was found, there is no existing
201 # firmware for the given version and therefore no action to be taken.
Sridevi Rameshe54be142025-05-05 00:52:45 -0500202 IF not ${num_keys} RETURN
Sushil Singh87dcee12019-08-07 13:13:13 -0500203
204 # Check if the existing firmware is functional.
205 Pass Execution If ${software_inventory_record['functional']}
206 ... The existing ${image_version} firmware is already functional.
207
208 # If existing firmware is not functional, then set the priority to least.
209 Print Timen The existing ${image_version} firmware is not yet functional.
210 Set BMC Image Priority To Least ${image_version} ${software_inventory_record}
211
212 Pass Execution The existing ${image_version} firmware is now functional.
213
214
215Get Image Priority
216 [Documentation] Get Current Image Priority.
217 [Arguments] ${image_version}
218
219 # Description of argument(s):
George Keishing16b3c7b2021-01-28 09:23:37 -0600220 # image_version The Firmware image version (e.g. 2.8.0-dev-1107-g512028d95).
Sushil Singh87dcee12019-08-07 13:13:13 -0500221
222 ${software_info}= Read Properties
223 ... ${SOFTWARE_VERSION_URI}/enumerate quiet=1
224 # Get only the record associated with our image_version.
225
226 ${software_info}= Filter Struct
227 ... ${software_info} [('Version', '${image_version}')]
228 # Convert from dict to list.
229 ${software_info}= Get Dictionary Values ${software_info}
230
George Keishing409df052024-01-17 22:36:14 +0530231 RETURN ${software_info[0]['Priority']}
Sushil Singh87dcee12019-08-07 13:13:13 -0500232
233
234Set BMC Image Priority To Least
235 [Documentation] Set BMC image priority to least value.
236 [Arguments] ${image_version} ${software_inventory}
237
238 # Description of argument(s):
George Keishing16b3c7b2021-01-28 09:23:37 -0600239 # image_version The Firmware image version (e.g. 2.8.0-dev-1107-g512028d95).
Sushil Singh87dcee12019-08-07 13:13:13 -0500240 # software_inventory Software inventory details.
241
242 ${least_priority}= Get Least Value Priority Image ${VERSION_PURPOSE_BMC}
243 ${cur_priority}= Get Image Priority ${image_version}
244 Rprint Vars least_priority cur_priority
245
Sridevi Rameshe54be142025-05-05 00:52:45 -0500246 IF '${least_priority}' == ${cur_priority} RETURN
247
Sushil Singh87dcee12019-08-07 13:13:13 -0500248 Set Host Software Property
249 ... ${SOFTWARE_VERSION_URI}${software_inventory['image_id']}
250 ... Priority ${least_priority}
251
Sushil Singh87dcee12019-08-07 13:13:13 -0500252 Redfish OBMC Reboot (off)
Sushil Singh87dcee12019-08-07 13:13:13 -0500253
254
Sushil Singhaad1da22021-06-21 04:19:18 -0500255Set Backup Firmware To Functional
256 [Documentation] Set the backup firmware to functional.
257 [Arguments] ${image_version} ${state}
258
259 # Description of argument(s):
260 # image_version Version of image.
261 # state Pre reboot state.
262
263 Print Timen Switch to back up and rebooting.
264 Switch Backup Firmware Image To Functional
265 Wait For Reboot start_boot_seconds=${state['epoch_seconds']}
266 Redfish Verify BMC Version ${IMAGE_FILE_PATH}
267 Pass Execution The backup firmware image ${image_version} is now functional.
268
269
Sushil Singh87dcee12019-08-07 13:13:13 -0500270Redfish Update Firmware
271 [Documentation] Update the BMC firmware via redfish interface.
272
Sushil Singh6624ce52020-01-22 00:53:41 -0600273 ${post_code_update_actions}= Get Post Boot Action
Sushil Singh87dcee12019-08-07 13:13:13 -0500274 ${state}= Get Pre Reboot State
275 Rprint Vars state
Sushil Singh090eedc2019-11-05 02:04:59 -0600276 Run Keyword And Ignore Error Set ApplyTime policy=OnReset
George Keishing2e078ae2022-02-03 09:13:23 -0600277
278 # Python module: get_member_list(resource_path)
279 ${before_inv_list}= redfish_utils.Get Member List /redfish/v1/UpdateService/FirmwareInventory
280 Log To Console Current images on the BMC before upload: ${before_inv_list}
281
George Keishingb695a902022-05-11 09:26:21 -0500282 Print Timen Start uploading image to BMC.
George Keishing57ab7cc2023-02-13 01:18:42 -0600283 Redfish Upload Image ${REDFISH_UPDATE_URI} ${IMAGE_FILE_PATH}
George Keishingb695a902022-05-11 09:26:21 -0500284 Print Timen Completed image upload to BMC.
George Keishing2e078ae2022-02-03 09:13:23 -0600285
286 # Python module: get_member_list(resource_path)
287 ${after_inv_list}= redfish_utils.Get Member List /redfish/v1/UpdateService/FirmwareInventory
288 Log To Console Current images on the BMC after upload: ${after_inv_list}
289
290 ${image_id}= Evaluate set(${after_inv_list}) - set(${before_inv_list})
291 Should Not Be Empty ${image_id}
292 ${image_id}= Evaluate list(${image_id})[0].split('/')[-1]
293 Log To Console Firmware installation in progress with image id:: ${image_id}
294
295 Wait Until Keyword Succeeds ${ACTIVATION_WAIT_TIMEOUT} 10 sec
296 ... Check Image Update Progress State match_state='Enabled' image_id=${image_id}
297
298 # Python module: get_version_tar(tar_file_path)
299 ${tar_version}= code_update_utils.Get Version Tar ${IMAGE_FILE_PATH}
Sushil Singh8f48c8f2020-01-16 04:36:25 -0600300 ${image_info}= Get Software Inventory State By Version ${tar_version}
George Keishing2e078ae2022-02-03 09:13:23 -0600301
Sushil Singh8f48c8f2020-01-16 04:36:25 -0600302 Run Key ${post_code_update_actions['${image_info["image_type"]}']['OnReset']}
303 Redfish.Login
304 Redfish Verify BMC Version ${IMAGE_FILE_PATH}
Sushil Singh87dcee12019-08-07 13:13:13 -0500305