*** Settings *** Documentation DHCP Network to test suite functionality. Resource ../lib/openbmc_ffdc.robot Resource ../lib/bmc_network_utils.robot Library ../lib/ipmi_utils.py Library ../lib/bmc_network_utils.py Suite Setup Suite Setup Execution Suite Teardown Redfish.Logout *** Variables *** &{dhcp_enable_dict} DHCPEnabled=${True} &{dhcp_disable_dict} DHCPEnabled=${False} &{dns_enable_dict} UseDNSServers=${True} &{dns_disable_dict} UseDNSServers=${False} &{ntp_enable_dict} UseNTPServers=${True} &{ntp_disable_dict} UseNTPServers=${False} &{domain_name_enable_dict} UseDomainName=${True} &{domain_name_disable_dict} UseDomainName=${False} &{enable_multiple_properties} UseDomainName=${True} ... UseNTPServers=${True} ... UseDNSServers=${True} &{disable_multiple_properties} UseDomainName=${False} ... UseNTPServers=${False} ... UseDNSServers=${False} *** Test Cases *** Set Network Property via Redfish And Verify [Documentation] Set network property via Redfish and verify. [Tags] Set_Network_Property_via_Redfish_And_Verify [Template] Apply Ethernet Config # property ${dhcp_enable_dict} ${dhcp_disable_dict} ${dns_enable_dict} ${dns_disable_dict} ${domain_name_enable_dict} ${domain_name_disable_dict} ${ntp_enable_dict} ${ntp_disable_dict} ${enable_multiple_properties} ${disable_multiple_properties} *** Keywords *** Suite Setup Execution [Documentation] Suite Setup Execution. Redfish.Login # This keyword should login to host OS. Run Inband IPMI Standard Command ... lan set ${CHANNEL_NUMBER} ipsrc static login_host=${1} ${host_name} ${ip_address}= Get Host Name IP host=${OPENBMC_HOST} Set Suite Variable ${ip_address} @{network_configurations}= Get Network Configuration FOR ${network_configuration} IN @{network_configurations} Run Keyword If '${network_configuration['Address']}' == '${ip_address}' ... Set Suite Variable ${subnet_mask} ${network_configuration['SubnetMask']} END ${initial_lan_config}= Get LAN Print Dict ${CHANNEL_NUMBER} ipmi_cmd_type=inband Set Suite Variable ${initial_lan_config} Set IPMI Inband Network Configuration [Documentation] Run sequence of standard in-band IPMI command and set ... the IP configuration. [Arguments] ${ip} ${netmask} ${gateway} # Description of argument(s): # ip The IP address to be set using ipmitool-inband. # netmask The Netmask to be set using ipmitool-inband. # gateway The Gateway address to be set using ipmitool-inband. # login Indicates that this keyword should login to host OS. Run Inband IPMI Standard Command ... lan set ${CHANNEL_NUMBER} ipaddr ${ip} login_host=${0} Run Inband IPMI Standard Command ... lan set ${CHANNEL_NUMBER} netmask ${netmask} login_host=${0} Run Inband IPMI Standard Command ... lan set ${CHANNEL_NUMBER} defgw ipaddr ${gateway} login_host=${0} Restore Configuration [Documentation] Restore the configuration to its pre-test state. ${length}= Get Length ${initial_lan_config} Return From Keyword If ${length} == ${0} Set IPMI Inband Network Configuration ${ip_address} ${subnet_mask} ... ${initial_lan_config['Default Gateway IP']} Apply Ethernet Config [Documentation] Set the given Ethernet config property. [Arguments] ${property} [Teardown] Run Keywords Restore Configuration AND ... Set Global Variable ${TEST_STATUS} ${KEYWORD STATUS} AND FFDC On Test Case Fail # Description of argument(s): # property Ethernet property to be set.. ${active_channel_config}= Get Active Channel Config Redfish.Patch ... /redfish/v1/Managers/bmc/EthernetInterfaces/${active_channel_config['${CHANNEL_NUMBER}']['name']}/ ... body={"DHCPv4":${property}} valid_status_codes=[${HTTP_OK}, ${HTTP_NO_CONTENT}] ${resp}= Redfish.Get ... /redfish/v1/Managers/bmc/EthernetInterfaces/${active_channel_config['${CHANNEL_NUMBER}']['name']} Verify Ethernet Config Property ${property} ${resp.dict["DHCPv4"]} Verify Ethernet Config Property [Documentation] verify ethernet config properties. [Arguments] ${property} ${response_data} # Description of argument(s): # ${property} DHCP Properties in dictionary. # Example: # property value # DHCPEnabled :False # UseDomainName :True # UseNTPServers :True # UseDNSServers :True # ${response_data} DHCP Response data in dictionary. # Example: # property value # DHCPEnabled :False # UseDomainName :True # UseNTPServers :True # UseDNSServers :True ${key_map}= Get Dictionary Items ${property} FOR ${key} ${value} IN @{key_map} Should Be Equal As Strings ${response_data['${key}']} ${value} END