blob: e3f400a7b2e936f7f7f9183bc003e774c2efeb1e [file] [log] [blame]
*** Settings ***
Documentation Vmi network utilities keywords.
Resource ../../lib/resource.robot
Resource ../../lib/bmc_redfish_resource.robot
Resource ../../lib/openbmc_ffdc.robot
Resource ../../lib/bmc_redfish_utils.robot
Resource ../../lib/state_manager.robot
Resource ../../lib/bmc_network_utils.robot
Library ../../lib/bmc_network_utils.py
*** Variables ***
${wait_time} 10s
*** Keywords ***
Set Static IPv4 Address To VMI And Verify
[Documentation] Set static IPv4 address to VMI.
[Arguments] ${ip} ${gateway} ${netmask} ${valid_status_code}=${HTTP_ACCEPTED}
... ${interface}=eth0
# Description of argument(s):
# ip VMI IPv4 address.
# gateway Gateway for VMI IP.
# netmask Subnetmask for VMI IP.
# valid_status_code Expected valid status code from GET request. Default is HTTP_ACCEPTED.
# interface VMI interface (eg. eth0 or eth1).
${ip_details}= Create dictionary Address=${ip} SubnetMask=${netmask} Gateway=${gateway}
${ip_data}= Create List ${ip_details}
${resp}= Redfish.Patch /redfish/v1/Systems/hypervisor/EthernetInterfaces/${interface}
... body={'IPv4StaticAddresses':${ip_data}} valid_status_codes=[${valid_status_code}]
# Wait few seconds for new configuration to get populated on runtime.
Sleep ${wait_time}
Return From Keyword If ${valid_status_code} != ${HTTP_ACCEPTED}
${host_power_state} ${host_state}= Redfish Get Host State
Run Keyword If '${host_power_state}' == 'On' and '${host_state}' == 'Enabled'
... Verify VMI Network Interface Details ${ip} Static ${gateway} ${netmask} ${interface}
Verify VMI Network Interface Details
[Documentation] Verify VMI network interface details.
[Arguments] ${ip} ${origin} ${gateway} ${netmask}
... ${interface}=eth0 ${valid_status_code}=${HTTP_OK}
# Description of argument(s):
# ip VMI IPv4 address.
# origin Origin of IPv4 address eg. Static or DHCP.
# gateway Gateway for VMI IP.
# netmask Subnetmask for VMI IP.
# interface VMI interface (eg. eth0 or eth1).
# valid_status_code Expected valid status code from GET request. Default is HTTP_OK.
${vmi_ip}= Get VMI Network Interface Details ${interface} ${valid_status_code}
Should Be Equal As Strings ${origin} ${vmi_ip["IPv4_AddressOrigin"]}
Should Be Equal As Strings ${gateway} ${vmi_ip["IPv4_Gateway"]}
Should Be Equal As Strings ${netmask} ${vmi_ip["IPv4_SubnetMask"]}
Should Be Equal As Strings ${ip} ${vmi_ip["IPv4_Address"]}
Delete VMI IPv4 Address
[Documentation] Delete VMI IPv4 address.
[Arguments] ${delete_param}=IPv4StaticAddresses ${valid_status_code}=${HTTP_ACCEPTED}
... ${interface}=eth0
# Description of argument(s):
# delete_param Parameter to be deleted eg. IPv4StaticAddresses or IPv4Addresses.
# Default is IPv4StaticAddresses.
# valid_status_code Expected valid status code from PATCH request. Default is HTTP_OK.
# interface VMI interface (eg. eth0 or eth1).
${data}= Set Variable {"${delete_param}": [${Null}]}
${resp}= Redfish.Patch
... /redfish/v1/Systems/hypervisor/EthernetInterfaces/${interface}
... body=${data} valid_status_codes=[${valid_status_code}]
Return From Keyword If ${valid_status_code} != ${HTTP_ACCEPTED}
# Wait few seconds for configuration to get effective.
Sleep ${wait_time}
${vmi_ip}= Get VMI Network Interface Details ${interface}
Should Be Empty ${vmi_ip["IPv4_Address"]}
Set VMI IPv4 Origin
[Documentation] Set VMI IPv4 origin.
[Arguments] ${dhcp_enabled}=${False} ${valid_status_code}=${HTTP_ACCEPTED}
... ${interface}=eth0
# Description of argument(s):
# dhcp_enabled True if user wants to enable DHCP. Default is Static, hence value is set to False.
# valid_status_code Expected valid status code from PATCH request. Default is HTTP_OK.
# interface VMI interface (eg. eth0 or eth1).
${data}= Set Variable If ${dhcp_enabled} == ${False} ${DISABLE_DHCP} ${ENABLE_DHCP}
${resp}= Redfish.Patch
... /redfish/v1/Systems/hypervisor/EthernetInterfaces/${interface}
... body=${data} valid_status_codes=[${valid_status_code}]
Sleep ${wait_time}
Return From Keyword If ${valid_status_code} != ${HTTP_ACCEPTED}
${resp}= Redfish.Get
... /redfish/v1/Systems/hypervisor/EthernetInterfaces/${interface}
Should Be Equal ${resp.dict["DHCPv4"]["DHCPEnabled"]} ${dhcp_enabled}
Get VMI Network Interface Details
[Documentation] Get VMI network interface details.
[Arguments] ${interface}=eth0 ${valid_status_code}=${HTTP_OK}
# Description of argument(s):
# interface VMI interface (eg. eth0 or eth1).
# valid_status_code Expected valid status code from GET request.
# Note: It returns a dictionary of VMI ethernet interface parameters.
${resp}= Redfish.Get
... /redfish/v1/Systems/hypervisor/EthernetInterfaces/${interface}
... valid_status_codes=[${valid_status_code}]
${ip_resp}= Evaluate json.loads(r'''${resp.text}''') json
${ip_exists}= Set Variable If ${ip_resp["IPv4Addresses"]} == @{empty} ${False} ${True}
${static_exists}= Set Variable If ${ip_resp["IPv4StaticAddresses"]} == @{empty} ${False} ${True}
${vmi_ip}= Run Keyword If ${ip_exists} == ${True}
... Create Dictionary DHCPv4=${${ip_resp["DHCPv4"]["DHCPEnabled"]}} Id=${ip_resp["Id"]}
... Description=${ip_resp["Description"]} IPv4_Address=${ip_resp["IPv4Addresses"][0]["Address"]}
... IPv4_AddressOrigin=${ip_resp["IPv4Addresses"][0]["AddressOrigin"]} Name=${ip_resp["Name"]}
... IPv4_Gateway=${ip_resp["IPv4Addresses"][0]["Gateway"]}
... InterfaceEnabled=${${ip_resp["InterfaceEnabled"]}}
... IPv4_SubnetMask=${ip_resp["IPv4Addresses"][0]["SubnetMask"]}
... IPv4StaticAddresses=${${static_exists}}
... ELSE
... Create Dictionary DHCPv4=${${ip_resp["DHCPv4"]["DHCPEnabled"]}} Id=${ip_resp["Id"]}
... Description=${ip_resp["Description"]} IPv4StaticAddresses=${ip_resp["IPv4StaticAddresses"]}
... IPv4_Address=${ip_resp["IPv4Addresses"]} Name=${ip_resp["Name"]}
... InterfaceEnabled=${${ip_resp["InterfaceEnabled"]}}
[Return] &{vmi_ip}
Get VMI Interfaces
[Documentation] Get VMI network interface.
[Arguments] ${valid_status_code}=${HTTP_OK}
# Description of argument(s):
# valid_status_code Expected valid status code from GET request.
# By default set to ${HTTP_OK}.
${resp}= Redfish.Get /redfish/v1/Systems/hypervisor/EthernetInterfaces
... valid_status_codes=[${valid_status_code}]
${resp}= Evaluate json.loads(r'''${resp.text}''') json
${interfaces_uri}= Set Variable ${resp["Members"]}
${interface_list}= Create List
${number_of_interfaces}= Get Length ${interfaces_uri}
FOR ${interface} IN RANGE ${number_of_interfaces}
${_} ${interface_value}= Split String From Right ${interfaces_uri[${interface}]}[@odata.id] / 1
Append To List ${interface_list} ${interface_value}
END
[Return] @{interface_list}
Verify VMI EthernetInterfaces
[Documentation] Verify VMI ethernet interfaces.
[Arguments] ${valid_status_code}=${HTTP_OK}
# Description of argument(s):
# valid_status_code Expected valid status code from GET request.
${resp}= Redfish.Get /redfish/v1/Systems/hypervisor/EthernetInterfaces
... valid_status_codes=[${valid_status_code}]
${resp}= Evaluate json.loads(r'''${resp.text}''') json
${interfaces}= Set Variable ${resp["Members"]}
${number_of_interfaces}= Get Length ${interfaces}
FOR ${i} IN RANGE ${number_of_interfaces}
Should Be Equal As Strings ${interfaces[${i}]}[@odata.id]
... /redfish/v1/Systems/hypervisor/EthernetInterfaces/eth${i}
END
Should Be Equal ${resp["Members@odata.count"]} ${number_of_interfaces}
Get And Set Static VMI IP
[Documentation] Get a suitable VMI IP and set it.
[Arguments] ${host}=${OPENBMC_HOST} ${network_active_channel}=${CHANNEL_NUMBER}
... ${interface}=eth0 ${valid_status_code}=${HTTP_ACCEPTED}
# Description of argument(s):
# host BMC host name or IP address.
# network_active_channel Ethernet channel number (e.g.1 or 2).
# interface VMI interface (eg. eth0 or eth1).
# valid_status_code Expected valid status code from PATCH request. Default is HTTP_ACCEPTED.
${vmi_ip}= Get First Non Pingable IP From Subnet ${host}
${bmc_ip_data}= Get Network Configuration ${network_active_channel}
Set Static IPv4 Address To VMI And Verify ${vmi_ip} ${bmc_ip_data[0]['Gateway']}
... ${bmc_ip_data[0]['SubnetMask']} ${valid_status_code} ${interface}
[Return] ${vmi_ip} ${bmc_ip_data}