1*** 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 18Resource ../../lib/utils.robot 19Library ../../lib/gen_robot_valid.py 20Library ../../lib/var_funcs.py 21Library ../../lib/gen_robot_keyword.py 22Library ../../lib/code_update_utils.py 23 24Suite Setup Suite Setup Execution 25Suite Teardown Redfish.Logout 26Test Setup Printn 27Test Teardown FFDC On Test Case Fail 28 29# Force the test to timedout to prevent test hanging. 30Test Timeout 30 minutes 31 32*** Test Cases *** 33 34Redfish Host Code Update 35 [Documentation] Update the firmware image. 36 [Tags] Redfish_Host_Code_Update 37 38 ${image_version}= Get Version Tar ${IMAGE_FILE_PATH} 39 Rprint Vars image_version 40 41 ${sw_inv}= Get Functional Firmware Host image 42 ${functional_sw_inv}= Get Non Functional Firmware ${sw_inv} True 43 44 ${num_records}= Get Length ${functional_sw_inv} 45 46 IF ${num_records} != 0 47 Pass Execution If '${functional_sw_inv['version']}' == '${image_version}' 48 ... The existing ${image_version} firmware is already functional. 49 END 50 51 ${post_code_update_actions}= Get Post Boot Action 52 ${state}= Get Pre Reboot State 53 Rprint Vars state 54 55 Print Timen Performing firmware update ${image_version}. 56 57 Redfish Update Firmware 58 59 60*** Keywords *** 61 62Suite Setup Execution 63 [Documentation] Do the suite setup. 64 65 Redfish.Login 66 # Delete BMC dump and Error logs. 67 Run Keyword And Ignore Error Redfish Delete All BMC Dumps 68 Run Keyword And Ignore Error Redfish Purge Event Log 69 # Checking for file existence. 70 Valid File Path IMAGE_FILE_PATH 71 72 73Redfish Update Firmware 74 [Documentation] Update the BMC firmware via redfish interface. 75 76 Redfish.Login 77 ${post_code_update_actions}= Get Post Boot Action 78 Rprint Vars post_code_update_actions 79 Run Keyword And Ignore Error Set ApplyTime policy=OnReset 80 Redfish Upload Image And Check Progress State 81 ${tar_version}= Get Version Tar ${IMAGE_FILE_PATH} 82 ${image_info}= Get Software Inventory State By Version ${tar_version} 83 Run Key ${post_code_update_actions['${image_info["image_type"]}']['OnReset']} 84 Redfish.Login 85 Redfish Verify Host Version ${IMAGE_FILE_PATH} 86 87