| *** Settings *** |
| |
| Documentation Module to test IPMI network functionality. |
| Resource ../lib/ipmi_client.robot |
| Resource ../lib/openbmc_ffdc.robot |
| Resource ../lib/bmc_network_utils.robot |
| Library ../lib/ipmi_utils.py |
| Library ../lib/gen_robot_valid.py |
| Library ../lib/var_funcs.py |
| Library ../lib/bmc_network_utils.py |
| Variables ../data/ipmi_raw_cmd_table.py |
| |
| Suite Setup Redfish.Login |
| Test Setup Printn |
| Test Teardown FFDC On Test Case Fail |
| |
| Force Tags IPMI_Network_Verify |
| |
| *** Test Cases *** |
| |
| Retrieve IP Address Via IPMI And Verify Using Redfish |
| [Documentation] Retrieve IP address using IPMI and verify using Redfish. |
| [Tags] Retrieve_IP_Address_Via_IPMI_And_Verify_Using_Redish |
| |
| ${active_channel_config}= Get Active Channel Config |
| FOR ${channel_number} IN @{active_channel_config.keys()} |
| Verify Channel Info ${channel_number} IPv4StaticAddresses ${active_channel_config} |
| END |
| |
| Retrieve Default Gateway Via IPMI And Verify |
| [Documentation] Retrieve default gateway via IPMI and verify it's existence on the BMC. |
| [Tags] Retrieve_Default_Gateway_Via_IPMI_And_Verify |
| |
| ${lan_print_ipmi}= Get LAN Print Dict |
| |
| Verify Gateway On BMC ${lan_print_ipmi['Default Gateway IP']} |
| |
| |
| Retrieve MAC Address Via IPMI And Verify Using Redfish |
| [Documentation] Retrieve MAC address via IPMI and verify using Redfish. |
| [Tags] Retrieve_MAC_Address_Via_IPMI_And_Verify_Using_Redfish |
| |
| ${active_channel_config}= Get Active Channel Config |
| FOR ${channel_number} IN @{active_channel_config.keys()} |
| Verify Channel Info ${channel_number} MACAddress ${active_channel_config} |
| END |
| |
| |
| Test Valid IPMI Channels Supported |
| [Documentation] Verify IPMI channels supported on a given system. |
| [Tags] Test_Valid_IPMI_Channels_Supported |
| |
| ${channel_count}= Get Physical Network Interface Count |
| |
| # Note: IPMI network channel logically starts from 1. |
| FOR ${channel_number} IN RANGE 1 ${channel_count} |
| Run IPMI Standard Command lan print ${channel_number} |
| END |
| |
| |
| Test Invalid IPMI Channel Response |
| [Documentation] Verify invalid IPMI channels supported response. |
| [Tags] Test_Invalid_IPMI_Channel_Response |
| |
| ${channel_count}= Get Physical Network Interface Count |
| |
| # To target invalid channel, increment count. |
| ${channel_number}= Evaluate ${channel_count} + 1 |
| |
| # Example of invalid channel: |
| # $ ipmitool -I lanplus -H xx.xx.xx.xx -P password lan print 3 |
| # Get Channel Info command failed: Parameter out of range |
| # Invalid channel: 3 |
| |
| ${stdout}= Run External IPMI Standard Command |
| ... lan print ${channel_number} fail_on_err=${0} |
| Should Contain ${stdout} Invalid channel |
| ... msg=IPMI channel ${channel_number} is invalid but seen working. |
| |
| |
| Get IP Address Source And Verify Using Redfish |
| [Documentation] Get IP address source and verify it using Redfish. |
| [Tags] Get_IP_Address_Source_And_Verify_Using_Redfish |
| |
| ${active_channel_config}= Get Active Channel Config |
| ${lan_config}= Get LAN Print Dict ${CHANNEL_NUMBER} |
| |
| ${ipv4_addresses}= Redfish.Get Attribute |
| ... /redfish/v1/Managers/bmc/EthernetInterfaces/${active_channel_config['${CHANNEL_NUMBER}']['name']} |
| ... IPv4Addresses |
| |
| FOR ${ipv4_address} IN @{ipv4_addresses} |
| ${ip_address_source}= |
| ... Set Variable if '${ipv4_address['Address']}' == '${lan_config['IP Address']}' |
| ... ${ipv4_address['AddressOrigin']} Address |
| Exit For Loop IF "${ip_address_source}" != 'None' |
| END |
| |
| Valid Value lan_config['IP Address Source'] ['${ip_address_source}'] |
| |
| |
| Verify Get Set In Progress |
| [Documentation] Verify Get Set In Progress which belongs to LAN Configuration Parameters |
| ... via IPMI raw Command. |
| [Tags] Verify_Get_Set_In_Progress |
| |
| ${ipmi_output}= Run IPMI Command |
| ... ${IPMI_RAW_CMD['LAN_Config_Params']['Get'][0]} ${CHANNEL_NUMBER} 0x00 0x00 0x00 |
| |
| ${ipmi_output}= Split String ${ipmi_output} |
| ${set_in_progress_value}= Set Variable ${ipmi_output[1]} |
| |
| # 00b = set complete. |
| # 01b = set in progress. |
| Should Contain Any ${set_in_progress_value} 00 01 |
| |
| |
| Verify Cipher Suite Entry Count |
| [Documentation] Verify cipher suite entry count which belongs to LAN Configuration Parameters |
| ... via IPMI raw Command. |
| [Tags] Verify_Cipher_Suite_Entry_Count |
| |
| ${ipmi_output}= Run IPMI Command |
| ... ${IPMI_RAW_CMD['LAN_Config_Params']['Get'][0]} ${CHANNEL_NUMBER} 0x16 0x00 0x00 |
| ${cipher_suite_entry_count}= Split String ${ipmi_output} |
| |
| # Convert minor cipher suite entry count from BCD format to integer. i.e. 01 to 1. |
| ${cipher_suite_entry_count[1]}= Convert To Integer ${cipher_suite_entry_count[1]} |
| ${cnt}= Get length ${valid_ciphers} |
| |
| Should be Equal ${cipher_suite_entry_count[1]} ${cnt} |
| |
| |
| Verify Authentication Type Support |
| [Documentation] Verify authentication type support which belongs to LAN Configuration Parameters |
| ... via IPMI raw Command. |
| [Tags] Verify_Authentication_Type_Support |
| |
| ${ipmi_output}= Run IPMI Command |
| ... ${IPMI_RAW_CMD['LAN_Config_Params']['Get'][0]} ${CHANNEL_NUMBER} 0x01 0x00 0x00 |
| |
| ${authentication_type_support}= Split String ${ipmi_output} |
| # All bits: |
| # 1b = supported |
| # 0b = authentication type not available for use |
| # [5] - OEM proprietary (per OEM identified by the IANA OEM ID in the RMCP Ping Response) |
| # [4] - straight password / key |
| # [3] - reserved |
| # [2] - MD5 |
| # [1] - MD2 |
| # [0] - none |
| Should Contain Any ${authentication_type_support[1]} 00 01 02 03 04 05 |
| |
| |
| *** Keywords *** |
| |
| Get Physical Network Interface Count |
| [Documentation] Return valid physical network interfaces count. |
| # Example: |
| # link/ether 22:3a:7f:70:92:cb brd ff:ff:ff:ff:ff:ff |
| # link/ether 0e:8e:0d:6b:e9:e4 brd ff:ff:ff:ff:ff:ff |
| |
| ${mac_entry_list}= Get BMC MAC Address List |
| ${mac_unique_list}= Remove Duplicates ${mac_entry_list} |
| ${physical_interface_count}= Get Length ${mac_unique_list} |
| |
| [Return] ${physical_interface_count} |
| |
| |
| Verify Channel Info |
| [Documentation] Verify the channel info. |
| [Arguments] ${channel_number} ${network_parameter} ${active_channel_config} |
| |
| Run Keyword If '${network_parameter}' == 'IPv4StaticAddresses' |
| ... Verify IPv4 Static Address ${channel_number} ${active_channel_config} |
| ... ELSE IF '${network_parameter}' == 'MACAddress' |
| ... Verify MAC Address ${channel_number} ${active_channel_config} |
| |
| |
| Verify IPv4 Static Address |
| [Documentation] Verify the IPv4 Static Address. |
| [Arguments] ${channel_number} ${active_channel_config} |
| |
| ${lan_print_ipmi}= Get LAN Print Dict ${channel_number} |
| ${ipv4_static_addresses}= Redfish.Get Attribute |
| ... ${REDFISH_NW_ETH_IFACE}${active_channel_config['${channel_number}']['name']} IPv4StaticAddresses |
| ${redfish_ips}= Nested Get Address ${ipv4_static_addresses} |
| Rprint Vars lan_print_ipmi ipv4_static_addresses redfish_ips |
| Valid Value lan_print_ipmi['IP Address'] ${redfish_ips} |
| |
| |
| Verify MAC Address |
| [Documentation] Verify the MAC Address. |
| [Arguments] ${channel_number} ${active_channel_config} |
| |
| ${lan_print_ipmi}= Get LAN Print Dict ${channel_number} |
| ${redfish_mac_address}= Redfish.Get Attribute |
| ... ${REDFISH_NW_ETH_IFACE}${active_channel_config['${channel_number}']['name']} MACAddress |
| Rprint Vars lan_print_ipmi redfish_mac_address |
| Valid Value lan_print_ipmi['MAC Address'] ['${redfish_mac_address}'] |