1*** Settings *** 2 3Documentation Module to test IPMI network functionality. 4Resource ../lib/ipmi_client.robot 5Resource ../lib/openbmc_ffdc.robot 6Resource ../lib/bmc_network_utils.robot 7Library ../lib/ipmi_utils.py 8Library ../lib/gen_robot_valid.py 9Library ../lib/var_funcs.py 10Library ../lib/bmc_network_utils.py 11Variables ../data/ipmi_raw_cmd_table.py 12 13Suite Setup Redfish.Login 14Test Setup Printn 15Test Teardown FFDC On Test Case Fail 16 17Force Tags IPMI_Network_Verify 18 19 20*** Variables *** 21${set_mac_address} 02:f4:43:24:e7:1a 22${Invalid_mac_address} 11:f4:43:24:e7:1a 23 24 25*** Test Cases *** 26 27Retrieve IP Address Via IPMI And Verify Using Redfish 28 [Documentation] Retrieve IP address using IPMI and verify using Redfish. 29 [Tags] Retrieve_IP_Address_Via_IPMI_And_Verify_Using_Redfish 30 31 ${active_channel_config}= Get Active Channel Config 32 FOR ${channel_number} IN @{active_channel_config.keys()} 33 Verify Channel Info ${channel_number} IPv4StaticAddresses ${active_channel_config} 34 END 35 36Retrieve Default Gateway Via IPMI And Verify 37 [Documentation] Retrieve default gateway via IPMI and verify it's existence on the BMC. 38 [Tags] Retrieve_Default_Gateway_Via_IPMI_And_Verify 39 40 ${lan_print_ipmi}= Get LAN Print Dict 41 42 Verify Gateway On BMC ${lan_print_ipmi['Default Gateway IP']} 43 44 45Retrieve MAC Address Via IPMI And Verify Using Redfish 46 [Documentation] Retrieve MAC address via IPMI and verify using Redfish. 47 [Tags] Retrieve_MAC_Address_Via_IPMI_And_Verify_Using_Redfish 48 49 ${active_channel_config}= Get Active Channel Config 50 FOR ${channel_number} IN @{active_channel_config.keys()} 51 Verify Channel Info ${channel_number} MACAddress ${active_channel_config} 52 END 53 54 55Test Valid IPMI Channels Supported 56 [Documentation] Verify IPMI channels supported on a given system. 57 [Tags] Test_Valid_IPMI_Channels_Supported 58 59 ${channel_count}= Get Physical Network Interface Count 60 Should Be True ${channel_count} > 0 61 ... msg=IPMI Lan channel support expected > 0 but found ${channel_count} 62 ${channel_count}= Evaluate ${channel_count} + 1 63 64 # Note: IPMI network channel logically starts from 1. 65 FOR ${channel_number} IN RANGE 1 ${channel_count} 66 Run IPMI Standard Command lan print ${channel_number} 67 END 68 69 70Test Invalid IPMI Channel Response 71 [Documentation] Verify invalid IPMI channels supported response. 72 [Tags] Test_Invalid_IPMI_Channel_Response 73 74 ${channel_count}= Get Physical Network Interface Count 75 76 # To target invalid channel, increment count. 77 ${channel_number}= Evaluate ${channel_count} + 1 78 79 # Example of invalid channel: 80 # $ ipmitool -I lanplus -H xx.xx.xx.xx -P password lan print 3 81 # Get Channel Info command failed: Parameter out of range 82 # Invalid channel: 3 83 84 ${stdout}= Run External IPMI Standard Command 85 ... lan print ${channel_number} fail_on_err=${0} 86 Should Contain ${stdout} Invalid channel 87 ... msg=IPMI channel ${channel_number} is invalid but seen working. 88 89 90Get IP Address Source And Verify Using Redfish 91 [Documentation] Get IP address source and verify it using Redfish. 92 [Tags] Get_IP_Address_Source_And_Verify_Using_Redfish 93 94 ${active_channel_config}= Get Active Channel Config 95 ${lan_config}= Get LAN Print Dict ${CHANNEL_NUMBER} 96 97 ${ipv4_addresses}= Redfish.Get Attribute 98 ... /redfish/v1/Managers/bmc/EthernetInterfaces/${active_channel_config['${CHANNEL_NUMBER}']['name']} 99 ... IPv4Addresses 100 101 FOR ${ipv4_address} IN @{ipv4_addresses} 102 ${ip_address_source}= 103 ... Set Variable if '${ipv4_address['Address']}' == '${lan_config['IP Address']}' 104 ... ${ipv4_address['AddressOrigin']} Address 105 Exit For Loop IF "${ip_address_source}" != 'None' 106 END 107 108 Valid Value lan_config['IP Address Source'] ['${ip_address_source}'] 109 110 111Verify Get Set In Progress 112 [Documentation] Verify Get Set In Progress which belongs to LAN Configuration Parameters 113 ... via IPMI raw Command. 114 [Tags] Verify_Get_Set_In_Progress 115 116 ${ipmi_output}= Run IPMI Command 117 ... ${IPMI_RAW_CMD['LAN_Config_Params']['Get'][0]} ${CHANNEL_NUMBER} 0x00 0x00 0x00 118 119 ${ipmi_output}= Split String ${ipmi_output} 120 ${set_in_progress_value}= Set Variable ${ipmi_output[1]} 121 122 # 00b = set complete. 123 # 01b = set in progress. 124 Should Contain Any ${set_in_progress_value} 00 01 125 126 127Verify Cipher Suite Entry Count 128 [Documentation] Verify cipher suite entry count which belongs to LAN Configuration Parameters 129 ... via IPMI raw Command. 130 [Tags] Verify_Cipher_Suite_Entry_Count 131 132 ${ipmi_output}= Run IPMI Command 133 ... ${IPMI_RAW_CMD['LAN_Config_Params']['Get'][0]} ${CHANNEL_NUMBER} 0x16 0x00 0x00 134 ${cipher_suite_entry_count}= Split String ${ipmi_output} 135 136 # Convert minor cipher suite entry count from BCD format to integer. i.e. 01 to 1. 137 ${cipher_suite_entry_count[1]}= Convert To Integer ${cipher_suite_entry_count[1]} 138 ${cnt}= Get length ${valid_ciphers} 139 140 Should be Equal ${cipher_suite_entry_count[1]} ${cnt} 141 142 143Verify Authentication Type Support 144 [Documentation] Verify authentication type support which belongs to LAN Configuration Parameters 145 ... via IPMI raw Command. 146 [Tags] Verify_Authentication_Type_Support 147 148 ${ipmi_output}= Run IPMI Command 149 ... ${IPMI_RAW_CMD['LAN_Config_Params']['Get'][0]} ${CHANNEL_NUMBER} 0x01 0x00 0x00 150 151 ${authentication_type_support}= Split String ${ipmi_output} 152 # All bits: 153 # 1b = supported 154 # 0b = authentication type not available for use 155 # [5] - OEM proprietary (per OEM identified by the IANA OEM ID in the RMCP Ping Response) 156 # [4] - straight password / key 157 # [3] - reserved 158 # [2] - MD5 159 # [1] - MD2 160 # [0] - none 161 Should Contain Any ${authentication_type_support[1]} 00 01 02 03 04 05 162 163 164Verify Set In Progress 165 [Documentation] Verify Set In Progress which belongs to LAN Configuration Parameters 166 ... via IPMI raw Command. 167 [Tags] Verify_Set_In_Progress 168 169 # Set the Set In Progress 170 ${output_msg}= Run Inband IPMI Raw Command 171 ... ${IPMI_RAW_CMD['LAN_Config_Params']['Set'][0]} ${CHANNEL_NUMBER} 0x00 0x01 172 173 # Get the Set In Progress 174 ${ipmi_output}= Run Inband IPMI Raw Command 175 ... ${IPMI_RAW_CMD['LAN_Config_Params']['Get'][0]} ${CHANNEL_NUMBER} 0x00 0x00 0x00 176 177 # Verify the response 178 ${ipmi_output}= Split String ${ipmi_output} 179 ${set_in_progress_value}= Set Variable ${ipmi_output[1]} 180 181 # 01b = set in progress. 182 Should be Equal ${set_in_progress_value} 01 183 184 # set back to default. 185 Run IPMI Command ${IPMI_RAW_CMD['LAN_Config_Params']['Set'][0]} ${CHANNEL_NUMBER} 0x00 0x00 186 187 # Get the Set In Progress. 188 ${ipmi_output}= Run Inband IPMI Raw Command 189 ... ${IPMI_RAW_CMD['LAN_Config_Params']['Get'][0]} ${CHANNEL_NUMBER} 0x00 0x00 0x00 190 191 # Verify the response. 192 ${ipmi_output}= Split String ${ipmi_output} 193 ${set_in_progress_value}= Set Variable ${ipmi_output[1]} 194 195 # 00b = set complete. 196 Should be Equal ${set_in_progress_value} 00 197 198 199Verify Invalid Set MAC Address Via IPMI 200 [Documentation] Verify Get and Set MAC address via IPMI. 201 [Tags] Verify_Invalid_Set_MAC_Address_Via_IPMI 202 203 # MAC to hexa string. 204 ${Invalid_mac_address_hex}= Mac Address To Hex String ${Invalid_mac_address} 205 206 # Set MAC Address with invalid data. 207 ${cmd}= Catenate ${IPMI_RAW_CMD['LAN_Config_Params']['Set'][0]} ${CHANNEL_NUMBER} 208 ... 0x05 ${Invalid_mac_address_hex} fail_on_err=0 209 ${ipmi_set_output}= Run Inband IPMI Raw Command ${cmd} 210 211 Should Contain ${ipmi_set_output} ${IPMI_RAW_CMD['LAN_Config_Params']['Set'][3]} 212 213 214Verify Get And Set MAC Address Via IPMI 215 [Documentation] Verify Get and Set MAC address via IPMI. 216 [Tags] Verify_Get_And_Set_MAC_Address_Via_IPMI 217 [Setup] Fetch The Default Mac Address 218 [Teardown] Set Default Mac And Verify ${ipmi_default_mac_split} 219 220 # MAC to hexa string. 221 ${mac_address_hex}= Mac Address To Hex String ${set_mac_address} 222 223 # Set the MAC address. 224 ${cmd}= Catenate ${IPMI_RAW_CMD['LAN_Config_Params']['Set'][0]} ${CHANNEL_NUMBER} 225 ... 0x05 ${mac_address_hex} fail_on_err=0 226 ${ipmi_set_output}= Run Inband IPMI Raw Command ${cmd} 227 228 # Get the MAC address and verify. 229 ${ipmi_output}= Run Inband IPMI Raw Command 230 ... ${IPMI_RAW_CMD['LAN_Config_Params']['Get'][0]} ${CHANNEL_NUMBER} 0x05 0x00 0x00 231 ${ipmi_output_split}= Split String ${ipmi_output} 232 ${get_mac}= Evaluate ":".join(${ipmi_output_split[1:]}) 233 234 Should be Equal ${get_mac} ${set_mac_address} 235 236 237Verify Cipher Suite Privilege 238 [Documentation] Verify cipher suite privilege which belongs to LAN Configuration Parameters 239 ... via IPMI raw Command. 240 [Tags] Verify_Cipher_Suite_Privilege 241 242 # Get the Cipher Suite privilege and verify the response. 243 ${ipmi_output}= Run Inband IPMI Raw Command 244 ... ${IPMI_RAW_CMD['LAN_Config_Params']['Get'][0]} ${CHANNEL_NUMBER} 0x18 0x00 0x00 245 ${cipher_suite_privilege}= Split String ${ipmi_output} 246 247 Should be Equal '${${cipher_suite_privilege}[0]}' '11' 248 # 00b = reserved. 249 Should Contain Any '${cipher_suite_privilege[1]}' '00' '0' 250 251 ${cipher_suite_privilege_length}= Get length ${cipher_suite_privilege} 252 Should be Equal '${cipher_suite_privilege_length}' '10' 253 254 #44b = Maximum privilege for cipher suite. 255 FOR ${channel_number} IN RANGE 2 ${cipher_suite_privilege_length} 256 Should be Equal '${cipher_suite_privilege[${channel_number}]}' '44' 257 END 258 259 260Verify Set On Authentication Type 261 [Documentation] Verify Set On Authentication Type which belongs to LAN Configuration Parameters 262 ... via IPMI raw Command. 263 [Tags] Verify_Set_On_Authentication_Type 264 265 # Set Authentication Type and expect error. 266 ${ipmi_output}= Run Inband IPMI Raw Command 267 ... ${IPMI_RAW_CMD['LAN_Config_Params']['Set'][0]} ${CHANNEL_NUMBER} 0x01 0x01 fail_on_err=0 268 269 Should Contain ${ipmi_output} ${IPMI_RAW_CMD['LAN_Config_Params']['Set'][2]} 270 271 272Verify IP Address Source Set To Address Loaded By BIOS 273 [Documentation] Verify Set IP Address Source to address loaded by BIOS or system software via IPMI. 274 [Tags] Verify_IP_Address_Source_Set_To_Address_Loaded_By_BIOS 275 276 # Set IP address source to address loaded by BIOS or system software. 277 ${ipmi_output}= Run Keyword and Expect Error *${IPMI_RAW_CMD['LAN_Config_Params']['Set'][3]}* 278 ... Run Inband IPMI Raw Command 279 ... ${IPMI_RAW_CMD['LAN_Config_Params']['Set'][0]} 0x0${CHANNEL_NUMBER} 0x04 0x03 280 281 282Verify IP Address Source Set To Address Obtained By BMC 283 [Documentation] Verify Set IP Address Source to address obtained by, 284 ... BMC running other address assignment protocol via IPMI. 285 [Tags] Verify_IP_Address_Source_Set_To_Address_Obtained_By_BMC 286 287 # Set IP address source to address obtained by BMC running other address assignment protocol 288 ${ipmi_output}= Run Keyword and Expect Error *${IPMI_RAW_CMD['LAN_Config_Params']['Set'][3]}* 289 ... Run Inband IPMI Raw Command 290 ... ${IPMI_RAW_CMD['LAN_Config_Params']['Set'][0]} 0x0${CHANNEL_NUMBER} 0x04 0x04 291 292 293Verify IP Address Source Set To Unspecified Address Source 294 [Documentation] Verify Set IP Address source to unspecified address source via IPMI. 295 [Tags] Verify_IP_Address_Source_Set_To_Unspecified_Address_Source 296 297 # Set IP address source to unspecified address source. 298 ${ipmi_output}= Run Keyword and Expect Error *${IPMI_RAW_CMD['LAN_Config_Params']['Set'][3]}* 299 ... Run Inband IPMI Raw Command 300 ... ${IPMI_RAW_CMD['LAN_Config_Params']['Set'][0]} 0x0${CHANNEL_NUMBER} 0x04 0x00 301 302 303*** Keywords *** 304 305Get Physical Network Interface Count 306 [Documentation] Return valid physical network interfaces count. 307 # Example: 308 # link/ether 22:3a:7f:70:92:cb brd ff:ff:ff:ff:ff:ff 309 # link/ether 0e:8e:0d:6b:e9:e4 brd ff:ff:ff:ff:ff:ff 310 311 ${mac_entry_list}= Get BMC MAC Address List 312 ${mac_unique_list}= Remove Duplicates ${mac_entry_list} 313 ${physical_interface_count}= Get Length ${mac_unique_list} 314 315 [Return] ${physical_interface_count} 316 317 318Verify Channel Info 319 [Documentation] Verify the channel info. 320 [Arguments] ${channel_number} ${network_parameter} ${active_channel_config} 321 322 Run Keyword If '${network_parameter}' == 'IPv4StaticAddresses' 323 ... Verify IPv4 Static Address ${channel_number} ${active_channel_config} 324 ... ELSE IF '${network_parameter}' == 'MACAddress' 325 ... Verify MAC Address ${channel_number} ${active_channel_config} 326 327 328Verify IPv4 Static Address 329 [Documentation] Verify the IPv4 Static Address. 330 [Arguments] ${channel_number} ${active_channel_config} 331 332 ${lan_print_ipmi}= Get LAN Print Dict ${channel_number} 333 ${ipv4_static_addresses}= Redfish.Get Attribute 334 ... ${REDFISH_NW_ETH_IFACE}${active_channel_config['${channel_number}']['name']} IPv4StaticAddresses 335 ${redfish_ips}= Nested Get Address ${ipv4_static_addresses} 336 Rprint Vars lan_print_ipmi ipv4_static_addresses redfish_ips 337 Valid Value lan_print_ipmi['IP Address'] ${redfish_ips} 338 339 340Verify MAC Address 341 [Documentation] Verify the MAC Address. 342 [Arguments] ${channel_number} ${active_channel_config} 343 344 ${lan_print_ipmi}= Get LAN Print Dict ${channel_number} 345 ${redfish_mac_address}= Redfish.Get Attribute 346 ... ${REDFISH_NW_ETH_IFACE}${active_channel_config['${channel_number}']['name']} MACAddress 347 Rprint Vars lan_print_ipmi redfish_mac_address 348 Valid Value lan_print_ipmi['MAC Address'] ['${redfish_mac_address}'] 349 350 351Fetch The Default Mac Address 352 [Documentation] Fetch The Default MAC Address. 353 354 # Get Default MAC Address. 355 ${ipmi_get_default_mac}= Run Inband IPMI Raw Command 356 ... ${IPMI_RAW_CMD['LAN_Config_Params']['Get'][0]} ${CHANNEL_NUMBER} 0x05 0x00 0x00 357 Set Test Variable ${ipmi_get_default_mac} 358 359 # After splitting, list will have each byte of MAC address. 360 ${ipmi_default_mac_split}= Split String ${ipmi_get_default_mac} 361 Set Test Variable ${ipmi_default_mac_split} 362 363 364Set Default Mac And Verify 365 [Documentation] Set Default Mac And Verify. 366 [Arguments] ${default_mac}=${ipmi_default_mac_split} 367 368 ${set_default_mac}= Evaluate ":".join(${default_mac[1:]}) 369 ${default_mac_address_hex}= Mac Address To Hex String ${set_default_mac} 370 371 # Set the Default MAC address. 372 ${cmd}= Catenate ${IPMI_RAW_CMD['LAN_Config_Params']['Set'][0]} ${CHANNEL_NUMBER} 373 ... 0x05 ${default_mac_address_hex} fail_on_err=0 374 ${ipmi_set_output}= Run Inband IPMI Raw Command ${cmd} 375 376 # check whether the default MAC is set. 377 ${ipmi_get_mac}= Run Inband IPMI Raw Command 378 ... ${IPMI_RAW_CMD['LAN_Config_Params']['Get'][0]} ${CHANNEL_NUMBER} 0x05 0x00 0x00 379 380 ${ipmi_out}= Split String ${ipmi_get_mac} 381 Should be Equal ${default_mac} ${ipmi_out} 382