Upgrade RF syntax for v3.2 compatibility
[integration/test.git] / csit / suites / netvirt / vpnservice / vpn_basic_ipv6.robot
1 *** Settings ***
2 Documentation     Test suite to validate IPv6 vpnservice functionality in an Openstack integrated environment.
3 ...               The assumption of this suite is that the environment is already configured with the proper
4 ...               integration bridges and vxlan tunnels.
5 Suite Setup       Suite Setup
6 Suite Teardown    Suite Teardown
7 Test Setup        SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing
8 Test Teardown     OpenStackOperations.Get Test Teardown Debugs
9 Library           OperatingSystem
10 Library           RequestsLibrary
11 Resource          ../../../libraries/Utils.robot
12 Resource          ../../../libraries/OpenStackOperations.robot
13 Resource          ../../../libraries/DevstackUtils.robot
14 Resource          ../../../libraries/VpnOperations.robot
15 Resource          ../../../libraries/OVSDB.robot
16 Resource          ../../../libraries/SetupUtils.robot
17 Resource          ../../../libraries/Tcpdump.robot
18 Resource          ../../../variables/Variables.robot
19 Resource          ../../../variables/netvirt/Variables.robot
20
21 *** Variables ***
22 ${SECURITY_GROUP}    vpn6_sg
23 @{NETWORKS}       vpn6_net_1    vpn6_net_2
24 @{SUBNETS}        vpn6_sub_1    vpn6_sub_2
25 @{SUBNET_CIDRS}    2001:db8:0:2::/64    2001:db8:0:3::/64
26 @{PORTS}          vpn6_net_1_port_1    vpn6_net_1_port_2    vpn6_net_2_port_1    vpn6_net_2_port_2
27 @{NET_1_VMS}      vpn6_net_1_vm_1    vpn6_net_1_vm_2
28 @{NET_2_VMS}      vpn6_net_2_vm_1    vpn6_net_2_vm_2
29 ${ROUTER}         vpn6_router
30 @{EXTRA_NW_IP}    2001:db9:cafe:d::10    2001:db9:abcd:d::20
31 @{EXTRA_NW_SUBNET}    2001:db9:cafe:d::/64    2001:db9:abcd:d::/64
32 ${UPDATE_NETWORK}    UpdateNetworkV6
33 ${UPDATE_SUBNET}    UpdateSubnetV6
34 ${UPDATE_PORT}    UpdatePortV6
35 @{VPN_INSTANCE_IDS}    4ae8cd92-48ca-49b5-94e1-b2921a261661    4ae8cd92-48ca-49b5-94e1-b2921a261662    4ae8cd92-48ca-49b5-94e1-b2921a261663
36 @{VPN_NAMES}      vpn6_1    vpn6_2    vpn6_3
37 @{RDS}            ["2206:2"]    ["2306:2"]    ["2406:2"]
38
39 *** Test Cases ***
40 Check ELAN Datapath Traffic Within The Networks
41     ${output}=    OpenStackOperations.Execute Command on VM Instance    @{NETWORKS}[0]    @{VM_IP_NET10}[0]    ping6 -c 3 @{VM_IP_NET10}[1]
42     BuiltIn.Should Contain    ${output}    64 bytes
43     ${output}=    OpenStackOperations.Execute Command on VM Instance    @{NETWORKS}[1]    @{VM_IP_NET20}[0]    ping6 -c 3 @{VM_IP_NET20}[1]
44     BuiltIn.Should Contain    ${output}    64 bytes
45
46 Check L3_Datapath Traffic Across Networks With Router
47     BuiltIn.Log    Verification of FIB Entries and Flow
48     @{tcpdump_conn_ids} =    OpenStackOperations.Start Packet Capture On Nodes    tcpdump_vpn6    ${EMPTY}    @{OS_ALL_IPS}
49     ${vm_ips} =    BuiltIn.Create List    @{VM_IP_NET10}    @{VM_IP_NET20}
50     BuiltIn.Wait Until Keyword Succeeds    30s    10s    Utils.Check For Elements At URI    ${FIB_ENTRY_URL}    ${vm_ips}
51     BuiltIn.Wait Until Keyword Succeeds    30s    10s    VpnOperations.Verify Flows Are Present For L3VPN    ${OS_CMP1_IP}    ${VM_IP_NET10}
52     BuiltIn.Wait Until Keyword Succeeds    30s    10s    VpnOperations.Verify Flows Are Present For L3VPN    ${OS_CMP1_IP}    ${VM_IP_NET20}
53     BuiltIn.Wait Until Keyword Succeeds    30s    10s    VpnOperations.Verify GWMAC Entry On ODL    ${GWMAC_ADDRS}
54     Verify GWMAC Flow Entry On Flow Table On All Compute Nodes    ipv6
55     ${dst_ip_list} =    BuiltIn.Create List    @{VM_IP_NET10}[1]    @{VM_IP_NET20}
56     OpenStackOperations.Test Operations From Vm Instance    @{NETWORKS}[0]    @{VM_IP_NET10}[0]    ${dst_ip_list}
57     ${dst_ip_list} =    BuiltIn.Create List    @{VM_IP_NET20}[1]    @{VM_IP_NET10}
58     OpenStackOperations.Test Operations From Vm Instance    @{NETWORKS}[1]    @{VM_IP_NET20}[0]    ${dst_ip_list}
59     [Teardown]    VpnOperations.Test Teardown With Tcpdump Stop    ${tcpdump_conn_ids}
60
61 Add Multiple Extra Routes And Check Datapath Before L3VPN Creation
62     ${CONFIG_EXTRA_ROUTE_IP1} =    BuiltIn.Catenate    sudo ip -6 addr add @{EXTRA_NW_IP}[0]/64 dev eth0
63     ${output} =    OpenStackOperations.Execute Command on VM Instance    @{NETWORKS}[0]    @{VM_IP_NET10}[0]    ${CONFIG_EXTRA_ROUTE_IP1}
64     ${output} =    OpenStackOperations.Execute Command on VM Instance    @{NETWORKS}[0]    @{VM_IP_NET10}[0]    ip -6 a
65     ${CONFIG_EXTRA_ROUTE_IP2} =    BuiltIn.Catenate    sudo ip -6 addr add @{EXTRA_NW_IP}[1]/64 dev eth0
66     ${output} =    OpenStackOperations.Execute Command on VM Instance    @{NETWORKS}[0]    @{VM_IP_NET10}[0]    ${CONFIG_EXTRA_ROUTE_IP2}
67     ${output} =    OpenStackOperations.Execute Command on VM Instance    @{NETWORKS}[0]    @{VM_IP_NET10}[0]    ip -6 a
68     ${EXT_RT1} =    Set Variable    destination=@{EXTRA_NW_SUBNET}[0],gateway=@{VM_IP_NET10}[0]
69     ${EXT_RT2} =    Set Variable    destination=@{EXTRA_NW_SUBNET}[1],gateway=@{VM_IP_NET10}[0]
70     ${cmd} =    BuiltIn.Catenate    ${RT_OPTIONS}    ${EXT_RT1}    ${RT_OPTIONS}    ${EXT_RT2}
71     OpenStackOperations.Update Router    ${ROUTER}    ${cmd}
72     OpenStackOperations.Show Router    ${ROUTER}
73     ${vm_ips} =    BuiltIn.Create List    @{EXTRA_NW_SUBNET}
74     BuiltIn.Wait Until Keyword Succeeds    30s    10s    Utils.Check For Elements At URI    ${FIB_ENTRY_URL}    ${vm_ips}
75     ${output} =    OpenStackOperations.Execute Command on VM Instance    @{NETWORKS}[0]    @{VM_IP_NET10}[1]    ping6 -c 3 @{EXTRA_NW_IP}[1]
76     BuiltIn.Should Contain    ${output}    64 bytes
77     ${output} =    OpenStackOperations.Execute Command on VM Instance    @{NETWORKS}[1]    @{VM_IP_NET20}[1]    ping6 -c 3 @{EXTRA_NW_IP}[1]
78     BuiltIn.Should Contain    ${output}    64 bytes
79     ${output} =    OpenStackOperations.Execute Command on VM Instance    @{NETWORKS}[0]    @{VM_IP_NET10}[1]    ping6 -c 3 @{EXTRA_NW_IP}[0]
80     BuiltIn.Should Contain    ${output}    64 bytes
81
82 Delete Extra Route
83     OpenStackOperations.Update Router    ${ROUTER}    ${RT_CLEAR}
84     OpenStackOperations.Show Router    ${ROUTER}
85
86 Delete And Recreate Extra Route
87     [Documentation]    Recreate multiple extra route and check data path before L3VPN creation
88     ${CONFIG_EXTRA_ROUTE_IP1} =    BuiltIn.Catenate    sudo ip -6 addr add @{EXTRA_NW_IP}[1]/64 dev eth0
89     ${output} =    OpenStackOperations.Execute Command on VM Instance    @{NETWORKS}[0]    @{VM_IP_NET10}[0]    ${CONFIG_EXTRA_ROUTE_IP1}
90     ${EXT_RT1} =    Set Variable    destination=@{EXTRA_NW_SUBNET}[0],gateway=@{VM_IP_NET10}[0]
91     ${cmd} =    BuiltIn.Catenate    ${RT_OPTIONS}    ${EXT_RT1}
92     OpenStackOperations.Update Router    ${ROUTER}    ${cmd}
93     OpenStackOperations.Show Router    ${ROUTER}
94     ${output} =    OpenStackOperations.Execute Command on VM Instance    @{NETWORKS}[0]    @{VM_IP_NET10}[1]    ping6 -c 3 @{EXTRA_NW_IP}[0]
95     BuiltIn.Should Contain    ${output}    64 bytes
96     # clear off extra-routes before the next set of tests
97     [Teardown]    BuiltIn.Run Keywords    OpenStackOperations.Update Router    ${ROUTER}    ${RT_CLEAR}
98     ...    AND    OpenStackOperations.Show Router    ${ROUTER}
99     ...    AND    OpenStackOperations.Get Test Teardown Debugs
100
101 Create L3VPN
102     ${net_id} =    OpenStackOperations.Get Net Id    @{NETWORKS}[0]
103     ${tenant_id} =    OpenStackOperations.Get Tenant ID From Network    ${net_id}
104     VpnOperations.VPN Create L3VPN    vpnid=@{VPN_INSTANCE_IDS}[0]    name=@{VPN_NAMES}[0]    rd=@{RDS}[0]    exportrt=@{RDS}[0]    importrt=@{RDS}[0]    tenantid=${tenant_id}
105     ${resp}=    VpnOperations.VPN Get L3VPN    vpnid=@{VPN_INSTANCE_IDS}[0]
106     BuiltIn.Should Contain    ${resp}    @{VPN_INSTANCE_IDS}[0]
107
108 Associate L3VPN To Routers
109     ${router_id} =    OpenStackOperations.Get Router Id    ${ROUTER}
110     VpnOperations.Associate VPN to Router    routerid=${router_id}    vpnid=@{VPN_INSTANCE_IDS}[0]
111     ${resp}=    VpnOperations.VPN Get L3VPN    vpnid=@{VPN_INSTANCE_IDS}[0]
112     BuiltIn.Should Contain    ${resp}    ${router_id}
113
114 Verify L3VPN Datapath With Router Association
115     BuiltIn.Log    Verify VPN interfaces, FIB entries and Flow table
116     ${vm_ips} =    BuiltIn.Create List    @{VM_IP_NET10}    @{VM_IP_NET20}
117     BuiltIn.Wait Until Keyword Succeeds    30s    10s    Utils.Check For Elements At URI    ${VPN_IFACES_URL}    ${vm_ips}
118     ${RD} =    Strip String    @{RDS}[0]    characters="[]
119     BuiltIn.Wait Until Keyword Succeeds    60s    15s    Utils.Check For Elements At URI    ${CONFIG_API}/odl-fib:fibEntries/vrfTables/${RD}/    ${vm_ips}
120     Verify Flows Are Present For L3VPN On All Compute Nodes    ${vm_ips}
121     BuiltIn.Wait Until Keyword Succeeds    30s    10s    VpnOperations.Verify GWMAC Entry On ODL    ${GWMAC_ADDRS}
122     Verify GWMAC Flow Entry On Flow Table On All Compute Nodes    ipv6
123     BuiltIn.Log    Check datapath from network1 to network2
124     ${dst_ip_list} =    BuiltIn.Create List    @{VM_IP_NET10}[1]    @{VM_IP_NET20}
125     OpenStackOperations.Test Operations From Vm Instance    @{NETWORKS}[0]    @{VM_IP_NET10}[0]    ${dst_ip_list}
126     BuiltIn.Log    Check datapath from network2 to network1
127     ${dst_ip_list} =    BuiltIn.Create List    @{VM_IP_NET20}[1]    @{VM_IP_NET10}
128     OpenStackOperations.Test Operations From Vm Instance    @{NETWORKS}[1]    @{VM_IP_NET20}[0]    ${dst_ip_list}
129
130 Dissociate L3VPN From Routers
131     ${router_id}=    OpenStackOperations.Get Router Id    ${ROUTER}
132     VpnOperations.Dissociate VPN to Router    routerid=${router_id}    vpnid=@{VPN_INSTANCE_IDS}[0]
133     ${resp}=    VpnOperations.VPN Get L3VPN    vpnid=@{VPN_INSTANCE_IDS}[0]
134     BuiltIn.Should Not Contain    ${resp}    ${router_id}
135
136 Delete Router And Router Interfaces With L3VPN
137     ${router_id}=    OpenStackOperations.Get Router Id    ${ROUTER}
138     VpnOperations.Associate VPN to Router    routerid=${router_id}    vpnid=@{VPN_INSTANCE_IDS}[0]
139     ${resp} =    VpnOperations.VPN Get L3VPN    vpnid=@{VPN_INSTANCE_IDS}[0]
140     BuiltIn.Should Contain    ${resp}    ${router_id}
141     FOR    ${INTERFACE}    IN    @{SUBNETS}
142         OpenStackOperations.Remove Interface    ${ROUTER}    ${INTERFACE}
143     END
144     ${interface_output} =    OpenStackOperations.Show Router Interface    ${ROUTER}
145     FOR    ${INTERFACE}    IN    @{SUBNETS}
146         ${subnet_id} =    OpenStackOperations.Get Subnet Id    ${INTERFACE}
147         BuiltIn.Should Not Contain    ${interface_output}    ${subnet_id}
148     END
149     OpenStackOperations.Delete Router    ${ROUTER}
150     ${router_output} =    OpenStackOperations.List Routers
151     BuiltIn.Should Not Contain    ${router_output}    ${ROUTER}
152     @{router_list} =    BuiltIn.Create List    ${ROUTER}
153     BuiltIn.Wait Until Keyword Succeeds    3s    1s    Utils.Check For Elements Not At URI    ${ROUTER_URL}    ${router_list}    check_for_null=True
154     ${resp}=    VpnOperations.VPN Get L3VPN    vpnid=@{VPN_INSTANCE_IDS}[0]
155     BuiltIn.Should Not Contain    ${resp}    ${router_id}
156     Verify GWMAC Flow Entry Removed From Flow Table On All Compute Nodes
157
158 Delete Router With NonExistentRouter Name
159     ${result} =    Process.Run Process    openstack router delete nonExistentRouter    shell=True
160     BuiltIn.Log    ${result.stdout}
161     BuiltIn.Log    ${result.stderr}
162     BuiltIn.Should Be True    '${result.rc}' == '1'
163     BuiltIn.Should Match Regexp    ${result.stderr}    Failed to delete router with name or ID 'nonExistentRouter': No Router found for nonExistentRouter
164
165 Associate L3VPN To Networks
166     ${network1_id} =    OpenStackOperations.Get Net Id    @{NETWORKS}[0]
167     ${network2_id} =    OpenStackOperations.Get Net Id    @{NETWORKS}[1]
168     VpnOperations.Associate L3VPN To Network    networkid=${network1_id}    vpnid=@{VPN_INSTANCE_IDS}[0]
169     ${resp} =    VpnOperations.VPN Get L3VPN    vpnid=@{VPN_INSTANCE_IDS}[0]
170     BuiltIn.Should Contain    ${resp}    ${network1_id}
171     VpnOperations.Associate L3VPN To Network    networkid=${network2_id}    vpnid=@{VPN_INSTANCE_IDS}[0]
172     ${resp} =    VpnOperations.VPN Get L3VPN    vpnid=@{VPN_INSTANCE_IDS}[0]
173     BuiltIn.Should Contain    ${resp}    ${network2_id}
174
175 Dissociate L3VPN From Networks
176     ${network1_id} =    OpenStackOperations.Get Net Id    @{NETWORKS}[0]
177     ${network2_id} =    OpenStackOperations.Get Net Id    @{NETWORKS}[1]
178     VpnOperations.Dissociate L3VPN From Networks    networkid=${network1_id}    vpnid=@{VPN_INSTANCE_IDS}[0]
179     ${resp}=    VpnOperations.VPN Get L3VPN    vpnid=@{VPN_INSTANCE_IDS}[0]
180     BuiltIn.Should Not Contain    ${resp}    ${network1_id}
181     VpnOperations.Dissociate L3VPN From Networks    networkid=${network2_id}    vpnid=@{VPN_INSTANCE_IDS}[0]
182     ${resp}=    VpnOperations.VPN Get L3VPN    vpnid=@{VPN_INSTANCE_IDS}[0]
183     BuiltIn.Should Not Contain    ${resp}    ${network2_id}
184
185 Delete L3VPN
186     VpnOperations.VPN Delete L3VPN    vpnid=@{VPN_INSTANCE_IDS}[0]
187
188 Create Multiple L3VPN
189     ${net_id} =    Get Net Id    @{NETWORKS}[0]
190     ${tenant_id} =    Get Tenant ID From Network    ${net_id}
191     VpnOperations.VPN Create L3VPN    vpnid=@{VPN_INSTANCE_IDS}[0]    name=@{VPN_NAMES}[0]    rd=@{RDS}[0]    exportrt=@{RDS}[0]    importrt=@{RDS}[0]    tenantid=${tenant_id}
192     VpnOperations.VPN Create L3VPN    vpnid=@{VPN_INSTANCE_IDS}[1]    name=@{VPN_NAMES}[1]    rd=@{RDS}[1]    exportrt=@{RDS}[1]    importrt=@{RDS}[1]    tenantid=${tenant_id}
193     VpnOperations.VPN Create L3VPN    vpnid=@{VPN_INSTANCE_IDS}[2]    name=@{VPN_NAMES}[2]    rd=@{RDS}[2]    exportrt=@{RDS}[2]    importrt=@{RDS}[2]    tenantid=${tenant_id}
194     ${resp}=    VpnOperations.VPN Get L3VPN    vpnid=@{VPN_INSTANCE_IDS}[0]
195     BuiltIn.Should Contain    ${resp}    @{VPN_INSTANCE_IDS}[0]
196     ${resp}=    VpnOperations.VPN Get L3VPN    vpnid=@{VPN_INSTANCE_IDS}[1]
197     BuiltIn.Should Contain    ${resp}    @{VPN_INSTANCE_IDS}[1]
198     ${resp}=    VpnOperations.VPN Get L3VPN    vpnid=@{VPN_INSTANCE_IDS}[2]
199     BuiltIn.Should Contain    ${resp}    @{VPN_INSTANCE_IDS}[2]
200
201 *** Keywords ***
202 Suite Setup
203     VpnOperations.Basic Suite Setup
204     OpenStackOperations.Create Network    @{NETWORKS}[0]
205     OpenStackOperations.Create Network    @{NETWORKS}[1]
206     BuiltIn.Wait Until Keyword Succeeds    3s    1s    Utils.Check For Elements At URI    ${NETWORK_URL}    ${NETWORKS}
207     OpenStackOperations.Update Network    @{NETWORKS}[0]    additional_args=--description ${UPDATE_NETWORK}
208     ${output} =    OpenStackOperations.Show Network    @{NETWORKS}[0]
209     BuiltIn.Should Contain    ${output}    ${UPDATE_NETWORK}
210     ${net1_additional_args}=    BuiltIn.Catenate    --ip-version=6 --ipv6-address-mode=slaac --ipv6-ra-mode=slaac ${NET1_IPV6_ADDR_POOL}
211     ${net2_additional_args}=    BuiltIn.Catenate    --ip-version=6 --ipv6-address-mode=slaac --ipv6-ra-mode=slaac ${NET2_IPV6_ADDR_POOL}
212     OpenStackOperations.Create SubNet    @{NETWORKS}[0]    @{SUBNETS}[0]    @{SUBNET_CIDRS}[0]    ${net1_additional_args}
213     OpenStackOperations.Create SubNet    @{NETWORKS}[1]    @{SUBNETS}[1]    @{SUBNET_CIDRS}[1]    ${net2_additional_args}
214     BuiltIn.Wait Until Keyword Succeeds    3s    1s    Utils.Check For Elements At URI    ${SUBNETWORK_URL}    ${SUBNETS}
215     OpenStackOperations.Update SubNet    @{SUBNETS}[0]    additional_args=--description ${UPDATE_SUBNET}
216     ${output} =    OpenStackOperations.Show SubNet    @{SUBNETS}[0]
217     BuiltIn.Should Contain    ${output}    ${UPDATE_SUBNET}
218     OpenStackOperations.Create Router    ${ROUTER}
219     ${router_list} =    BuiltIn.Create List    ${ROUTER}
220     BuiltIn.Wait Until Keyword Succeeds    3s    1s    Utils.Check For Elements At URI    ${ROUTER_URL}    ${router_list}
221     FOR    ${interface}    IN    @{SUBNETS}
222         OpenStackOperations.Add Router Interface    ${ROUTER}    ${interface}
223     END
224     ${interface_output} =    OpenStackOperations.Show Router Interface    ${ROUTER}
225     FOR    ${interface}    IN    @{SUBNETS}
226         ${subnet_id} =    OpenStackOperations.Get Subnet Id    ${interface}
227         BuiltIn.Should Contain    ${interface_output}    ${subnet_id}
228     END
229     ${GWMAC_ADDRS}    ${GWIP_ADDRS} =    VpnOperations.Get Gateway MAC And IP Address    ${ROUTER}    ${IP6_REGEX}
230     BuiltIn.Set Suite Variable    ${GWMAC_ADDRS}
231     BuiltIn.Set Suite Variable    ${GWIP_ADDRS}
232     OpenStackOperations.Create Allow All SecurityGroup    ${SECURITY_GROUP}    IPv6
233     ${allowed_address_pairs_args} =    BuiltIn.Set Variable    --allowed-address ip-address=@{EXTRA_NW_SUBNET}[0] --allowed-address ip-address=@{EXTRA_NW_SUBNET}[1]
234     Create Port    @{NETWORKS}[0]    @{PORTS}[0]    sg=${SECURITY_GROUP}    additional_args=${allowed_address_pairs_args}
235     Create Port    @{NETWORKS}[0]    @{PORTS}[1]    sg=${SECURITY_GROUP}    additional_args=${allowed_address_pairs_args}
236     Create Port    @{NETWORKS}[1]    @{PORTS}[2]    sg=${SECURITY_GROUP}    additional_args=${allowed_address_pairs_args}
237     Create Port    @{NETWORKS}[1]    @{PORTS}[3]    sg=${SECURITY_GROUP}    additional_args=${allowed_address_pairs_args}
238     BuiltIn.Wait Until Keyword Succeeds    3s    1s    Check For Elements At URI    ${PORT_URL}    ${PORTS}
239     OpenStackOperations.Update Port    @{PORTS}[0]    additional_args=--name ${UPDATE_PORT}
240     ${output} =    Show Port    ${UPDATE_PORT}
241     BuiltIn.Should Contain    ${output}    ${UPDATE_PORT}
242     OpenStackOperations.Update Port    ${UPDATE_PORT}    additional_args=--name @{PORTS}[0]
243     OpenStackOperations.Create Vm Instance With Port On Compute Node    @{PORTS}[0]    @{NET_1_VMS}[0]    ${OS_CMP1_HOSTNAME}    sg=${SECURITY_GROUP}
244     OpenStackOperations.Create Vm Instance With Port On Compute Node    @{PORTS}[1]    @{NET_1_VMS}[1]    ${OS_CMP2_HOSTNAME}    sg=${SECURITY_GROUP}
245     OpenStackOperations.Create Vm Instance With Port On Compute Node    @{PORTS}[2]    @{NET_2_VMS}[0]    ${OS_CMP1_HOSTNAME}    sg=${SECURITY_GROUP}
246     OpenStackOperations.Create Vm Instance With Port On Compute Node    @{PORTS}[3]    @{NET_2_VMS}[1]    ${OS_CMP2_HOSTNAME}    sg=${SECURITY_GROUP}
247     ${vms}=    BuiltIn.Create List    @{NET_1_VMS}    @{NET_2_VMS}
248     FOR    ${vm}    IN    @{vms}
249         OpenStackOperations.Poll VM Is ACTIVE    ${vm}
250     END
251     BuiltIn.Wait Until Keyword Succeeds    30s    10s    Wait For Routes To Propogate    ${NETWORKS}    ${SUBNET_CIDRS}
252     ${prefix_net10} =    Replace String    @{SUBNET_CIDRS}[0]    ::/64    (:[a-f0-9]{,4}){,4}
253     ${status}    ${message}    Run Keyword And Ignore Error    BuiltIn.Wait Until Keyword Succeeds    3x    60s    OpenStackOperations.Collect VM IPv6 SLAAC Addresses
254     ...    fail_on_none=true    vm_list=${NET_1_VMS}    network=@{NETWORKS}[0]    subnet=${prefix_net10}
255     ${prefix_net20} =    Replace String    @{SUBNET_CIDRS}[1]    ::/64    (:[a-f0-9]{,4}){,4}
256     ${status}    ${message}    Run Keyword And Ignore Error    BuiltIn.Wait Until Keyword Succeeds    3x    60s    OpenStackOperations.Collect VM IPv6 SLAAC Addresses
257     ...    fail_on_none=true    vm_list=${NET_2_VMS}    network=@{NETWORKS}[1]    subnet=${prefix_net20}
258     ${VM_IP_NET10} =    OpenStackOperations.Collect VM IPv6 SLAAC Addresses    fail_on_none=false    vm_list=${NET_1_VMS}    network=@{NETWORKS}[0]    subnet=${prefix_net10}
259     ${VM_IP_NET20} =    OpenStackOperations.Collect VM IPv6 SLAAC Addresses    fail_on_none=false    vm_list=${NET_2_VMS}    network=@{NETWORKS}[1]    subnet=${prefix_net20}
260     ${VM_INSTANCES} =    Collections.Combine Lists    ${NET_1_VMS}    ${NET_2_VMS}
261     ${VM_IPS}=    Collections.Combine Lists    ${VM_IP_NET10}    ${VM_IP_NET20}
262     ${LOOP_COUNT}    BuiltIn.Get Length    ${NET_1_VMS}
263     FOR    ${index}    IN RANGE    0    ${LOOP_COUNT}
264         ${status}    ${message}    Run Keyword And Ignore Error    BuiltIn.Should Not Contain    ${VM_IPS}[${index}]    None
265         Run Keyword If    '${status}' == 'FAIL'    OpenStack CLI    openstack console log show @{VM_INSTANCES}[${index}]    30s
266     END
267     OpenStackOperations.Copy DHCP Files From Control Node
268     BuiltIn.Set Suite Variable    ${VM_IP_NET10}
269     BuiltIn.Set Suite Variable    ${VM_IP_NET20}
270     BuiltIn.Should Not Contain    ${VM_IP_NET10}    None
271     BuiltIn.Should Not Contain    ${VM_IP_NET20}    None
272     OpenStackOperations.Show Debugs    @{NET_1_VMS}    @{NET_2_VMS}
273     OpenStackOperations.Get Suite Debugs
274
275 Suite Teardown
276     [Documentation]    Delete the setup
277     BuiltIn.Run Keyword And Ignore Error    VpnOperations.VPN Delete L3VPN    vpnid=@{VPN_INSTANCE_IDS}[0]
278     BuiltIn.Run Keyword And Ignore Error    VpnOperations.VPN Delete L3VPN    vpnid=@{VPN_INSTANCE_IDS}[1]
279     BuiltIn.Run Keyword And Ignore Error    VpnOperations.VPN Delete L3VPN    vpnid=@{VPN_INSTANCE_IDS}[2]
280     OpenStackOperations.OpenStack Suite Teardown