... that the instance is fully up and ready.
${devstack_conn_id}= Get ControlNode Connection
Switch Connection ${devstack_conn_id}
- ${ip_list} Create List
+ ${ip_list} Create List @{EMPTY}
+ ${dhcp_ip} Create List @{EMPTY}
: FOR ${vm} IN @{vm_list}
- \ ${output}= Write Commands Until Prompt nova console-log ${vm} | grep -i "obtained" 30s
+ \ ${vm_ip_line}= Write Commands Until Prompt nova console-log ${vm} | grep -i "obtained" 30s
+ \ Log ${vm_ip_line}
+ \ @{vm_ip} Get Regexp Matches ${vm_ip_line} [0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}
+ \ ${vm_ip_length} Get Length ${vm_ip}
+ \ Run Keyword If ${vm_ip_length}>0 Append To List ${ip_list} @{vm_ip}[0]
\ ${dhcp_ip_line}= Write Commands Until Prompt nova console-log ${vm} | grep "^nameserver" 30s
- \ Log ${output}
- \ @{output_words} Split String ${output}
- \ @{dhcp_output_words} Split String ${dhcp_ip_line}
- \ Should Contain ${output} obtained
- \ Append To List ${ip_list} @{output_words}[2]
- [Return] ${ip_list} @{dhcp_output_words}[1]
+ \ Log ${dhcp_ip_line}
+ \ @{dhcp_ip} Get Regexp Matches ${dhcp_ip_line} [0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}
+ \ Log ${dhcp_ip}
+ ${dhcp_length} Get Length ${dhcp_ip}
+ Return From Keyword If ${dhcp_length}==0 ${ip_list} ${EMPTY}
+ [Return] ${ip_list} @{dhcp_ip}[0]
View Vm Console
[Arguments] ${vm_instance_names}
Documentation Test suite to verify packet flows between vm instances.
Suite Setup Devstack Suite Setup source_pwd=yes
Suite Teardown Close All Connections
-Test Teardown Run Keywords Show Debugs @{NET_1_VM_INSTANCES} @{NET_2_VM_INSTANCES}
-... AND Get OvsDebugInfo
+Test Setup SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing
+Test Teardown Run Keywords Get OvsDebugInfo
Library SSHLibrary
Library OperatingSystem
Library RequestsLibrary
Resource ../../../libraries/OVSDB.robot
Resource ../../../libraries/ClusterOvsdb.robot
Resource ../../../libraries/ClusterManagement.robot
+Resource ../../../libraries/SetupUtils.robot
Variables ../../../variables/Variables.py
*** Variables ***
@{SUBNETS_NAME} l2_sub_net_1 l2_sub_net_2
@{NET_1_VM_INSTANCES} VmInstance1_l2_net_1 VmInstance2_net_1 VmInstance3_net_1
@{NET_2_VM_INSTANCES} VmInstance1_l2_net_2 VmInstance2_net_2 VmInstance3_net_2
-@{NET_1_VM_IPS} 70.0.0.3 70.0.0.4 70.0.0.5
-@{NET_2_VM_IPS} 80.0.0.3 80.0.0.4 80.0.0.5
@{VM_IPS_NOT_DELETED} 70.0.0.4
-@{GATEWAY_IPS} 70.0.0.1 80.0.0.1
-@{DHCP_IPS} 70.0.0.2 80.0.0.2
@{cluster_down_list} ${1} ${2}
@{SUBNETS_RANGE} 70.0.0.0/24 80.0.0.0/24
[Documentation] Delete bridge with OVS command and verify it gets deleted from all instances.
ClusterOvsdb.Delete Sample Bridge Manually And Verify ${OS_CONTROL_NODE_IP} ${new_cluster_list}
-Create Vm Instances For l2_net_1
- [Documentation] Create Vm instances using flavor and image names for a network.
- Log ${devstack_conn_id}
- OpenStackOperations.Create Vm Instances l2_net_1 ${NET_1_VM_INSTANCES} sg=csit
-
Bring Up ODL1
[Documentation] Bring up ODL1 again
ClusterManagement.Start Single Member 1
[Documentation] Create Vm instances using flavor and image names for a network.
OpenStackOperations.Create Vm Instances l2_net_2 ${NET_2_VM_INSTANCES} sg=csit
+Create Vm Instances For l2_net_1
+ [Documentation] Create Vm instances using flavor and image names for a network.
+ Log ${devstack_conn_id}
+ OpenStackOperations.Create Vm Instances l2_net_1 ${NET_1_VM_INSTANCES} sg=csit
+
+Check Vm Instances Have Ip Address
+ [Documentation] Test case to verify that all created VMs are ready and have received their ip addresses.
+ ... We are polling first and longest on the last VM created assuming that if it's received it's address
+ ... already the other instances should have theirs already or at least shortly thereafter.
+ # first, ensure all VMs are in ACTIVE state. if not, we can just fail the test case and not waste time polling
+ # for dhcp addresses
+ : FOR ${vm} IN @{NET_1_VM_INSTANCES} @{NET_2_VM_INSTANCES}
+ \ Wait Until Keyword Succeeds 15s 5s Verify VM Is ACTIVE ${vm}
+ ${NET1_VM_COUNT} Get Length ${NET_1_VM_INSTANCES}
+ ${NET2_VM_COUNT} Get Length ${NET_2_VM_INSTANCES}
+ ${LOOP_COUNT} Evaluate ${NET1_VM_COUNT}+${NET2_VM_COUNT}
+ : FOR ${index} IN RANGE 1 ${LOOP_COUNT}
+ \ ${NET1_VM_IPS} ${NET1_DHCP_IP} Verify VMs Received DHCP Lease @{NET_1_VM_INSTANCES}
+ \ ${NET2_VM_IPS} ${NET2_DHCP_IP} Verify VMs Received DHCP Lease @{NET_2_VM_INSTANCES}
+ \ ${NET1_VM_LIST_LENGTH}= Get Length ${NET1_VM_IPS}
+ \ ${NET2_VM_LIST_LENGTH}= Get Length ${NET2_VM_IPS}
+ \ Exit For Loop If ${NET1_VM_LIST_LENGTH}==${NET1_VM_COUNT} and ${NET2_VM_LIST_LENGTH}==${NET2_VM_COUNT}
+ Append To List ${NET1_VM_IPS} ${NET1_DHCP_IP}
+ Set Suite Variable ${NET1_VM_IPS}
+ Append To List ${NET2_VM_IPS} ${NET2_DHCP_IP}
+ Set Suite Variable ${NET2_VM_IPS}
+ [Teardown] Run Keywords Show Debugs @{NET_1_VM_INSTANCES} @{NET_2_VM_INSTANCES}
+ ... AND Get OvsDebugInfo
+
Bring Up ODL2
[Documentation] Bring up ODL2 again
ClusterManagement.Start Single Member 2
Connectivity Tests From Vm Instance1 In l2_net_1
[Documentation] Logging to the vm instance using generated key pair.
- ${dst_ip_list}= Create List @{NET_1_VM_IPS}[1] @{DHCP_IPS}[0] @{NET_1_VM_IPS}[2]
- Log ${dst_ip_list}
- Get OvsDebugInfo
- OpenStackOperations.Test Operations From Vm Instance l2_net_1 @{NET_1_VM_IPS}[0] ${dst_ip_list}
+ OpenStackOperations.Test Operations From Vm Instance l2_net_1 @{NET_1_VM_IPS}[0] ${NET_1_VM_IPS}
Connectivity Tests From Vm Instance2 In l2_net_1
[Documentation] Logging to the vm instance using generated key pair.
- ${dst_ip_list}= Create List @{NET_1_VM_IPS}[0] @{DHCP_IPS}[0] @{NET_1_VM_IPS}[2]
- Log ${dst_ip_list}
- Get OvsDebugInfo
- OpenStackOperations.Test Operations From Vm Instance l2_net_1 @{NET_1_VM_IPS}[1] ${dst_ip_list}
+ OpenStackOperations.Test Operations From Vm Instance l2_net_1 @{NET_1_VM_IPS}[1] ${NET_1_VM_IPS}
Connectivity Tests From Vm Instance3 In l2_net_1
[Documentation] Logging to the vm instance using generated key pair.
- ${dst_ip_list}= Create List @{NET_1_VM_IPS}[0] @{DHCP_IPS}[0] @{NET_1_VM_IPS}[1]
- Log ${dst_ip_list}
- Get OvsDebugInfo
- OpenStackOperations.Test Operations From Vm Instance l2_net_1 @{NET_1_VM_IPS}[2] ${dst_ip_list}
+ OpenStackOperations.Test Operations From Vm Instance l2_net_1 @{NET_1_VM_IPS}[2] ${NET_1_VM_IPS}
Bring Up ODL3
[Documentation] Bring up ODL3 again
Connectivity Tests From Vm Instance1 In l2_net_2
[Documentation] Logging to the vm instance using generated key pair.
- ${dst_ip_list}= Create List @{NET_2_VM_IPS}[1] @{DHCP_IPS}[1] @{NET_2_VM_IPS}[2]
- Log ${dst_ip_list}
- Get OvsDebugInfo
- OpenStackOperations.Test Operations From Vm Instance l2_net_2 @{NET_2_VM_IPS}[0] ${dst_ip_list}
+ OpenStackOperations.Test Operations From Vm Instance l2_net_2 @{NET_2_VM_IPS}[0] ${NET_2_VM_IPS}
Connectivity Tests From Vm Instance2 In l2_net_2
[Documentation] Logging to the vm instance using generated key pair.
- ${dst_ip_list}= Create List @{NET_2_VM_IPS}[0] @{DHCP_IPS}[1] @{NET_2_VM_IPS}[2]
- Log ${dst_ip_list}
- Get OvsDebugInfo
- OpenStackOperations.Test Operations From Vm Instance l2_net_2 @{NET_2_VM_IPS}[1] ${dst_ip_list}
+ OpenStackOperations.Test Operations From Vm Instance l2_net_2 @{NET_2_VM_IPS}[1] ${NET_2_VM_IPS}
Connectivity Tests From Vm Instance3 In l2_net_2
[Documentation] Logging to the vm instance using generated key pair.
- ${dst_ip_list}= Create List @{NET_2_VM_IPS}[0] @{DHCP_IPS}[1] @{NET_2_VM_IPS}[1]
- Log ${dst_ip_list}
- Get OvsDebugInfo
- OpenStackOperations.Test Operations From Vm Instance l2_net_2 @{NET_2_VM_IPS}[2] ${dst_ip_list}
+ OpenStackOperations.Test Operations From Vm Instance l2_net_2 @{NET_2_VM_IPS}[2] ${NET_2_VM_IPS}
Bring Up ODL1 and ODL2
[Documentation] Bring up ODL1 and ODL2 again.
Documentation Test suite to check connectivity in L3 using routers.
Suite Setup Devstack Suite Setup source_pwd=yes
Suite Teardown Close All Connections
-Test Teardown Run Keywords Show Debugs @{NET_1_VM_INSTANCES} @{NET_2_VM_INSTANCES}
-... AND Get OvsDebugInfo
+Test Setup SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing
+Test Teardown Run Keywords Get OvsDebugInfo
Library SSHLibrary
Library OperatingSystem
Library RequestsLibrary
+Library Collections
Resource ../../../libraries/Utils.robot
Resource ../../../libraries/OpenStackOperations.robot
Resource ../../../libraries/DevstackUtils.robot
+Resource ../../../libraries/OVSDB.robot
+Resource ../../../libraries/ClusterOvsdb.robot
Resource ../../../libraries/ClusterManagement.robot
+Resource ../../../libraries/SetupUtils.robot
+Variables ../../../variables/Variables.py
*** Variables ***
@{NETWORKS_NAME} l3_net_1 l3_net_2
@{SUBNETS_NAME} l3_sub_net_1 l3_sub_net_2
@{NET_1_VM_INSTANCES} VmInstance1_net_1 VmInstance2_net_1 VmInstance3_net_1
@{NET_2_VM_INSTANCES} VmInstance1_net_2 VmInstance2_net_2 VmInstance3_net_2
-@{NET_1_VM_IPS} 90.0.0.3 90.0.0.4 90.0.0.5
-@{NET_2_VM_IPS} 100.0.0.3 100.0.0.4 100.0.0.5
@{GATEWAY_IPS} 90.0.0.1 100.0.0.1
-@{DHCP_IPS} 90.0.0.2 100.0.0.2
@{SUBNETS_RANGE} 90.0.0.0/24 100.0.0.0/24
@{odl_1_and_2_down} ${1} ${2}
@{odl_2_and_3_down} ${2} ${3}
[Documentation] Create Four Vm instances using flavor and image names for a network.
OpenStackOperations.Create Vm Instances l3_net_2 ${NET_2_VM_INSTANCES} sg=csit
+Check Vm Instances Have Ip Address
+ [Documentation] Test case to verify that all created VMs are ready and have received their ip addresses.
+ ... We are polling first and longest on the last VM created assuming that if it's received it's address
+ ... already the other instances should have theirs already or at least shortly thereafter.
+ # first, ensure all VMs are in ACTIVE state. if not, we can just fail the test case and not waste time polling
+ # for dhcp addresses
+ : FOR ${vm} IN @{NET_1_VM_INSTANCES} @{NET_2_VM_INSTANCES}
+ \ Wait Until Keyword Succeeds 15s 5s Verify VM Is ACTIVE ${vm}
+ ${NET1_VM_COUNT} Get Length ${NET_1_VM_INSTANCES}
+ ${NET2_VM_COUNT} Get Length ${NET_2_VM_INSTANCES}
+ ${LOOP_COUNT} Evaluate ${NET1_VM_COUNT}+${NET2_VM_COUNT}
+ : FOR ${index} IN RANGE 1 ${LOOP_COUNT}
+ \ ${NET1_L3_VM_IPS} ${NET1_DHCP_IP} Verify VMs Received DHCP Lease @{NET_1_VM_INSTANCES}
+ \ ${NET2_L3_VM_IPS} ${NET2_DHCP_IP} Verify VMs Received DHCP Lease @{NET_2_VM_INSTANCES}
+ \ ${NET1_VM_LIST_LENGTH}= Get Length ${NET1_L3_VM_IPS}
+ \ ${NET2_VM_LIST_LENGTH}= Get Length ${NET2_L3_VM_IPS}
+ \ Exit For Loop If ${NET1_VM_LIST_LENGTH}==${NET1_VM_COUNT} and ${NET2_VM_LIST_LENGTH}==${NET2_VM_COUNT}
+ Set Suite Variable ${NET1_L3_VM_IPS}
+ Set Suite Variable ${NET1_DHCP_IP}
+ Set Suite Variable ${NET2_L3_VM_IPS}
+ Set Suite Variable ${NET2_DHCP_IP}
+ [Teardown] Run Keywords Show Debugs @{NET_1_VM_INSTANCES} @{NET_2_VM_INSTANCES}
+ ... AND Get OvsDebugInfo
+
Bring Up ODL2
[Documentation] Bring up ODL2 again
ClusterManagement.Start Single Member 2
Ping Vm Instance1 In l3_net_2 From l3_net_1
[Documentation] Check reachability of vm instances by pinging to them after creating routers.
- Get OvsDebugInfo
- OpenStackOperations.Ping Vm From DHCP Namespace l3_net_1 @{NET_2_VM_IPS}[0]
+ OpenStackOperations.Ping Vm From DHCP Namespace l3_net_1 @{NET2_L3_VM_IPS}[0]
Ping Vm Instance2 In l3_net_2 From l3_net_1
[Documentation] Check reachability of vm instances by pinging to them after creating routers.
- Get OvsDebugInfo
- OpenStackOperations.Ping Vm From DHCP Namespace l3_net_1 @{NET_2_VM_IPS}[1]
+ OpenStackOperations.Ping Vm From DHCP Namespace l3_net_1 @{NET2_L3_VM_IPS}[1]
Ping Vm Instance3 In l3_net_2 From l3_net_1
[Documentation] Check reachability of vm instances by pinging to them after creating routers.
- Get OvsDebugInfo
- OpenStackOperations.Ping Vm From DHCP Namespace l3_net_1 @{NET_2_VM_IPS}[2]
+ OpenStackOperations.Ping Vm From DHCP Namespace l3_net_1 @{NET2_L3_VM_IPS}[2]
Ping Vm Instance1 In l3_net_1 From l3_net_2
[Documentation] Check reachability of vm instances by pinging to them after creating routers.
- Get OvsDebugInfo
- OpenStackOperations.Ping Vm From DHCP Namespace l3_net_2 @{NET_1_VM_IPS}[0]
+ OpenStackOperations.Ping Vm From DHCP Namespace l3_net_2 @{NET1_L3_VM_IPS}[0]
Ping Vm Instance2 In l3_net_1 From l3_net_2
[Documentation] Check reachability of vm instances by pinging to them after creating routers.
- Get OvsDebugInfo
- OpenStackOperations.Ping Vm From DHCP Namespace l3_net_2 @{NET_1_VM_IPS}[1]
+ OpenStackOperations.Ping Vm From DHCP Namespace l3_net_2 @{NET1_L3_VM_IPS}[1]
Ping Vm Instance3 In l3_net_1 From l3_net_2
[Documentation] Check reachability of vm instances by pinging to them after creating routers.
- Get OvsDebugInfo
- OpenStackOperations.Ping Vm From DHCP Namespace l3_net_2 @{NET_1_VM_IPS}[2]
+ OpenStackOperations.Ping Vm From DHCP Namespace l3_net_2 @{NET1_L3_VM_IPS}[2]
Take Down ODL1 and ODL2
[Documentation] Kill the karaf in First and Second Controller
ClusterManagement.Kill Members From List Or All ${odl_1_and_2_down}
Connectivity Tests From Vm Instance1 In l3_net_1
- [Documentation] Logging to the vm instance using generated key pair.
- ${dst_ip_list}= Create List @{NET_1_VM_IPS}[1] @{DHCP_IPS}[0] @{NET_1_VM_IPS}[2]
+ [Documentation] ssh to the VM instance and test operations.
+ ${dst_ip_list}= Create List @{NET2_L3_VM_IPS} @{NET1_L3_VM_IPS}
Log ${dst_ip_list}
- ${other_dst_ip_list}= Create List @{NET_2_VM_IPS}[0] @{DHCP_IPS}[1] @{NET_2_VM_IPS}[2] @{NET_2_VM_IPS}[1]
- Log ${other_dst_ip_list}
- Get OvsDebugInfo
- OpenStackOperations.Test Operations From Vm Instance l3_net_1 @{NET_1_VM_IPS}[0] ${dst_ip_list} l2_or_l3=l3 list_of_external_dst_ips=${other_dst_ip_list}
+ OpenStackOperations.Test Operations From Vm Instance l3_net_1 @{NET1_L3_VM_IPS}[0] ${dst_ip_list}
Connectivity Tests From Vm Instance2 In l3_net_1
- [Documentation] Logging to the vm instance using generated key pair.
- ${dst_ip_list}= Create List @{NET_1_VM_IPS}[0] @{DHCP_IPS}[0] @{NET_1_VM_IPS}[2]
+ [Documentation] ssh to the VM instance and test operations.
+ ${dst_ip_list}= Create List @{NET2_L3_VM_IPS} @{NET1_L3_VM_IPS}
Log ${dst_ip_list}
- ${other_dst_ip_list}= Create List @{NET_2_VM_IPS}[0] @{DHCP_IPS}[1] @{NET_2_VM_IPS}[2]
- Log ${other_dst_ip_list}
- Get OvsDebugInfo
- OpenStackOperations.Test Operations From Vm Instance l3_net_1 @{NET_1_VM_IPS}[1] ${dst_ip_list} l2_or_l3=l3 list_of_external_dst_ips=${other_dst_ip_list}
+ OpenStackOperations.Test Operations From Vm Instance l3_net_1 @{NET1_L3_VM_IPS}[1] ${dst_ip_list}
Connectivity Tests From Vm Instance3 In l3_net_1
- [Documentation] Logging to the vm instance using generated key pair.
- ${dst_ip_list}= Create List @{NET_1_VM_IPS}[0] @{DHCP_IPS}[0] @{NET_1_VM_IPS}[1]
+ [Documentation] ssh to the VM instance and test operations.
+ ${dst_ip_list}= Create List @{NET2_L3_VM_IPS} @{NET1_L3_VM_IPS}
Log ${dst_ip_list}
- ${other_dst_ip_list}= Create List @{NET_2_VM_IPS}[0] @{DHCP_IPS}[1] @{NET_2_VM_IPS}[2]
- Log ${other_dst_ip_list}
- Get OvsDebugInfo
- OpenStackOperations.Test Operations From Vm Instance l3_net_1 @{NET_1_VM_IPS}[2] ${dst_ip_list} l2_or_l3=l3 list_of_external_dst_ips=${other_dst_ip_list}
+ OpenStackOperations.Test Operations From Vm Instance l3_net_1 @{NET1_L3_VM_IPS}[2] ${dst_ip_list}
Bring Up ODL1 and ODL2
[Documentation] Bring up ODL1 and ODL2 again
ClusterManagement.Kill Members From List Or All ${odl_2_and_3_down}
Connectivity Tests From Vm Instance1 In l3_net_2
- [Documentation] Logging to the vm instance using generated key pair.
- ${dst_ip_list}= Create List @{NET_2_VM_IPS}[1] @{DHCP_IPS}[1] @{NET_2_VM_IPS}[2]
+ [Documentation] ssh to the VM instance and test operations.
+ ${dst_ip_list}= Create List @{NET2_L3_VM_IPS} @{NET1_L3_VM_IPS}
Log ${dst_ip_list}
- ${other_dst_ip_list}= Create List @{NET_1_VM_IPS}[0] @{DHCP_IPS}[0] @{NET_1_VM_IPS}[1] @{NET_1_VM_IPS}[2]
- Log ${other_dst_ip_list}
- Get OvsDebugInfo
- OpenStackOperations.Test Operations From Vm Instance l3_net_2 @{NET_2_VM_IPS}[0] ${dst_ip_list} l2_or_l3=l3 list_of_external_dst_ips=${other_dst_ip_list}
+ OpenStackOperations.Test Operations From Vm Instance l3_net_2 @{NET2_L3_VM_IPS}[0] ${dst_ip_list}
Connectivity Tests From Vm Instance2 In l3_net_2
- [Documentation] Logging to the vm instance using generated key pair.
- ${dst_ip_list}= Create List @{NET_2_VM_IPS}[0] @{DHCP_IPS}[1] @{NET_2_VM_IPS}[2]
+ [Documentation] ssh to the VM instance and test operations.
+ ${dst_ip_list}= Create List @{NET2_L3_VM_IPS} @{NET1_L3_VM_IPS}
Log ${dst_ip_list}
- ${other_dst_ip_list}= Create List @{NET_1_VM_IPS}[0] @{DHCP_IPS}[0] @{NET_1_VM_IPS}[1] @{NET_1_VM_IPS}[2]
- Log ${other_dst_ip_list}
- Get OvsDebugInfo
- OpenStackOperations.Test Operations From Vm Instance l3_net_2 @{NET_2_VM_IPS}[1] ${dst_ip_list} l2_or_l3=l3 list_of_external_dst_ips=${other_dst_ip_list}
+ OpenStackOperations.Test Operations From Vm Instance l3_net_2 @{NET2_L3_VM_IPS}[1] ${dst_ip_list}
Connectivity Tests From Vm Instance3 In l3_net_2
- [Documentation] Logging to the vm instance using generated key pair.
- ${dst_ip_list}= Create List @{NET_2_VM_IPS}[0] @{DHCP_IPS}[1] @{NET_2_VM_IPS}[1]
+ [Documentation] ssh to the VM instance and test operations.
+ ${dst_ip_list}= Create List @{NET2_L3_VM_IPS} @{NET1_L3_VM_IPS}
Log ${dst_ip_list}
- ${other_dst_ip_list}= Create List @{NET_1_VM_IPS}[0] @{DHCP_IPS}[0] @{NET_1_VM_IPS}[1] @{NET_1_VM_IPS}[2]
- Log ${other_dst_ip_list}
- Get OvsDebugInfo
- OpenStackOperations.Test Operations From Vm Instance l3_net_2 @{NET_2_VM_IPS}[2] ${dst_ip_list} l2_or_l3=l3 list_of_external_dst_ips=${other_dst_ip_list}
+ OpenStackOperations.Test Operations From Vm Instance l3_net_2 @{NET2_L3_VM_IPS}[2] ${dst_ip_list}
Bring Up ODL2 and ODL3
[Documentation] Bring up ODL2 and ODL3 again.
# for dhcp addresses
: FOR ${vm} IN @{NET_1_VM_INSTANCES} @{NET_2_VM_INSTANCES}
\ Wait Until Keyword Succeeds 15s 5s Verify VM Is ACTIVE ${vm}
- ${NET1_VM_IPS} ${NET1_DHCP_IP} Wait Until Keyword Succeeds 180s 10s Verify VMs Received DHCP Lease @{NET_1_VM_INSTANCES}
- ${NET2_VM_IPS} ${NET2_DHCP_IP} Wait Until Keyword Succeeds 180s 10s Verify VMs Received DHCP Lease @{NET_2_VM_INSTANCES}
+ ${NET1_VM_COUNT} Get Length ${NET_1_VM_INSTANCES}
+ ${NET2_VM_COUNT} Get Length ${NET_2_VM_INSTANCES}
+ ${LOOP_COUNT} Evaluate ${NET1_VM_COUNT}+${NET2_VM_COUNT}
+ : FOR ${index} IN RANGE 1 ${LOOP_COUNT}
+ \ ${NET1_VM_IPS} ${NET1_DHCP_IP} Verify VMs Received DHCP Lease @{NET_1_VM_INSTANCES}
+ \ ${NET2_VM_IPS} ${NET2_DHCP_IP} Verify VMs Received DHCP Lease @{NET_2_VM_INSTANCES}
+ \ ${NET1_VM_LIST_LENGTH}= Get Length ${NET1_VM_IPS}
+ \ ${NET2_VM_LIST_LENGTH}= Get Length ${NET2_VM_IPS}
+ \ Exit For Loop If ${NET1_VM_LIST_LENGTH}==${NET1_VM_COUNT} and ${NET2_VM_LIST_LENGTH}==${NET2_VM_COUNT}
Append To List ${NET1_VM_IPS} ${NET1_DHCP_IP}
Set Suite Variable ${NET1_VM_IPS}
Append To List ${NET2_VM_IPS} ${NET2_DHCP_IP}
# for dhcp addresses
: FOR ${vm} IN @{NET_1_VM_INSTANCES} @{NET_2_VM_INSTANCES}
\ Wait Until Keyword Succeeds 15s 5s Verify VM Is ACTIVE ${vm}
- ${NET1_L3_VM_IPS} ${NET1_DHCP_IP} Wait Until Keyword Succeeds 180s 10s Verify VMs Received DHCP Lease @{NET_1_VM_INSTANCES}
- ${NET2_L3_VM_IPS} ${NET2_DHCP_IP} Wait Until Keyword Succeeds 180s 10s Verify VMs Received DHCP Lease @{NET_2_VM_INSTANCES}
+ ${NET1_VM_COUNT} Get Length ${NET_1_VM_INSTANCES}
+ ${NET2_VM_COUNT} Get Length ${NET_2_VM_INSTANCES}
+ ${LOOP_COUNT} Evaluate ${NET1_VM_COUNT}+${NET2_VM_COUNT}
+ : FOR ${index} IN RANGE 1 ${LOOP_COUNT}
+ \ ${NET1_L3_VM_IPS} ${NET1_DHCP_IP} Verify VMs Received DHCP Lease @{NET_1_VM_INSTANCES}
+ \ ${NET2_L3_VM_IPS} ${NET2_DHCP_IP} Verify VMs Received DHCP Lease @{NET_2_VM_INSTANCES}
+ \ ${NET1_VM_LIST_LENGTH}= Get Length ${NET1_L3_VM_IPS}
+ \ ${NET2_VM_LIST_LENGTH}= Get Length ${NET2_L3_VM_IPS}
+ \ Exit For Loop If ${NET1_VM_LIST_LENGTH}==${NET1_VM_COUNT} and ${NET2_VM_LIST_LENGTH}==${NET2_VM_COUNT}
Set Suite Variable ${NET1_L3_VM_IPS}
Set Suite Variable ${NET1_DHCP_IP}
Set Suite Variable ${NET2_L3_VM_IPS}