increase the timeout for Get VM IP
[integration/test.git] / csit / suites / netvirt / vpnservice / vpn_basic.robot
1 *** Settings ***
2 Documentation     Test suite to validate 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}    vpn_sg
23 @{NETWORKS}       vpn_net_1    vpn_net_2
24 @{SUBNETS}        vpn_sub_1    vpn_sub_2
25 @{SUBNET_CIDRS}    10.1.1.0/24    20.1.1.0/24
26 @{PORTS}          vpn_net_1_port_1    vpn_net_1_port_2    vpn_net_2_port_1    vpn_net_2_port_2
27 @{NET_1_VMS}      vpn_net_1_vm_1    vpn_net_1_vm_2
28 @{NET_2_VMS}      vpn_net_2_vm_1    vpn_net_2_vm_2
29 ${ROUTER}         vpn_router
30 @{EXTRA_NW_IP}    71.1.1.2    72.1.1.2
31 @{EXTRA_NW_SUBNET}    71.1.1.0/24    72.1.1.0/24
32 ${UPDATE_NETWORK}    UpdateNetwork
33 ${UPDATE_SUBNET}    UpdateSubnet
34 ${UPDATE_PORT}    UpdatePort
35 @{VPN_INSTANCE_IDS}    4ae8cd92-48ca-49b5-94e1-b2921a261441    4ae8cd92-48ca-49b5-94e1-b2921a261442    4ae8cd92-48ca-49b5-94e1-b2921a261443
36 @{VPN_NAMES}      vpn_1    vpn_2    vpn_3
37 @{RDS}            ["2200:2"]    ["2300:2"]    ["2400:2"]
38 ${PORT_NEW}       vpn_net_1_port_new
39 ${VM_NAME_NEW}    vpn_net_1_vm_new
40 ${INVALID_VPN_INSTANCE_ID}    AAAAAAAAAA-4848-4949-9494-666666666666
41
42 *** Test Cases ***
43 Check ELAN Datapath Traffic Within The Networks
44     [Documentation]    Checks datapath within the same network with different vlans.
45     ${output} =    OpenStackOperations.Execute Command on VM Instance    @{NETWORKS}[0]    @{NET_1_VM_IPS}[0]    ping -c 3 @{NET_1_VM_IPS}[1]
46     BuiltIn.Should Contain    ${output}    64 bytes
47     ${output} =    OpenStackOperations.Execute Command on VM Instance    @{NETWORKS}[1]    @{NET_2_VM_IPS}[0]    ping -c 3 @{NET_2_VM_IPS}[1]
48     BuiltIn.Should Contain    ${output}    64 bytes
49
50 Create Router
51     OpenStackOperations.Create Router    ${ROUTER}
52     ${router_list} =    BuiltIn.Create List    ${ROUTER}
53     BuiltIn.Wait Until Keyword Succeeds    3s    1s    Utils.Check For Elements At URI    ${ROUTER_URL}    ${router_list}
54
55 Add Interfaces To Router
56     : FOR    ${interface}    IN    @{SUBNETS}
57     \    OpenStackOperations.Add Router Interface    ${ROUTER}    ${interface}
58     ${interface_output} =    OpenStackOperations.Show Router Interface    ${ROUTER}
59     ${GWMAC_ADDRS}    ${GWIP_ADDRS} =    VpnOperations.Get Gateway MAC And IP Address    ${ROUTER}
60     BuiltIn.Set Suite Variable    ${GWMAC_ADDRS}
61     BuiltIn.Set Suite Variable    ${GWIP_ADDRS}
62
63 Check L3_Datapath Traffic Across Networks With Router
64     @{tcpdump_conn_ids} =    OpenStackOperations.Start Packet Capture On Nodes    tcpdump_vpn    ${EMPTY}    @{OS_ALL_IPS}
65     ${vm_ips} =    BuiltIn.Create List    @{NET_1_VM_IPS}    @{NET_2_VM_IPS}
66     BuiltIn.Wait Until Keyword Succeeds    30s    10s    Utils.Check For Elements At URI    ${FIB_ENTRY_URL}    ${vm_ips}
67     Verify Flows Are Present For L3VPN On All Compute Nodes    ${vm_ips}
68     BuiltIn.Wait Until Keyword Succeeds    30s    10s    VpnOperations.Verify GWMAC Entry On ODL    ${GWMAC_ADDRS}
69     Verify GWMAC Flow Entry On Flow Table On All Compute Nodes
70     ${dst_ip_list} =    BuiltIn.Create List    @{NET_1_VM_IPS}[1]    @{NET_2_VM_IPS}
71     OpenStackOperations.Test Operations From Vm Instance    @{NETWORKS}[0]    @{NET_1_VM_IPS}[0]    ${dst_ip_list}
72     ${dst_ip_list} =    BuiltIn.Create List    @{NET_2_VM_IPS}[1]    @{NET_1_VM_IPS}
73     OpenStackOperations.Test Operations From Vm Instance    @{NETWORKS}[1]    @{NET_2_VM_IPS}[0]    ${dst_ip_list}
74     [Teardown]    VpnOperations.Test Teardown With Tcpdump Stop    ${tcpdump_conn_ids}
75
76 Add Multiple Extra Routes And Check Datapath Before L3VPN Creation
77     ${CONFIG_EXTRA_ROUTE_IP1} =    BuiltIn.Catenate    sudo ifconfig eth0:1 @{EXTRA_NW_IP}[0] netmask 255.255.255.0 up
78     ${output} =    OpenStackOperations.Execute Command on VM Instance    @{NETWORKS}[0]    @{NET_1_VM_IPS}[0]    ${CONFIG_EXTRA_ROUTE_IP1}
79     ${CONFIG_EXTRA_ROUTE_IP2} =    BuiltIn.Catenate    sudo ifconfig eth0:2 @{EXTRA_NW_IP}[1] netmask 255.255.255.0 up
80     ${output} =    OpenStackOperations.Execute Command on VM Instance    @{NETWORKS}[0]    @{NET_1_VM_IPS}[0]    ${CONFIG_EXTRA_ROUTE_IP2}
81     ${output} =    OpenStackOperations.Execute Command on VM Instance    @{NETWORKS}[0]    @{NET_1_VM_IPS}[0]    ifconfig
82     ${ext_rt1} =    BuiltIn.Set Variable    destination=@{EXTRA_NW_SUBNET}[0],gateway=@{NET_1_VM_IPS}[0]
83     ${ext_rt2} =    BuiltIn.Set Variable    destination=@{EXTRA_NW_SUBNET}[1],gateway=@{NET_1_VM_IPS}[0]
84     ${cmd} =    BuiltIn.Catenate    ${RT_OPTIONS}    ${ext_rt1}    ${RT_OPTIONS}    ${ext_rt2}
85     OpenStackOperations.Update Router    ${ROUTER}    ${cmd}
86     OpenStackOperations.Show Router    ${ROUTER}
87     ${vm_ips} =    BuiltIn.Create List    @{EXTRA_NW_SUBNET}
88     BuiltIn.Wait Until Keyword Succeeds    30s    10s    Utils.Check For Elements At URI    ${FIB_ENTRY_URL}    ${vm_ips}
89     ${output} =    OpenStackOperations.Execute Command on VM Instance    @{NETWORKS}[0]    @{NET_1_VM_IPS}[1]    ping -c 3 @{EXTRA_NW_IP}[1]
90     BuiltIn.Should Contain    ${output}    64 bytes
91     ${output} =    OpenStackOperations.Execute Command on VM Instance    @{NETWORKS}[1]    @{NET_2_VM_IPS}[1]    ping -c 3 @{EXTRA_NW_IP}[1]
92     BuiltIn.Should Contain    ${output}    64 bytes
93     ${output} =    OpenStackOperations.Execute Command on VM Instance    @{NETWORKS}[0]    @{NET_1_VM_IPS}[1]    ping -c 3 @{EXTRA_NW_IP}[0]
94     BuiltIn.Should Contain    ${output}    64 bytes
95
96 Delete Extra Route
97     OpenStackOperations.Update Router    ${ROUTER}    ${RT_CLEAR}
98     OpenStackOperations.Show Router    ${ROUTER}
99
100 Delete And Recreate Extra Route
101     [Documentation]    Recreate multiple extra route and check data path before L3VPN creation
102     ${CONFIG_EXTRA_ROUTE_IP1} =    BuiltIn.Catenate    sudo ifconfig eth0:1 @{EXTRA_NW_IP}[0] netmask 255.255.255.0 up
103     ${output} =    OpenStackOperations.Execute Command on VM Instance    @{NETWORKS}[0]    @{NET_1_VM_IPS}[0]    ${CONFIG_EXTRA_ROUTE_IP1}
104     ${ext_rt1} =    BuiltIn.Set Variable    destination=@{EXTRA_NW_SUBNET}[0],gateway=@{NET_1_VM_IPS}[0]
105     ${cmd} =    BuiltIn.Catenate    ${RT_OPTIONS}    ${ext_rt1}
106     OpenStackOperations.Update Router    ${ROUTER}    ${cmd}
107     OpenStackOperations.Show Router    ${ROUTER}
108     ${output} =    OpenStackOperations.Execute Command on VM Instance    @{NETWORKS}[0]    @{NET_1_VM_IPS}[1]    ping -c 3 @{EXTRA_NW_IP}[0]
109     BuiltIn.Should Contain    ${output}    64 bytes
110     # clear off extra-routes before the next set of tests
111     [Teardown]    BuiltIn.Run Keywords    OpenStackOperations.Update Router    ${ROUTER}    ${RT_CLEAR}
112     ...    AND    OpenStackOperations.Show Router    ${ROUTER}
113     ...    AND    OpenStackOperations.Get Test Teardown Debugs
114
115 Create L3VPN
116     ${net_id} =    OpenStackOperations.Get Net Id    @{NETWORKS}[0]
117     ${tenant_id} =    OpenStackOperations.Get Tenant ID From Network    ${net_id}
118     BuiltIn.Log    @{RDS}[0]
119     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}
120     ${resp} =    VpnOperations.VPN Get L3VPN    vpnid=@{VPN_INSTANCE_IDS}[0]
121     BuiltIn.Should Contain    ${resp}    @{VPN_INSTANCE_IDS}[0]
122
123 Associate L3VPN To Routers
124     ${router_id} =    OpenStackOperations.Get Router Id    ${ROUTER}
125     VpnOperations.Associate VPN to Router    routerid=${router_id}    vpnid=@{VPN_INSTANCE_IDS}[0]
126     ${resp} =    VpnOperations.VPN Get L3VPN    vpnid=@{VPN_INSTANCE_IDS}[0]
127     BuiltIn.Should Contain    ${resp}    ${router_id}
128
129 Verify L3VPN Datapath With Router Association
130     ${vm_ips} =    BuiltIn.Create List    @{NET_1_VM_IPS}    @{NET_2_VM_IPS}
131     BuiltIn.Wait Until Keyword Succeeds    30s    10s    Utils.Check For Elements At URI    ${VPN_IFACES_URL}    ${vm_ips}
132     ${RD} =    Strip String    @{RDS}[0]    characters="[]
133     BuiltIn.Wait Until Keyword Succeeds    60s    15s    Utils.Check For Elements At URI    ${CONFIG_API}/odl-fib:fibEntries/vrfTables/${RD}/    ${vm_ips}
134     Verify Flows Are Present For L3VPN On All Compute Nodes    ${vm_ips}
135     BuiltIn.Wait Until Keyword Succeeds    30s    15s    VpnOperations.Verify GWMAC Entry On ODL    ${GWMAC_ADDRS}
136     Verify GWMAC Flow Entry On Flow Table On All Compute Nodes
137     BuiltIn.Log    Check datapath from network1 to network2
138     ${dst_ip_list} =    BuiltIn.Create List    @{NET_1_VM_IPS}[1]    @{NET_2_VM_IPS}
139     OpenStackOperations.Test Operations From Vm Instance    @{NETWORKS}[0]    @{NET_1_VM_IPS}[0]    ${dst_ip_list}
140     BuiltIn.Log    Check datapath from network2 to network1
141     ${dst_ip_list} =    BuiltIn.Create List    @{NET_2_VM_IPS}[1]    @{NET_1_VM_IPS}
142     OpenStackOperations.Test Operations From Vm Instance    @{NETWORKS}[1]    @{NET_2_VM_IPS}[0]    ${dst_ip_list}
143
144 Delete Router Failure When Associated With L3VPN
145     ${router_id} =    OpenStackOperations.Get Router Id    ${ROUTER}
146     ${rc}    ${output} =    Run And Return Rc And Output    openstack router delete ${ROUTER}
147     BuiltIn.Should Match Regexp    ${output}    Failed to delete router.*${ROUTER}
148     BuiltIn.Should Be True    '${rc}' == '1'
149     ${router_output} =    OpenStackOperations.List Routers
150     BuiltIn.Should Contain    ${router_output}    ${ROUTER}
151     @{router_list} =    BuiltIn.Create List    ${ROUTER}
152     BuiltIn.Wait Until Keyword Succeeds    3s    1s    Utils.Check For Elements At URI    ${ROUTER_URL}    ${router_list}
153     ${resp} =    VpnOperations.VPN Get L3VPN    vpnid=@{VPN_INSTANCE_IDS}[0]
154     BuiltIn.Should Contain    ${resp}    ${router_id}
155     Verify GWMAC Flow Entry On Flow Table On All Compute Nodes
156
157 Verify Remove Interface From Router When Associated With L3VPN
158     OpenStackOperations.Remove Interface    ${ROUTER}    @{SUBNETS}[0]
159     OpenStackOperations.Test Operations From Vm Instance    @{NETWORKS}[0]    @{NET_1_VM_IPS}[0]    ${NET_1_VM_IPS}
160     OpenStackOperations.Test Operations From Vm Instance    @{NETWORKS}[0]    @{NET_1_VM_IPS}[0]    ${NET_2_VM_IPS}    ping_should_succeed=False
161
162 Verify L3VPN Datapath With Router Dissociation When Interfaces are Added To Router
163     OpenStackOperations.Add Router Interface    ${ROUTER}    @{SUBNETS}[0]
164     ${vm_ips} =    BuiltIn.Create List    @{NET_1_VM_IPS}    @{NET_2_VM_IPS}
165     ${router_id} =    OpenStackOperations.Get Router Id    ${ROUTER}
166     VpnOperations.Dissociate VPN to Router    routerid=${router_id}    vpnid=@{VPN_INSTANCE_IDS}[0]
167     ${resp} =    VpnOperations.VPN Get L3VPN    vpnid=@{VPN_INSTANCE_IDS}[0]
168     BuiltIn.Should Not Contain    ${resp}    ${router_id}
169     Verify Flows Are Present For L3VPN On All Compute Nodes    ${vm_ips}
170     ${dst_ip_list} =    BuiltIn.Create List    @{NET_1_VM_IPS}[1]    @{NET_2_VM_IPS}
171     OpenStackOperations.Test Operations From Vm Instance    @{NETWORKS}[0]    @{NET_1_VM_IPS}[0]    ${dst_ip_list}
172     BuiltIn.Log    Check datapath from network2 to network1
173     ${dst_ip_list} =    BuiltIn.Create List    @{NET_2_VM_IPS}[1]    @{NET_1_VM_IPS}
174     BuiltIn.Wait Until Keyword Succeeds    60s    10s    OpenStackOperations.Test Operations From Vm Instance    @{NETWORKS}[1]    @{NET_2_VM_IPS}[0]    ${dst_ip_list}
175
176 Remove Router Interfaces And Check L3_Datapath Traffic Across Networks
177     ${router_id} =    OpenStackOperations.Get Router Id    ${ROUTER}
178     : FOR    ${INTERFACE}    IN    @{SUBNETS}
179     \    OpenStackOperations.Remove Interface    ${ROUTER}    ${INTERFACE}
180     \    OpenStackOperations.Test Operations From Vm Instance    @{NETWORKS}[0]    @{NET_1_VM_IPS}[0]    ${NET_1_VM_IPS}
181     \    OpenStackOperations.Test Operations From Vm Instance    @{NETWORKS}[0]    @{NET_1_VM_IPS}[0]    ${NET_2_VM_IPS}    ping_should_succeed=False
182     ${interface_output} =    OpenStackOperations.Show Router Interface    ${ROUTER}
183     : FOR    ${INTERFACE}    IN    @{SUBNETS}
184     \    ${subnet_id} =    OpenStackOperations.Get Subnet Id    ${INTERFACE}
185     \    BuiltIn.Should Not Contain    ${interface_output}    ${subnet_id}
186
187 Delete Router
188     Delete Router    ${ROUTER}
189     ${router_output} =    OpenStackOperations.List Routers
190     BuiltIn.Should Not Contain    ${router_output}    ${ROUTER}
191     @{router_list} =    BuiltIn.Create List    ${ROUTER}
192     BuiltIn.Wait Until Keyword Succeeds    3s    1s    Utils.Check For Elements Not At URI    ${ROUTER_URL}    ${router_list}    check_for_null=True
193     ${resp} =    VpnOperations.VPN Get L3VPN    vpnid=@{VPN_INSTANCE_IDS}[0]
194     BuiltIn.Should Not Contain    ${resp}    ${ROUTER}
195     Verify GWMAC Flow Entry Removed From Flow Table On All Compute Nodes
196
197 Delete Router With NonExistentRouter Name
198     [Documentation]    Delete router with nonExistentRouter name
199     ${result} =    Process.Run Process    openstack router delete nonExistentRouter    shell=True
200     BuiltIn.Log    ${result.stdout}
201     BuiltIn.Log    ${result.stderr}
202     BuiltIn.Should Be True    '${result.rc}' == '1'
203     BuiltIn.Should Match Regexp    ${result.stderr}    Failed to delete router with name or ID 'nonExistentRouter': No Router found for nonExistentRouter
204
205 Associate Networks To L3VPN
206     [Documentation]    Associates L3VPN to networks and verify
207     ${network1_id} =    OpenStackOperations.Get Net Id    @{NETWORKS}[0]
208     ${network2_id} =    OpenStackOperations.Get Net Id    @{NETWORKS}[1]
209     VpnOperations.Associate L3VPN To Network    networkid=${network1_id}    vpnid=@{VPN_INSTANCE_IDS}[0]
210     ${resp} =    VpnOperations.VPN Get L3VPN    vpnid=@{VPN_INSTANCE_IDS}[0]
211     BuiltIn.Should Contain    ${resp}    ${network1_id}
212     VpnOperations.Associate L3VPN To Network    networkid=${network2_id}    vpnid=@{VPN_INSTANCE_IDS}[0]
213     ${resp} =    VpnOperations.VPN Get L3VPN    vpnid=@{VPN_INSTANCE_IDS}[0]
214     BuiltIn.Should Contain    ${resp}    ${network2_id}
215
216 Check Datapath Traffic Across Networks With L3VPN
217     [Documentation]    Datapath Test Across the networks with VPN.
218     ${output} =    OpenStackOperations.Execute Command on VM Instance    @{NETWORKS}[0]    @{NET_1_VM_IPS}[0]    ping -c 20 @{NET_1_VM_IPS}[1]
219     BuiltIn.Should Contain    ${output}    64 bytes
220     ${output} =    OpenStackOperations.Execute Command on VM Instance    @{NETWORKS}[0]    @{NET_1_VM_IPS}[0]    ping -c 20 @{NET_2_VM_IPS}[1]
221     BuiltIn.Should Contain    ${output}    64 bytes
222     ${output} =    OpenStackOperations.Execute Command on VM Instance    @{NETWORKS}[0]    @{NET_1_VM_IPS}[0]    ping -c 20 @{NET_2_VM_IPS}[0]
223     BuiltIn.Should Contain    ${output}    64 bytes
224
225 Verification of route update after VM port removed and re added to VPN
226     [Documentation]    Verify route update after VM port removed and re added to VPN
227     OpenStackOperations.Delete Port    @{PORTS}[0]
228     ${net_list} =    BuiltIn.Create List    ${NET_1_VM_IPS[0]}
229     BuiltIn.Wait Until Keyword Succeeds    30s    10s    Utils.Check For Elements Not At URI    ${FIB_ENTRY_URL}    ${net_list}
230     OpenStackOperations.Delete Vm Instance    @{NET_1_VMS}[0]
231     OpenStackOperations.Create Port    @{NETWORKS}[0]    @{PORTS}[0]    sg=${SECURITY_GROUP}
232     BuiltIn.Wait Until Keyword Succeeds    3s    1s    Utils.Check For Elements At URI    ${PORT_URL}    ${PORTS}
233     OpenStackOperations.Create Vm Instance With Port On Compute Node    @{PORTS}[0]    @{NET_1_VMS}[0]    ${OS_CMP1_HOSTNAME}    sg=${SECURITY_GROUP}
234     OpenStackOperations.Poll VM Is ACTIVE    @{NET_1_VMS}[0]
235     ${status}    ${ips_and_console_log} =    BuiltIn.Run Keyword And Ignore Error    BuiltIn.Wait Until Keyword Succeeds    360s    15s    OpenStackOperations.Get VM IP
236     ...    true    @{NET_1_VMS}[0]
237     @{NET_1_VM_IPS}    ${NET_1_DHCP_IP} =    OpenStackOperations.Get VM IPs    @{NET_1_VMS}
238     BuiltIn.Set Suite Variable    @{NET_1_VM_IPS}
239     BuiltIn.Wait Until Keyword Succeeds    30s    10s    Utils.Check For Elements At URI    ${FIB_ENTRY_URL}    ${NET_1_VM_IPS}
240     ${output} =    OpenStackOperations.Execute Command on VM Instance    @{NETWORKS}[0]    @{NET_1_VM_IPS}[0]    ping -c 10 @{NET_1_VM_IPS}[1]
241     BuiltIn.Should Contain    ${output}    64 bytes
242     ${output} =    OpenStackOperations.Execute Command on VM Instance    @{NETWORKS}[0]    @{NET_1_VM_IPS}[0]    ping -c 10 @{NET_2_VM_IPS}[0]
243     BuiltIn.Should Contain    ${output}    64 bytes
244
245 Verification of route update after reconfiguring vpn by adding new ports
246     [Documentation]    Verify route update after reconfiguring vpn by creating new VM with new port on openvswitch1
247     OpenStackOperations.Create Port    @{NETWORKS}[0]    ${PORT_NEW}    sg=${SECURITY_GROUP}
248     OpenStackOperations.Create Vm Instance With Port On Compute Node    ${PORT_NEW}    ${VM_NAME_NEW}    ${OS_CMP1_HOSTNAME}    sg=${SECURITY_GROUP}
249     OpenStackOperations.Poll VM Is ACTIVE    ${VM_NAME_NEW}
250     ${status}    ${ips_and_console_log} =    BuiltIn.Run Keyword And Ignore Error    BuiltIn.Wait Until Keyword Succeeds    360s    15s    OpenStackOperations.Get VM IP
251     ...    true    ${VM_NAME_NEW}
252     ${output} =    VpnOperations.Get Fib Entries    session
253     BuiltIn.Should Contain    ${output}    ${ips_and_console_log[0]}
254     OpenStackOperations.Delete Vm Instance    ${VM_NAME_NEW}
255     OpenStackOperations.Delete Port    ${PORT_NEW}
256
257 Dissociate L3VPN From Networks
258     [Documentation]    Dissociate L3VPN from networks
259     ${network1_id} =    OpenStackOperations.Get Net Id    @{NETWORKS}[0]
260     ${network2_id} =    OpenStackOperations.Get Net Id    @{NETWORKS}[1]
261     VpnOperations.Dissociate L3VPN From Networks    networkid=${network1_id}    vpnid=@{VPN_INSTANCE_IDS}[0]
262     ${resp} =    VpnOperations.VPN Get L3VPN    vpnid=@{VPN_INSTANCE_IDS}[0]
263     BuiltIn.Should Not Contain    ${resp}    ${network1_id}
264     VpnOperations.Dissociate L3VPN From Networks    networkid=${network2_id}    vpnid=@{VPN_INSTANCE_IDS}[0]
265     ${resp} =    VpnOperations.VPN Get L3VPN    vpnid=@{VPN_INSTANCE_IDS}[0]
266     BuiltIn.Should Not Contain    ${resp}    ${network2_id}
267
268 Delete Unknown L3VPN
269     [Documentation]    Verification of a failure response with deletion of an unknown L3VPN
270     ${status}    ${message} =    BuiltIn.Run Keyword And Ignore Error    VpnOperations.VPN Delete L3VPN    vpnid=${INVALID_VPN_INSTANCE_ID}
271     BuiltIn.Should Contain    ${status}    FAIL
272
273 Delete L3VPN
274     [Documentation]    Delete L3VPN
275     VpnOperations.VPN Delete L3VPN    vpnid=@{VPN_INSTANCE_IDS}[0]
276
277 Create Multiple L3VPN
278     [Documentation]    Creates three L3VPNs and then verify the same
279     ${net_id} =    OpenStackOperations.Get Net Id    @{NETWORKS}[0]
280     ${tenant_id} =    OpenStackOperations.Get Tenant ID From Network    ${net_id}
281     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}
282     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}
283     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}
284     ${resp} =    VpnOperations.VPN Get L3VPN    vpnid=@{VPN_INSTANCE_IDS}[0]
285     BuiltIn.Should Contain    ${resp}    @{VPN_INSTANCE_IDS}[0]
286     ${resp} =    VpnOperations.VPN Get L3VPN    vpnid=@{VPN_INSTANCE_IDS}[1]
287     BuiltIn.Should Contain    ${resp}    @{VPN_INSTANCE_IDS}[1]
288     ${resp} =    VpnOperations.VPN Get L3VPN    vpnid=@{VPN_INSTANCE_IDS}[2]
289     BuiltIn.Should Contain    ${resp}    @{VPN_INSTANCE_IDS}[2]
290
291 *** Keywords ***
292 Suite Setup
293     VpnOperations.Basic Suite Setup
294     OpenStackOperations.Create Network    @{NETWORKS}[0]
295     OpenStackOperations.Create Network    @{NETWORKS}[1]
296     BuiltIn.Wait Until Keyword Succeeds    3s    1s    Utils.Check For Elements At URI    ${NETWORK_URL}    ${NETWORKS}
297     OpenStackOperations.Update Network    @{NETWORKS}[0]    additional_args=--description ${UPDATE_NETWORK}
298     ${output} =    OpenStackOperations.Show Network    @{NETWORKS}[0]
299     BuiltIn.Should Contain    ${output}    ${UPDATE_NETWORK}
300     OpenStackOperations.Create SubNet    @{NETWORKS}[0]    @{SUBNETS}[0]    @{SUBNET_CIDRS}[0]
301     OpenStackOperations.Create SubNet    @{NETWORKS}[1]    @{SUBNETS}[1]    @{SUBNET_CIDRS}[1]
302     BuiltIn.Wait Until Keyword Succeeds    3s    1s    Utils.Check For Elements At URI    ${SUBNETWORK_URL}    ${SUBNETS}
303     OpenStackOperations.Update SubNet    @{SUBNETS}[0]    additional_args=--description ${UPDATE_SUBNET}
304     ${output} =    OpenStackOperations.Show SubNet    @{SUBNETS}[0]
305     BuiltIn.Should Contain    ${output}    ${UPDATE_SUBNET}
306     OpenStackOperations.Create Allow All SecurityGroup    ${SECURITY_GROUP}
307     ${allowed_address_pairs_args} =    BuiltIn.Set Variable    --allowed-address ip-address=@{EXTRA_NW_SUBNET}[0] --allowed-address ip-address=@{EXTRA_NW_SUBNET}[1]
308     Create Port    @{NETWORKS}[0]    @{PORTS}[0]    sg=${SECURITY_GROUP}    additional_args=${allowed_address_pairs_args}
309     Create Port    @{NETWORKS}[0]    @{PORTS}[1]    sg=${SECURITY_GROUP}    additional_args=${allowed_address_pairs_args}
310     Create Port    @{NETWORKS}[1]    @{PORTS}[2]    sg=${SECURITY_GROUP}    additional_args=${allowed_address_pairs_args}
311     Create Port    @{NETWORKS}[1]    @{PORTS}[3]    sg=${SECURITY_GROUP}    additional_args=${allowed_address_pairs_args}
312     Wait Until Keyword Succeeds    3s    1s    Check For Elements At URI    ${PORT_URL}    ${PORTS}
313     ${PORTS_MACADDR} =    Get Ports MacAddr    ${PORTS}
314     Set Suite Variable    ${PORTS_MACADDR}
315     Update Port    @{PORTS}[0]    additional_args=--description ${UPDATE_PORT}
316     ${output} =    Show Port    @{PORTS}[0]
317     Should Contain    ${output}    ${UPDATE_PORT}
318     OpenStackOperations.Create Vm Instance With Port On Compute Node    @{PORTS}[0]    @{NET_1_VMS}[0]    ${OS_CMP1_HOSTNAME}    sg=${SECURITY_GROUP}
319     OpenStackOperations.Create Vm Instance With Port On Compute Node    @{PORTS}[1]    @{NET_1_VMS}[1]    ${OS_CMP2_HOSTNAME}    sg=${SECURITY_GROUP}
320     OpenStackOperations.Create Vm Instance With Port On Compute Node    @{PORTS}[2]    @{NET_2_VMS}[0]    ${OS_CMP1_HOSTNAME}    sg=${SECURITY_GROUP}
321     OpenStackOperations.Create Vm Instance With Port On Compute Node    @{PORTS}[3]    @{NET_2_VMS}[1]    ${OS_CMP2_HOSTNAME}    sg=${SECURITY_GROUP}
322     @{NET_1_VM_IPS}    ${NET_1_DHCP_IP} =    OpenStackOperations.Get VM IPs    @{NET_1_VMS}
323     @{NET_2_VM_IPS}    ${NET_2_DHCP_IP} =    OpenStackOperations.Get VM IPs    @{NET_2_VMS}
324     BuiltIn.Set Suite Variable    @{NET_1_VM_IPS}
325     BuiltIn.Set Suite Variable    @{NET_2_VM_IPS}
326     BuiltIn.Should Not Contain    ${NET_1_VM_IPS}    None
327     BuiltIn.Should Not Contain    ${NET_2_VM_IPS}    None
328     BuiltIn.Should Not Contain    ${NET_1_DHCP_IP}    None
329     BuiltIn.Should Not Contain    ${NET_2_DHCP_IP}    None
330     BuiltIn.Wait Until Keyword Succeeds    30s    10s    Wait For Routes To Propogate    ${NETWORKS}    ${SUBNET_CIDRS}
331     OpenStackOperations.Show Debugs    @{NET_1_VMS}    @{NET_2_VMS}
332     OpenStackOperations.Get Suite Debugs
333
334 Suite Teardown
335     [Documentation]    Delete the setup
336     BuiltIn.Run Keyword And Ignore Error    VpnOperations.VPN Delete L3VPN    vpnid=@{VPN_INSTANCE_IDS}[0]
337     BuiltIn.Run Keyword And Ignore Error    VpnOperations.VPN Delete L3VPN    vpnid=@{VPN_INSTANCE_IDS}[1]
338     BuiltIn.Run Keyword And Ignore Error    VpnOperations.VPN Delete L3VPN    vpnid=@{VPN_INSTANCE_IDS}[2]
339     OpenStackOperations.OpenStack Suite Teardown