Split IPMI network into verification and configuration suites
Change-Id: I001f1db530973e3090f03986f9abd180b20c90a4
Signed-off-by: George Keishing <gkeishin@in.ibm.com>
diff --git a/ipmi/test_ipmi_network.robot b/ipmi/test_ipmi_network.robot
deleted file mode 100644
index e96d584..0000000
--- a/ipmi/test_ipmi_network.robot
+++ /dev/null
@@ -1,277 +0,0 @@
-*** 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
-
-Suite Setup Suite Setup Execution
-Test Setup Printn
-Test Teardown FFDC On Test Case Fail
-
-Force Tags IPMI_Network
-
-
-*** Variables ***
-${vlan_id} ${10}
-@{vlan_ids} ${20} ${30}
-${interface} eth0
-${ip} 10.0.0.1
-${initial_lan_config} &{EMPTY}
-${vlan_resource} ${NETWORK_MANAGER}action/VLAN
-
-*** 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.
-
-
-Verify IPMI Inband Network Configuration
- [Documentation] Verify BMC network configuration via inband IPMI.
- [Tags] Verify_IPMI_Inband_Network_Configuration
- [Teardown] Run Keywords Restore Configuration AND FFDC On Test Case Fail
-
- Redfish Power On
-
- Set IPMI Inband Network Configuration 10.10.10.10 255.255.255.0 10.10.10.10
- Sleep 10
-
- ${lan_print_output}= Get LAN Print Dict ${CHANNEL_NUMBER} ipmi_cmd_type=inband
- Valid Value lan_print_output['IP Address'] ["10.10.10.10"]
- Valid Value lan_print_output['Subnet Mask'] ["255.255.255.0"]
- Valid Value lan_print_output['Default Gateway IP'] ["10.10.10.10"]
-
-
-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}']
-
-Disable VLAN Via IPMI When Multiple VLAN Exist On BMC
- [Documentation] Disable VLAN Via IPMI When Multiple VLAN Exist On BMC.
- [Tags] Disable_VLAN_Via_IPMI_When_LAN_And_VLAN_Exist_On_BMC
- [Teardown] Run Keywords FFDC On Test Case Fail AND
- ... Create VLAN Via IPMI off AND Restore Configuration
-
- FOR ${id} IN @{vlan_ids}
- @{data_vlan_id}= Create List ${interface} ${id}
- ${data}= Create Dictionary data=@{data_vlan_id}
- ${resp}= OpenBMC Post Request ${vlan_resource} data=${data}
- END
-
- Create VLAN Via IPMI off
-
- ${lan_config}= Get LAN Print Dict ${CHANNEL_NUMBER} ipmi_cmd_type=inband
- Valid Value lan_config['802.1q VLAN ID'] ['Disabled']
-
-
-Configure IP On VLAN Via IPMI
- [Documentation] Configure IP On VLAN Via IPMI.
- [Tags] Configure_IP_On_VLAN_Via_IPMI
- [Teardown] Run Keywords FFDC On Test Case Fail AND
- ... Create VLAN Via IPMI off AND Restore Configuration
-
- Create VLAN Via IPMI ${vlan_id}
-
- Run Inband IPMI Standard Command
- ... lan set ${CHANNEL_NUMBER} ipaddr ${ip} login_host=${0}
-
- ${lan_config}= Get LAN Print Dict ${CHANNEL_NUMBER} ipmi_cmd_type=inband
- Valid Value lan_config['802.1q VLAN ID'] ['${vlan_id}']
- Valid Value lan_config['IP Address'] ["${ip}"]
-
-
-Create VLAN Via IPMI When LAN And VLAN Exist On BMC
- [Documentation] Create VLAN Via IPMI When LAN And VLAN Exist On BMC.
- [Tags] Create_VLAN_Via_IPMI_When_LAN_And_VLAN_Exist_On_BMC
- [Teardown] Run Keywords FFDC On Test Case Fail AND
- ... Create VLAN Via IPMI off AND Restore Configuration
-
- @{data_vlan_id}= Create List ${interface} ${vlan_id}
- ${data}= Create Dictionary data=@{data_vlan_id}
- ${resp}= OpenBMC Post Request ${vlan_resource} data=${data}
-
- Create VLAN Via IPMI ${vlan_id}
-
- ${lan_config}= Get LAN Print Dict ${CHANNEL_NUMBER} ipmi_cmd_type=inband
- Valid Value lan_config['802.1q VLAN ID'] ['${vlan_id}']
-
-
-*** 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}
-
-
-Set IPMI Inband Network Configuration
- [Documentation] Run sequence of standard IPMI command in-band and set
- ... the IP configuration.
- [Arguments] ${ip} ${netmask} ${gateway} ${login}=${1}
-
- # 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.
-
- Run Inband IPMI Standard Command
- ... lan set ${CHANNEL_NUMBER} ipsrc static login_host=${login}
- 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 ${network_configurations[0]['Address']}
- ... ${network_configurations[0]['SubnetMask']}
- ... ${initial_lan_config['Default Gateway IP']} login=${0}
-
-
-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}']
-
-
-Create VLAN Via IPMI
- [Documentation] Create VLAN via inband IPMI command.
- [Arguments] ${vlan_id} ${channel_number}=${CHANNEL_NUMBER}
-
- # Description of argument(s):
- # vlan_id The VLAN ID (e.g. '10').
-
- Run Inband IPMI Standard Command
- ... lan set ${channel_number} vlan id ${vlan_id} login_host=${0}
-
-
-Suite Setup Execution
- [Documentation] Suite Setup Execution.
-
- Redfish.Login
-
- Run Inband IPMI Standard Command
- ... lan set ${CHANNEL_NUMBER} ipsrc static login_host=${1}
-
- @{network_configurations}= Get Network Configuration
- Set Suite Variable @{network_configurations}
-
- ${initial_lan_config}= Get LAN Print Dict ${CHANNEL_NUMBER} ipmi_cmd_type=inband
- Set Suite Variable ${initial_lan_config}
diff --git a/ipmi/test_ipmi_network_configuration.robot b/ipmi/test_ipmi_network_configuration.robot
new file mode 100644
index 0000000..ab94df8
--- /dev/null
+++ b/ipmi/test_ipmi_network_configuration.robot
@@ -0,0 +1,150 @@
+*** 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
+
+Suite Setup Suite Setup Execution
+Test Setup Printn
+Test Teardown FFDC On Test Case Fail
+
+Force Tags IPMI_Network_Config
+
+
+*** Variables ***
+${vlan_id} ${10}
+@{vlan_ids} ${20} ${30}
+${interface} eth0
+${ip} 10.0.0.1
+${initial_lan_config} &{EMPTY}
+${vlan_resource} ${NETWORK_MANAGER}action/VLAN
+
+*** Test Cases ***
+
+Verify IPMI Inband Network Configuration
+ [Documentation] Verify BMC network configuration via inband IPMI.
+ [Tags] Verify_IPMI_Inband_Network_Configuration
+ [Teardown] Run Keywords Restore Configuration AND FFDC On Test Case Fail
+
+ Redfish Power On
+
+ Set IPMI Inband Network Configuration 10.10.10.10 255.255.255.0 10.10.10.10
+ Sleep 10
+
+ ${lan_print_output}= Get LAN Print Dict ${CHANNEL_NUMBER} ipmi_cmd_type=inband
+ Valid Value lan_print_output['IP Address'] ["10.10.10.10"]
+ Valid Value lan_print_output['Subnet Mask'] ["255.255.255.0"]
+ Valid Value lan_print_output['Default Gateway IP'] ["10.10.10.10"]
+
+
+Disable VLAN Via IPMI When Multiple VLAN Exist On BMC
+ [Documentation] Disable VLAN Via IPMI When Multiple VLAN Exist On BMC.
+ [Tags] Disable_VLAN_Via_IPMI_When_LAN_And_VLAN_Exist_On_BMC
+ [Teardown] Run Keywords FFDC On Test Case Fail AND
+ ... Create VLAN Via IPMI off AND Restore Configuration
+
+ FOR ${id} IN @{vlan_ids}
+ @{data_vlan_id}= Create List ${interface} ${id}
+ ${data}= Create Dictionary data=@{data_vlan_id}
+ ${resp}= OpenBMC Post Request ${vlan_resource} data=${data}
+ END
+
+ Create VLAN Via IPMI off
+
+ ${lan_config}= Get LAN Print Dict ${CHANNEL_NUMBER} ipmi_cmd_type=inband
+ Valid Value lan_config['802.1q VLAN ID'] ['Disabled']
+
+
+Configure IP On VLAN Via IPMI
+ [Documentation] Configure IP On VLAN Via IPMI.
+ [Tags] Configure_IP_On_VLAN_Via_IPMI
+ [Teardown] Run Keywords FFDC On Test Case Fail AND
+ ... Create VLAN Via IPMI off AND Restore Configuration
+
+ Create VLAN Via IPMI ${vlan_id}
+
+ Run Inband IPMI Standard Command
+ ... lan set ${CHANNEL_NUMBER} ipaddr ${ip} login_host=${0}
+
+ ${lan_config}= Get LAN Print Dict ${CHANNEL_NUMBER} ipmi_cmd_type=inband
+ Valid Value lan_config['802.1q VLAN ID'] ['${vlan_id}']
+ Valid Value lan_config['IP Address'] ["${ip}"]
+
+
+Create VLAN Via IPMI When LAN And VLAN Exist On BMC
+ [Documentation] Create VLAN Via IPMI When LAN And VLAN Exist On BMC.
+ [Tags] Create_VLAN_Via_IPMI_When_LAN_And_VLAN_Exist_On_BMC
+ [Teardown] Run Keywords FFDC On Test Case Fail AND
+ ... Create VLAN Via IPMI off AND Restore Configuration
+
+ @{data_vlan_id}= Create List ${interface} ${vlan_id}
+ ${data}= Create Dictionary data=@{data_vlan_id}
+ ${resp}= OpenBMC Post Request ${vlan_resource} data=${data}
+
+ Create VLAN Via IPMI ${vlan_id}
+
+ ${lan_config}= Get LAN Print Dict ${CHANNEL_NUMBER} ipmi_cmd_type=inband
+ Valid Value lan_config['802.1q VLAN ID'] ['${vlan_id}']
+
+
+*** Keywords ***
+
+Create VLAN Via IPMI
+ [Documentation] Create VLAN via inband IPMI command.
+ [Arguments] ${vlan_id} ${channel_number}=${CHANNEL_NUMBER}
+
+ # Description of argument(s):
+ # vlan_id The VLAN ID (e.g. '10').
+
+ Run Inband IPMI Standard Command
+ ... lan set ${channel_number} vlan id ${vlan_id} login_host=${0}
+
+
+Set IPMI Inband Network Configuration
+ [Documentation] Run sequence of standard IPMI command in-band and set
+ ... the IP configuration.
+ [Arguments] ${ip} ${netmask} ${gateway} ${login}=${1}
+
+ # 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.
+
+ Run Inband IPMI Standard Command
+ ... lan set ${CHANNEL_NUMBER} ipsrc static login_host=${login}
+ 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 ${network_configurations[0]['Address']}
+ ... ${network_configurations[0]['SubnetMask']}
+ ... ${initial_lan_config['Default Gateway IP']} login=${0}
+
+
+Suite Setup Execution
+ [Documentation] Suite Setup Execution.
+
+ Redfish.Login
+
+ Run Inband IPMI Standard Command
+ ... lan set ${CHANNEL_NUMBER} ipsrc static login_host=${1}
+
+ @{network_configurations}= Get Network Configuration
+ Set Suite Variable @{network_configurations}
+
+ ${initial_lan_config}= Get LAN Print Dict ${CHANNEL_NUMBER} ipmi_cmd_type=inband
+ Set Suite Variable ${initial_lan_config}
diff --git a/ipmi/test_ipmi_network_verificaton.robot b/ipmi/test_ipmi_network_verificaton.robot
new file mode 100644
index 0000000..39bac45
--- /dev/null
+++ b/ipmi/test_ipmi_network_verificaton.robot
@@ -0,0 +1,146 @@
+*** 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
+
+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}']
+
+
+*** 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}']