blob: 921ae1a959b9fee7f776487311249ababa3338ea [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 Singh87dcee12019-08-07 13:13:13 -050022
Sushil Singhb2162d82019-09-27 07:22:04 -050023Suite Setup Suite Setup Execution
24Suite Teardown Redfish.Logout
25Test Setup Printn
26Test Teardown FFDC On Test Case Fail
Sushil Singh87dcee12019-08-07 13:13:13 -050027
Sushil Singhb2162d82019-09-27 07:22:04 -050028Force Tags BMC_Code_Update
Sushil Singh87dcee12019-08-07 13:13:13 -050029
Sushil Singh65878cb2020-02-27 03:43:44 -060030*** Variables ***
31
32${FORCE_UPDATE} ${0}
33
34
Sushil Singh87dcee12019-08-07 13:13:13 -050035*** Test Cases ***
36
37Redfish BMC Code Update
38 [Documentation] Update the firmware image.
39 [Tags] Redfish_BMC_Code_Update
40
41 ${image_version}= Get Version Tar ${IMAGE_FILE_PATH}
42 Rprint Vars image_version
43
44 Run Keyword If not ${FORCE_UPDATE}
45 ... Activate Existing Firmware ${image_version}
46 Redfish Update Firmware
47
48*** Keywords ***
49
50Suite Setup Execution
51 [Documentation] Do the suite setup.
52
53 Redfish.Login
Sushil Singh87dcee12019-08-07 13:13:13 -050054 # Delete BMC dump and Error logs.
55 Delete All BMC Dump
56 Redfish Purge Event Log
Sushil Singh87dcee12019-08-07 13:13:13 -050057 # Checking for file existence.
58 Valid File Path IMAGE_FILE_PATH
59
Sushil Singh87dcee12019-08-07 13:13:13 -050060Activate Existing Firmware
61 [Documentation] Set fimware image to lower priority.
62 [Arguments] ${image_version}
63
64 # Description of argument(s):
65 # image_version Version of image.
66
67 ${software_inventory_record}= Get Software Inventory State By Version
68 ... ${image_version}
69 ${num_keys}= Get Length ${software_inventory_record}
70
71 Rprint Vars software_inventory_record
72
73 # If no software inventory record was found, there is no existing
74 # firmware for the given version and therefore no action to be taken.
75 Return From Keyword If not ${num_keys}
76
77 # Check if the existing firmware is functional.
78 Pass Execution If ${software_inventory_record['functional']}
79 ... The existing ${image_version} firmware is already functional.
80
81 # If existing firmware is not functional, then set the priority to least.
82 Print Timen The existing ${image_version} firmware is not yet functional.
83 Set BMC Image Priority To Least ${image_version} ${software_inventory_record}
84
85 Pass Execution The existing ${image_version} firmware is now functional.
86
87
88Get Image Priority
89 [Documentation] Get Current Image Priority.
90 [Arguments] ${image_version}
91
92 # Description of argument(s):
George Keishing19700762020-01-22 12:32:53 -060093 # image_version The Fimware image version (e.g. 2.8.0-dev-1107-g512028d95).
Sushil Singh87dcee12019-08-07 13:13:13 -050094
95 ${software_info}= Read Properties
96 ... ${SOFTWARE_VERSION_URI}/enumerate quiet=1
97 # Get only the record associated with our image_version.
98
99 ${software_info}= Filter Struct
100 ... ${software_info} [('Version', '${image_version}')]
101 # Convert from dict to list.
102 ${software_info}= Get Dictionary Values ${software_info}
103
104 [Return] ${software_info[0]['Priority']}
105
106
107Set BMC Image Priority To Least
108 [Documentation] Set BMC image priority to least value.
109 [Arguments] ${image_version} ${software_inventory}
110
111 # Description of argument(s):
George Keishing19700762020-01-22 12:32:53 -0600112 # image_version The Fimware image version (e.g. 2.8.0-dev-1107-g512028d95).
Sushil Singh87dcee12019-08-07 13:13:13 -0500113 # software_inventory Software inventory details.
114
115 ${least_priority}= Get Least Value Priority Image ${VERSION_PURPOSE_BMC}
116 ${cur_priority}= Get Image Priority ${image_version}
117 Rprint Vars least_priority cur_priority
118
119 Return From Keyword If '${least_priority}' == ${cur_priority}
120 Set Host Software Property
121 ... ${SOFTWARE_VERSION_URI}${software_inventory['image_id']}
122 ... Priority ${least_priority}
123
124 # Reboot BMC And Login
125 Redfish OBMC Reboot (off)
126 Redfish.Login
127
128
129Redfish Update Firmware
130 [Documentation] Update the BMC firmware via redfish interface.
131
Sushil Singh6624ce52020-01-22 00:53:41 -0600132 ${post_code_update_actions}= Get Post Boot Action
Sushil Singh87dcee12019-08-07 13:13:13 -0500133 ${state}= Get Pre Reboot State
134 Rprint Vars state
Sushil Singh090eedc2019-11-05 02:04:59 -0600135 Run Keyword And Ignore Error Set ApplyTime policy=OnReset
Sushil Singh6f86f172019-10-30 11:36:25 -0500136 Redfish Upload Image And Check Progress State
Sushil Singh8f48c8f2020-01-16 04:36:25 -0600137 ${tar_version}= Get Version Tar ${IMAGE_FILE_PATH}
138 ${image_info}= Get Software Inventory State By Version ${tar_version}
Sushil Singh8f48c8f2020-01-16 04:36:25 -0600139 Run Key ${post_code_update_actions['${image_info["image_type"]}']['OnReset']}
140 Redfish.Login
141 Redfish Verify BMC Version ${IMAGE_FILE_PATH}
Sushil Singh87dcee12019-08-07 13:13:13 -0500142