1*** Settings *** 2Documentation Inventory of hardware FRUs under redfish. 3 4Resource ../../lib/bmc_redfish_resource.robot 5Resource ../../lib/bmc_redfish_utils.robot 6Resource ../../lib/openbmc_ffdc.robot 7Library ../../lib/gen_robot_valid.py 8 9Suite Setup Suite Setup Execution 10Suite Teardown Suite Teardown Execution 11Test Setup Printn 12Test Teardown Test Teardown Execution 13 14*** Variables *** 15 16# The passing criteria. Must have at least this many. 17${min_num_dimms} 2 18${min_num_cpus} 1 19${min_num_cores} 18 20${min_num_power_supplies} 1 21 22 23*** Test Cases *** 24 25 26Verify CPU And Core Count 27 [Documentation] Get the total number of CPUs and cores in the system. 28 ... Verify counts are above minimums. 29 [Tags] Verify_CPU_And_Core_Count 30 31 # Select only CPUs with Health = "OK". 32 ${cpus_ok}= Filter Struct ${cpu_info} [('Health', 'OK')] 33 ${num_cpus}= Get Length ${cpus_ok} 34 35 Rprint Vars num_cpus min_num_cpus 36 37 # Assert that num_cpus is greater than or equal to min_num_cpus. 38 Valid Range num_cpus ${min_num_cpus} 39 40 # Get the number of cores. 41 ${total_num_cores}= Set Variable ${0} 42 :FOR ${cpu} IN @{cpus_ok} 43 ${cores}= Get CPU TotalCores ${cpu} 44 ${total_num_cores}= Evaluate $total_num_cores + ${cores} 45 END 46 47 Rprint Vars total_num_cores min_num_cores 48 49 # Assert that total_num_cores is greater than or equal to 50 # min_num_cores. 51 Valid Range total_num_cores ${min_num_cores} 52 53 54Get Memory Inventory Via Redfish And Verify 55 [Documentation] Get the number of DIMMs that are functional and enabled. 56 [Tags] Get_Memory_Inventory_Via_Redfish_And_Verify 57 58 Verify FRU Inventory Minimums Memory ${min_num_dimms} 59 60 61Get Memory Summary State And Verify Enabled 62 [Documentation] Check that the state of the MemorySummary attribute 63 ... under /redfish/v1/Systems/system is 'Enabled'. 64 [Tags] Get_Memory_Summary_State_And_Verify_Enabled 65 66 ${status}= Redfish.Get Attribute ${SYSTEM_BASE_URI} MemorySummary 67 ${memory_summary_state}= Set Variable ${status['Status']['State']} 68 Rprint Vars memory_summary_state 69 70 Should Be Equal As Strings Enabled ${memory_summary_state} 71 ... msg=MemorySummary State is not 'Enabled'. 72 73 74Get System Serial And Verify Populated 75 [Documentation] Check that the System SerialNumber is non-blank. 76 [Tags] Get_System_Serial_And_Verify_Populated 77 78 ${serial_number}= Redfish.Get Attribute ${SYSTEM_BASE_URI} SerialNumber 79 Valid Value serial_number 80 Rprint Vars serial_number 81 82 83Get Model And Verify Populated 84 [Documentation] Check that the Model is non-blank. 85 [Tags] Get_Model_And_Verify_Populated 86 87 ${model}= Redfish.Get Attribute ${SYSTEM_BASE_URI} Model 88 Valid Value model 89 Rprint Vars model 90 91 92Get Available Power Supplies And Verify 93 [Documentation] Get the number of functional power supplies and 94 ... verify that it is at or above the minimum. 95 [Tags] Get_Available_Power_Supplies_And_Verify 96 97 # Select only power supplies with Health = "OK". 98 ${power_supplies_ok}= Filter Struct ${power_supplies} [('Health', 'OK')] 99 100 # Count the power supplies that are Enabled or StandbyOffline. 101 ${total_num_supplies}= Set Variable ${0} 102 :FOR ${power_supply} IN @{power_supplies_ok} 103 # Example of power_supply: 104 # power_supply = {'@odata.id': '/redfish/v1/Chassis/chassis/Power#/PowerSupplies/0', 105 # 'Manufacturer': '', 'MemberId': 'powersupply0', 'Model': '2100', 'Name': 106 # 'powersupply0', 'PartNumber': 'PNPWR123', 'PowerInputWatts': 394.0, 107 # 'SerialNumber': '75B12W', 'Status': {'Health': 'OK', 'State': 'Enabled'}} 108 ${state}= Set Variable ${power_supply['Status']['State']} 109 ${good_state}= Evaluate 110 ... any(x in '${state}' for x in ('Enabled', 'StandbyOffline')) 111 Run Keyword If not ${good_state} Continue For Loop 112 ${total_num_supplies}= Evaluate $total_num_supplies + ${1} 113 END 114 115 Rprint Vars total_num_supplies min_num_power_supplies 116 117 Valid Range total_num_supplies ${min_num_power_supplies} 118 119 120Get Motherboard Serial And Verify Populated 121 [Documentation] Check that the Motherboard SerialNumber is non-blank. 122 [Tags] Get_Motherboard_Serial_And_Verify_Populated 123 124 ${serial_number}= Redfish.Get Attribute 125 ... ${REDFISH_CHASSIS_URI}motherboard SerialNumber 126 Valid Value serial_number 127 Rprint Vars serial_number 128 129 130Check GPU States When Power On 131 [Documentation] Check the State of each of the GPUs 132 ... in the system. A system may have 0-6 GPUs. 133 [Tags] Check_GPU_States_When_Power_On 134 135 # System was powered-on in Suite Setup. 136 GPU State Check 137 138 139Check GPU States When Power Off 140 [Documentation] Check the State of the GPUs when power is Off. 141 [Tags] Check_GPU_States_When_Power_Off 142 143 Redfish Power Off 144 Redfish.Login 145 GPU State Check 146 147 148*** Keywords *** 149 150 151Get CPU TotalCores 152 [Documentation] Return the TotalCores of a CPU. 153 ... Return 0 if this attribute is missing or NONE. 154 [Arguments] ${processor} 155 156 # Description of Argument(s): 157 # processor The Redfish URI of a CPU (e.g. 158 # "/redfish/v1/Systems/system/Processors/cpu0"). 159 160 ${total_cores}= Redfish.Get Attribute ${processor} TotalCores 161 Return From Keyword If ${total_cores} is ${NONE} ${0} 162 [Return] ${total_cores} 163 164 165GPU State Check 166 [Documentation] The state of every "OK" GPU should be 167 ... "Absent", "Enabled", or "UnavailableOffline". 168 169 # Select only GPUs with Health = "OK". 170 ${gpus_ok}= Filter Struct ${gpu_info} [('Health', 'OK')] 171 172 :FOR ${gpu} IN @{gpus_ok} 173 ${status}= Redfish.Get Attribute ${gpu} Status 174 ${state}= Set Variable ${status['State']} 175 ${good_state}= Evaluate 176 ... any(x in '${state}' for x in ('Absent', 'Enabled', 'UnavailableOffline')) 177 Rprint Vars gpu state 178 Run Keyword If not ${good_state} Fail 179 ... msg=GPU State is not Absent, Enabled, or UnavailableOffline. 180 END 181 182 183Get Inventory URIs 184 [Documentation] Get and return a tuple of lists of URIs for CPU, 185 ... GPU and PowerSupplies. 186 187 ${processor_info}= Redfish_Utils.Enumerate Request 188 ... ${SYSTEM_BASE_URI}Processors return_json=0 189 190 ${cpu_info}= Filter Struct ${processor_info} 191 ... [('ProcessorType', 'CPU')] regex=1 192 193 ${gpu_info}= Filter Struct ${processor_info} 194 ... [('ProcessorType', 'Accelerator')] regex=1 195 196 ${power_supplies}= Redfish.Get Attribute 197 ... ${REDFISH_CHASSIS_POWER_URI} PowerSupplies 198 199 [Return] ${cpu_info} ${gpu_info} ${power_supplies} 200 201 202Verify FRU Inventory Minimums 203 [Documentation] Verify a minimum number of FRUs. 204 [Arguments] ${fru_type} ${min_num_frus} 205 206 # Description of Argument(s): 207 # fru_type The type of FRU (e.g. "Processors", "Memory", etc.). 208 # min_num_frus The minimum acceptable number of FRUs found. 209 210 # A valid FRU will have a "State" key of "Enabled" and a "Health" key 211 # of "OK". 212 213 ${status} ${num_valid_frus}= Run Key U Get Num Valid FRUs \ ${fru_type} 214 215 Rprint Vars fru_type num_valid_frus min_num_frus 216 217 Return From Keyword If ${num_valid_frus} >= ${min_num_frus} 218 Fail Too few "${fru_type}" FRUs found, found only ${num_valid_frus}. 219 220 221Suite Teardown Execution 222 [Documentation] Do the post suite teardown. 223 224 Redfish.Logout 225 226 227Suite Setup Execution 228 [Documentation] Do test case setup tasks. 229 230 Redfish Power On stack_mode=skip 231 Redfish.Login 232 233 ${cpu_info} ${gpu_info} ${power_supplies}= Get Inventory URIs 234 235 Set Suite Variable ${cpu_info} 236 Set Suite Variable ${gpu_info} 237 Set Suite Variable ${power_supplies} 238 239 240Test Teardown Execution 241 [Documentation] Do the post test teardown. 242 243 FFDC On Test Case Fail 244