*** Settings ***
Documentation Test suite to check connectivity in L3 using routers.
-Suite Setup Devstack Suite Setup source_pwd=yes
-Suite Teardown Close All Connections
+Suite Setup OpenStackOperations.OpenStack Suite Setup
+Suite Teardown OpenStackOperations.OpenStack Suite Teardown
Test Setup SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing
-Test Teardown Get Test Teardown Debugs
+Test Teardown OpenStackOperations.Get Test Teardown Debugs
Library SSHLibrary
Library OperatingSystem
Library RequestsLibrary
Resource ../../../libraries/ClusterOvsdb.robot
Resource ../../../libraries/ClusterManagement.robot
Resource ../../../libraries/SetupUtils.robot
-Variables ../../../variables/Variables.py
+Resource ../../../variables/Variables.robot
+Resource ../../../variables/netvirt/Variables.robot
*** Variables ***
-${SECURITY_GROUP} sg-clustering
-@{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
-@{GATEWAY_IPS} 90.0.0.1 100.0.0.1
-@{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}
+${SECURITY_GROUP} cl3_sg
+@{NETWORKS} cl3_net_1 cl3_net_2
+@{SUBNETS} cl3_sub_1 cl3_sub_2
+@{ROUTERS} cl3_router_1 cl3_router_2 cl3_router_3
+@{NET_1_VMS} cl3_net_1_vm_1 cl3_net_1_vm_2 cl3_net_1_vm_3
+@{NET_2_VMS} cl3_net_2_vm_1 cl3_net_2_vm_2 cl3_net_2_vm_3
+@{SUBNET_CIDRS} 36.0.0.0/24 37.0.0.0/24
+@{GATEWAY_IPS} 36.0.0.1 37.0.0.1
+@{ODL_1_AND_2_DOWN} ${1} ${2}
+@{ODL_2_AND_3_DOWN} ${2} ${3}
*** Test Cases ***
Create All Controller Sessions
- [Documentation] Create sessions for all three contorllers.
+ [Documentation] Create sessions for all three controllers.
ClusterManagement.ClusterManagement Setup
+Take Down Leader Of Default Shard
+ [Documentation] Stop the karaf on ODL cluster leader
+ ${cluster_leader} ${followers} = ClusterManagement.Get Leader And Followers For Shard shard_type=config
+ BuiltIn.Set Suite Variable ${cluster_leader}
+ ${new_cluster_list} = ClusterManagement.Stop Single Member ${cluster_leader} msg=up: ODL1, ODL2, ODL3, down=none
+ BuiltIn.Set Suite Variable ${new_cluster_list}
+
Create Networks
[Documentation] Create Network with neutron request.
- : FOR ${NetworkElement} IN @{NETWORKS_NAME}
- \ OpenStackOperations.Create Network ${NetworkElement}
+ FOR ${NetworkElement} IN @{NETWORKS}
+ OpenStackOperations.Create Network ${NetworkElement}
+ END
-Create Subnets For l3_net_1
+Create Subnets For net_1
[Documentation] Create Sub Nets for the Networks with neutron request.
- OpenStackOperations.Create SubNet l3_net_1 l3_sub_net_1 @{SUBNETS_RANGE}[0]
+ OpenStackOperations.Create SubNet @{NETWORKS}[0] @{SUBNETS}[0] @{SUBNET_CIDRS}[0]
-Create Subnets For l3_net_2
+Create Subnets For net_2
[Documentation] Create Sub Nets for the Networks with neutron request.
- OpenStackOperations.Create SubNet l3_net_2 l3_sub_net_2 @{SUBNETS_RANGE}[1]
+ OpenStackOperations.Create SubNet @{NETWORKS}[1] @{SUBNETS}[1] @{SUBNET_CIDRS}[1]
+
+Bring Up Leader Of Default Shard
+ [Documentation] Bring up on cluster leader
+ ClusterManagement.Start Single Member ${cluster_leader} msg=up: ${new_cluster_list}, down: ${cluster_leader}
-Add Ssh Allow Rule
+Add Ssh Allow All Rule
[Documentation] Allow all TCP/UDP/ICMP packets for this suite
OpenStackOperations.Create Allow All SecurityGroup ${SECURITY_GROUP}
Take Down ODL1
- [Documentation] Kill the karaf in First Controller
- ClusterManagement.Kill Single Member 1
+ [Documentation] Stop the karaf in First Controller
+ ClusterManagement.Stop Single Member 1 msg=up: ODL1, ODL2, ODL3, down=none
-Create Vm Instances For l3_net_1
- [Documentation] Create Four Vm instances using flavor and image names for a network.
- OpenStackOperations.Create Vm Instances l3_net_1 ${NET_1_VM_INSTANCES} sg=${SECURITY_GROUP}
+Create Vm Instances For net_1
+ [Documentation] Create Vm instances using flavor and image names for a network.
+ OpenStackOperations.Create Vm Instance On Compute Node @{NETWORKS}[0] @{NET_1_VMS}[0] ${OS_CMP1_HOSTNAME} sg=${SECURITY_GROUP}
+ OpenStackOperations.Create Vm Instance On Compute Node @{NETWORKS}[0] @{NET_1_VMS}[1] ${OS_CMP1_HOSTNAME} sg=${SECURITY_GROUP}
+ OpenStackOperations.Create Vm Instance On Compute Node @{NETWORKS}[0] @{NET_1_VMS}[2] ${OS_CMP2_HOSTNAME} sg=${SECURITY_GROUP}
Bring Up ODL1
[Documentation] Bring up ODL1 again
- ClusterManagement.Start Single Member 1
+ ClusterManagement.Start Single Member 1 msg=up: ODL2, ODL3, down: ODL1
Take Down ODL2
- [Documentation] Kill the karaf in Second Controller
- ClusterManagement.Kill Single Member 2
+ [Documentation] Stop the karaf in Second Controller
+ ClusterManagement.Stop Single Member 2 msg=up: ODL1, ODL2, ODL3, down=none
-Create Vm Instances For l3_net_2
- [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=${SECURITY_GROUP}
+Create Vm Instances For net_2
+ [Documentation] Create Vm instances using flavor and image names for a network.
+ OpenStackOperations.Create Vm Instance On Compute Node @{NETWORKS}[1] @{NET_2_VMS}[0] ${OS_CMP1_HOSTNAME} sg=${SECURITY_GROUP}
+ OpenStackOperations.Create Vm Instance On Compute Node @{NETWORKS}[1] @{NET_2_VMS}[1] ${OS_CMP2_HOSTNAME} sg=${SECURITY_GROUP}
+ OpenStackOperations.Create Vm Instance On Compute Node @{NETWORKS}[1] @{NET_2_VMS}[2] ${OS_CMP2_HOSTNAME} sg=${SECURITY_GROUP}
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
- @{NET1_L3_VM_IPS} ${NET1_DHCP_IP} = Get VM IPs @{NET_1_VM_INSTANCES}
- @{NET2_L3_VM_IPS} ${NET2_DHCP_IP} = Get VM IPs @{NET_2_VM_INSTANCES}
- Set Suite Variable @{NET1_L3_VM_IPS}
- Set Suite Variable @{NET2_L3_VM_IPS}
- Should Not Contain ${NET1_L3_VM_IPS} None
- Should Not Contain ${NET2_L3_VM_IPS} None
- Should Not Contain ${NET1_DHCP_IP} None
- Should Not Contain ${NET2_DHCP_IP} None
- [Teardown] Run Keywords Show Debugs @{NET_1_VM_INSTANCES} @{NET_2_VM_INSTANCES}
- ... AND Get Test Teardown Debugs
+ @{NET_1_L3_VM_IPS} ${NET_1_DHCP_IP} = OpenStackOperations.Get VM IPs @{NET_1_VMS}
+ @{NET_2_L3_VM_IPS} ${NET_2_DHCP_IP} = OpenStackOperations.Get VM IPs @{NET_2_VMS}
+ BuiltIn.Set Suite Variable @{NET_1_L3_VM_IPS}
+ BuiltIn.Set Suite Variable @{NET_2_L3_VM_IPS}
+ BuiltIn.Should Not Contain ${NET_1_L3_VM_IPS} None
+ BuiltIn.Should Not Contain ${NET_2_L3_VM_IPS} None
+ BuiltIn.Should Not Contain ${NET_1_DHCP_IP} None
+ BuiltIn.Should Not Contain ${NET_2_DHCP_IP} None
+ [Teardown] BuiltIn.Run Keywords OpenStackOperations.Show Debugs @{NET_1_VMS} @{NET_2_VMS}
+ ... AND OpenStackOperations.Get Test Teardown Debugs
Bring Up ODL2
[Documentation] Bring up ODL2 again
- ClusterManagement.Start Single Member 2
+ ClusterManagement.Start Single Member 2 msg=up: ODL1, ODL3, down: ODL2
Take Down ODL3
- [Documentation] Kill the karaf in Third Controller
- ClusterManagement.Kill Single Member 3
+ [Documentation] Stop the karaf in Third Controller
+ ClusterManagement.Stop Single Member 3 msg=up: ODL1, ODL2, ODL3, down=none
Create Router router_2
- [Documentation] Create Router and Add Interface to the subnets. this fails sometimes.
- OpenStackOperations.Create Router router_2
+ [Documentation] Create Router and Add Interface to the subnets.
+ OpenStackOperations.Create Router @{ROUTERS}[1]
[Teardown] Report_Failure_Due_To_Bug 6117
Create Router router_3
[Documentation] Create Router and Add Interface to the subnets.
- OpenStackOperations.Create Router router_3
+ OpenStackOperations.Create Router @{ROUTERS}[2]
Add Interfaces To Router
[Documentation] Add Interfaces
- : FOR ${interface} IN @{SUBNETS_NAME}
- \ OpenStackOperations.Add Router Interface router_3 ${interface}
+ FOR ${interface} IN @{SUBNETS}
+ OpenStackOperations.Add Router Interface @{ROUTERS}[2] ${interface}
+ END
Verify Created Routers
[Documentation] Check created routers using northbound rest calls
${data} Utils.Get Data From URI 1 ${NEUTRON_ROUTERS_API}
- Log ${data}
- Should Contain ${data} router_3
+ BuiltIn.Log ${data}
+ Should Contain ${data} @{ROUTERS}[2]
Bring Up ODL3
[Documentation] Bring up ODL3 again
- ClusterManagement.Start Single Member 3
+ ClusterManagement.Start Single Member 3 msg=up: ODL1, ODL2, down: ODL3
-Ping Vm Instance1 In l3_net_2 From l3_net_1
+Ping Vm Instance1 In net_2 From net_1
[Documentation] Check reachability of vm instances by pinging to them after creating routers.
- OpenStackOperations.Ping Vm From DHCP Namespace l3_net_1 @{NET2_L3_VM_IPS}[0]
+ OpenStackOperations.Ping Vm From DHCP Namespace @{NETWORKS}[0] @{NET_2_L3_VM_IPS}[0]
-Ping Vm Instance2 In l3_net_2 From l3_net_1
+Ping Vm Instance2 In net_2 From net_1
[Documentation] Check reachability of vm instances by pinging to them after creating routers.
- OpenStackOperations.Ping Vm From DHCP Namespace l3_net_1 @{NET2_L3_VM_IPS}[1]
+ OpenStackOperations.Ping Vm From DHCP Namespace @{NETWORKS}[0] @{NET_2_L3_VM_IPS}[1]
-Ping Vm Instance3 In l3_net_2 From l3_net_1
+Ping Vm Instance3 In net_2 From net_1
[Documentation] Check reachability of vm instances by pinging to them after creating routers.
- OpenStackOperations.Ping Vm From DHCP Namespace l3_net_1 @{NET2_L3_VM_IPS}[2]
+ OpenStackOperations.Ping Vm From DHCP Namespace @{NETWORKS}[0] @{NET_2_L3_VM_IPS}[2]
-Ping Vm Instance1 In l3_net_1 From l3_net_2
+Ping Vm Instance1 In net_1 From net_2
[Documentation] Check reachability of vm instances by pinging to them after creating routers.
- OpenStackOperations.Ping Vm From DHCP Namespace l3_net_2 @{NET1_L3_VM_IPS}[0]
+ OpenStackOperations.Ping Vm From DHCP Namespace @{NETWORKS}[1] @{NET_1_L3_VM_IPS}[0]
-Ping Vm Instance2 In l3_net_1 From l3_net_2
+Ping Vm Instance2 In net_1 From net_2
[Documentation] Check reachability of vm instances by pinging to them after creating routers.
- OpenStackOperations.Ping Vm From DHCP Namespace l3_net_2 @{NET1_L3_VM_IPS}[1]
+ OpenStackOperations.Ping Vm From DHCP Namespace @{NETWORKS}[1] @{NET_1_L3_VM_IPS}[1]
-Ping Vm Instance3 In l3_net_1 From l3_net_2
+Ping Vm Instance3 In net_1 From net_2
[Documentation] Check reachability of vm instances by pinging to them after creating routers.
- OpenStackOperations.Ping Vm From DHCP Namespace l3_net_2 @{NET1_L3_VM_IPS}[2]
+ OpenStackOperations.Ping Vm From DHCP Namespace @{NETWORKS}[1] @{NET_1_L3_VM_IPS}[2]
+
+Connectivity Tests From Vm Instance1 In net_1 In Healthy Cluster
+ [Documentation] ssh to the VM instance and test operations.
+ ${dst_list} = BuiltIn.Create List @{NET_2_L3_VM_IPS} @{NET_1_L3_VM_IPS}
+ OpenStackOperations.Test Operations From Vm Instance @{NETWORKS}[0] @{NET_1_L3_VM_IPS}[0] ${dst_list}
+ [Teardown] OpenStackOperations.Get Test Teardown Debugs fail=False
+
+Connectivity Tests From Vm Instance2 In net_1 In Healthy Cluster
+ [Documentation] ssh to the VM instance and test operations.
+ ${dst_list} = BuiltIn.Create List @{NET_2_L3_VM_IPS} @{NET_1_L3_VM_IPS}
+ OpenStackOperations.Test Operations From Vm Instance @{NETWORKS}[0] @{NET_1_L3_VM_IPS}[1] ${dst_list}
+ [Teardown] OpenStackOperations.Get Test Teardown Debugs fail=False
+
+Connectivity Tests From Vm Instance3 In net_1 In Healthy Cluster
+ [Documentation] ssh to the VM instance and test operations.
+ ${dst_list} = BuiltIn.Create List @{NET_2_L3_VM_IPS} @{NET_1_L3_VM_IPS}
+ OpenStackOperations.Test Operations From Vm Instance @{NETWORKS}[0] @{NET_1_L3_VM_IPS}[2] ${dst_list}
+ [Teardown] OpenStackOperations.Get Test Teardown Debugs fail=False
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}
- [Teardown] Get OvsDebugInfo
+ [Documentation] Stop the karaf in First and Second Controller
+ ClusterManagement.Stop Single Member 1 msg=up: ODL1, ODL2, ODL3, down=none
+ ClusterManagement.Stop Single Member 2 msg=up: ODL2, ODL3, down=ODL1
+ [Teardown] OpenStackOperations.Get Test Teardown Debugs fail=False
-Connectivity Tests From Vm Instance1 In l3_net_1
+Connectivity Tests From Vm Instance1 In net_1 With Two ODLs Down
[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}
- OpenStackOperations.Test Operations From Vm Instance l3_net_1 @{NET1_L3_VM_IPS}[0] ${dst_ip_list}
- [Teardown] Get OvsDebugInfo
+ ${dst_list} = BuiltIn.Create List @{NET_2_L3_VM_IPS} @{NET_1_L3_VM_IPS}
+ OpenStackOperations.Test Operations From Vm Instance @{NETWORKS}[0] @{NET_1_L3_VM_IPS}[0] ${dst_list}
+ [Teardown] OpenStackOperations.Get Test Teardown Debugs fail=False
-Connectivity Tests From Vm Instance2 In l3_net_1
+Connectivity Tests From Vm Instance2 In net_1 With Two ODLs Down
[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}
- OpenStackOperations.Test Operations From Vm Instance l3_net_1 @{NET1_L3_VM_IPS}[1] ${dst_ip_list}
- [Teardown] Get OvsDebugInfo
+ ${dst_list} = BuiltIn.Create List @{NET_2_L3_VM_IPS} @{NET_1_L3_VM_IPS}
+ OpenStackOperations.Test Operations From Vm Instance @{NETWORKS}[0] @{NET_1_L3_VM_IPS}[1] ${dst_list}
+ [Teardown] OpenStackOperations.Get Test Teardown Debugs fail=False
-Connectivity Tests From Vm Instance3 In l3_net_1
+Connectivity Tests From Vm Instance3 In net_1 With Two ODLs Down
[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}
- OpenStackOperations.Test Operations From Vm Instance l3_net_1 @{NET1_L3_VM_IPS}[2] ${dst_ip_list}
- [Teardown] Get OvsDebugInfo
+ ${dst_list} = BuiltIn.Create List @{NET_2_L3_VM_IPS} @{NET_1_L3_VM_IPS}
+ OpenStackOperations.Test Operations From Vm Instance @{NETWORKS}[0] @{NET_1_L3_VM_IPS}[2] ${dst_list}
+ [Teardown] OpenStackOperations.Get Test Teardown Debugs fail=False
Bring Up ODL1 and ODL2
- [Documentation] Bring up ODL1 and ODL2 again
- ClusterManagement.Start Members From List Or All ${odl_1_and_2_down}
+ [Documentation] Bring up ODL1 and ODL2 again. Do not check for cluster sync until all nodes are
+ ... up. akka will not let nodes join until they are all back up if two were down.
+ ClusterManagement.Start Single Member 1 msg=up: ODL3, down: ODL1, ODL2 wait_for_sync=False
+ ClusterManagement.Start Single Member 2 msg=up: ODL1, ODL3, down: ODL2
+ [Teardown] OpenStackOperations.Get Test Teardown Debugs fail=False
Take Down ODL2 and ODL3
- [Documentation] Kill the karaf in First and Second Controller
- ClusterManagement.Kill Members From List Or All ${odl_2_and_3_down}
- [Teardown] Get OvsDebugInfo
+ [Documentation] Stop the karaf in First and Second Controller
+ ClusterManagement.Stop Single Member 2 msg=up: ODL1, ODL2, ODL3, down=none
+ ClusterManagement.Stop Single Member 3 msg=up: ODL1, ODL3, down=ODL2
+ [Teardown] OpenStackOperations.Get Test Teardown Debugs fail=False
-Connectivity Tests From Vm Instance1 In l3_net_2
+Connectivity Tests From Vm Instance1 In net_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}
- OpenStackOperations.Test Operations From Vm Instance l3_net_2 @{NET2_L3_VM_IPS}[0] ${dst_ip_list}
- [Teardown] Get OvsDebugInfo
+ ${dst_list} = BuiltIn.Create List @{NET_2_L3_VM_IPS} @{NET_1_L3_VM_IPS}
+ OpenStackOperations.Test Operations From Vm Instance @{NETWORKS}[1] @{NET_2_L3_VM_IPS}[0] ${dst_list}
+ [Teardown] OpenStackOperations.Get Test Teardown Debugs fail=False
-Connectivity Tests From Vm Instance2 In l3_net_2
+Connectivity Tests From Vm Instance2 In net_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}
- OpenStackOperations.Test Operations From Vm Instance l3_net_2 @{NET2_L3_VM_IPS}[1] ${dst_ip_list}
- [Teardown] Get OvsDebugInfo
+ ${dst_list} = BuiltIn.Create List @{NET_2_L3_VM_IPS} @{NET_1_L3_VM_IPS}
+ OpenStackOperations.Test Operations From Vm Instance @{NETWORKS}[1] @{NET_2_L3_VM_IPS}[1] ${dst_list}
+ [Teardown] OpenStackOperations.Get Test Teardown Debugs fail=False
-Connectivity Tests From Vm Instance3 In l3_net_2
+Connectivity Tests From Vm Instance3 In net_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}
- OpenStackOperations.Test Operations From Vm Instance l3_net_2 @{NET2_L3_VM_IPS}[2] ${dst_ip_list}
- [Teardown] Get OvsDebugInfo
+ ${dst_list} = BuiltIn.Create List @{NET_2_L3_VM_IPS} @{NET_1_L3_VM_IPS}
+ OpenStackOperations.Test Operations From Vm Instance @{NETWORKS}[1] @{NET_2_L3_VM_IPS}[2] ${dst_list}
+ [Teardown] OpenStackOperations.Get Test Teardown Debugs fail=False
Bring Up ODL2 and ODL3
- [Documentation] Bring up ODL2 and ODL3 again.
- ClusterManagement.Start Members From List Or All ${odl_2_and_3_down}
-
-Delete Vm Instances In l3_net_1
- [Documentation] Delete Vm instances using instance names in l3_net_1.
- : FOR ${VmElement} IN @{NET_1_VM_INSTANCES}
- \ OpenStackOperations.Delete Vm Instance ${VmElement}
+ [Documentation] Bring up ODL2 and ODL3 again. Do not check for cluster sync until all nodes are
+ ... up. akka will not let nodes join until they are all back up if two were down.
+ ClusterManagement.Start Single Member 2 msg=up: ODL1, down: ODL2, ODL3 wait_for_sync=False
+ ClusterManagement.Start Single Member 3 msg=up: ODL1, ODL2, down: ODL3
+ [Teardown] OpenStackOperations.Get Test Teardown Debugs fail=False
+
+Take Down All Instances
+ [Documentation] Stop karaf on all controllers
+ ClusterManagement.Stop Single Member 1 msg=up: ODL1, ODL2, ODL3, down=none
+ ClusterManagement.Stop Single Member 2 msg=up: ODL2, ODL3, down=ODL1
+ ClusterManagement.Stop Single Member 3 msg=up: ODL3, down=ODL1, ODL2
+ [Teardown] OpenStackOperations.Get Test Teardown Debugs fail=False
+
+Bring Up All Instances
+ [Documentation] Bring up all controllers. Do not check for cluster sync until all nodes are
+ ... up. akka will not let nodes join until they are all back up if two were down.
+ ClusterManagement.Start Single Member 1 msg=up: none, down: ODL1, ODL2, ODL3 wait_for_sync=False
+ ClusterManagement.Start Single Member 2 msg=up: ~ODL1, down: ODL2, ODL3 wait_for_sync=False
+ ClusterManagement.Start Single Member 3 msg=up: ~ODL1, ~ODL2, down: ODL3
+ [Teardown] OpenStackOperations.Get Test Teardown Debugs fail=False
+
+Connectivity Tests From Vm Instance2 In net_2 after recovering all nodes
+ [Documentation] ssh to the VM instance and test operations.
+ ${dst_list} = BuiltIn.Create List @{NET_2_L3_VM_IPS} @{NET_1_L3_VM_IPS}
+ OpenStackOperations.Test Operations From Vm Instance @{NETWORKS}[1] @{NET_2_L3_VM_IPS}[1] ${dst_list}
+ [Teardown] OpenStackOperations.Get Test Teardown Debugs fail=False
-Delete Vm Instances In l3_net_2
- [Documentation] Delete Vm instances using instance names in l3_net_2.
- : FOR ${VmElement} IN @{NET_2_VM_INSTANCES}
- \ OpenStackOperations.Delete Vm Instance ${VmElement}
+Connectivity Tests From Vm Instance3 In net_2 after recovering all nodes
+ [Documentation] ssh to the VM instance and test operations.
+ ${dst_list} = BuiltIn.Create List @{NET_2_L3_VM_IPS} @{NET_1_L3_VM_IPS}
+ OpenStackOperations.Test Operations From Vm Instance @{NETWORKS}[1] @{NET_2_L3_VM_IPS}[2] ${dst_list}
+ [Teardown] OpenStackOperations.Get Test Teardown Debugs fail=False
+
+Delete Vm Instances In net_1
+ [Documentation] Delete Vm instances using instance names in net_1.
+ FOR ${vm} IN @{NET_1_VMS}
+ OpenStackOperations.Delete Vm Instance ${vm}
+ END
+
+Delete Vm Instances In net_2
+ [Documentation] Delete Vm instances using instance names in net_2.
+ FOR ${vm} IN @{NET_2_VMS}
+ OpenStackOperations.Delete Vm Instance ${vm}
+ END
Delete Router Interfaces
[Documentation] Remove Interface to the subnets.
- : FOR ${interface} IN @{SUBNETS_NAME}
- \ OpenStackOperations.Remove Interface router_3 ${interface}
+ FOR ${interface} IN @{SUBNETS}
+ OpenStackOperations.Remove Interface @{ROUTERS}[2] ${interface}
+ END
Delete Routers
[Documentation] Delete Router and Interface to the subnets.
- OpenStackOperations.Delete Router router_2
- OpenStackOperations.Delete Router router_3
+ OpenStackOperations.Delete Router @{ROUTERS}[1]
+ OpenStackOperations.Delete Router @{ROUTERS}[2]
Verify Deleted Routers
[Documentation] Check deleted routers using northbound rest calls
- ${data} Utils.Get Data From URI 1 ${NEUTRON_ROUTERS_API}
- Log ${data}
- Should Not Contain ${data} router_3
+ ${data} = Utils.Get Data From URI 1 ${NEUTRON_ROUTERS_API}
+ BuiltIn.Log ${data}
+ BuiltIn.Should Not Contain ${data} @{ROUTERS}[2]
-Delete Sub Networks In l3_net_1
+Delete Sub Network In net_1
[Documentation] Delete Sub Nets for the Networks with neutron request.
- OpenStackOperations.Delete SubNet l3_sub_net_1
+ OpenStackOperations.Delete SubNet @{SUBNETS}[0]
-Delete Sub Networks In l3_net_2
+Delete Sub Network In net_2
[Documentation] Delete Sub Nets for the Networks with neutron request.
- OpenStackOperations.Delete SubNet l3_sub_net_2
+ OpenStackOperations.Delete SubNet @{SUBNETS}[1]
Delete Networks
[Documentation] Delete Networks with neutron request.
- : FOR ${NetworkElement} IN @{NETWORKS_NAME}
- \ OpenStackOperations.Delete Network ${NetworkElement}
+ FOR ${network} IN @{NETWORKS}
+ OpenStackOperations.Delete Network ${network}
+ END
Delete Security Group
[Documentation] Delete security groups with neutron request
- Delete SecurityGroup ${SECURITY_GROUP}
+ OpenStackOperations.Delete SecurityGroup ${SECURITY_GROUP}
Verify Flows Cleanup
[Documentation] Verify that flows have been cleaned up properly after removing all neutron configurations
- Verify Flows Are Cleaned Up On All OpenStack Nodes
+ DataModels.Verify Flows Are Cleaned Up On All OpenStack Nodes