diff options
author | Filip Tehlar <ftehlar@cisco.com> | 2016-06-29 14:53:39 +0200 |
---|---|---|
committer | Filip Tehlar <ftehlar@cisco.com> | 2016-06-29 15:48:00 +0200 |
commit | 572c17d6b9db44b8e0fb70222a13272fe41a4a7e (patch) | |
tree | d101e68bf3591d592a648080fe29b962b95f5f60 /tests/data_plane/vpp_lite_topo/topologies | |
parent | af09353134cdd9c6ea250851b22086e7237073d4 (diff) |
Add RTR + EID virt test (6over46)
Change-Id: Ia21075fc33059165f1fcef1bcb177e54dee0e6b8
Signed-off-by: Filip Tehlar <ftehlar@cisco.com>
Diffstat (limited to 'tests/data_plane/vpp_lite_topo/topologies')
-rw-r--r-- | tests/data_plane/vpp_lite_topo/topologies/rtr_two_iface_two_customers.sh | 167 |
1 files changed, 167 insertions, 0 deletions
diff --git a/tests/data_plane/vpp_lite_topo/topologies/rtr_two_iface_two_customers.sh b/tests/data_plane/vpp_lite_topo/topologies/rtr_two_iface_two_customers.sh new file mode 100644 index 0000000..ac9020d --- /dev/null +++ b/tests/data_plane/vpp_lite_topo/topologies/rtr_two_iface_two_customers.sh @@ -0,0 +1,167 @@ + +#!/usr/bin/env bash + +function rtr_two_iface_two_customers_clean { + echo "Clearing all VPP instances.." + pkill vpp --signal 9 + + rm /dev/shm/* + + echo "Cleaning RTR topology.." + ip netns exec vpp1-rtr-ns ifconfig vppbr1 down + ip netns exec vpp1-rtr-ns brctl delbr vppbr1 + ip netns exec vpp2-rtr-ns ifconfig vppbr2 down + ip netns exec vpp2-rtr-ns brctl delbr vppbr2 + ip link del dev vpp1 &> /dev/null + ip link del dev vpp2 &> /dev/null + ip link del dev vpp1_rtr &> /dev/null + ip link del dev rtr1_vpp1 &> /dev/null + ip link del dev vpp2_rtr &> /dev/null + ip link del dev rtr_vpp2 &> /dev/null + ip link del dev odl_vpp1 &> /dev/null + ip link del dev odl_vpp2 &> /dev/null + + ip netns del vpp1-cus1-ns &> /dev/null + ip netns del vpp2-cus1-ns &> /dev/null + ip netns del vpp1-cus2-ns &> /dev/null + ip netns del vpp2-cus2-ns &> /dev/null + ip netns del vpp1-rtr-ns &> /dev/null + ip netns del vpp2-rtr-ns &> /dev/null + + odl_clear_all +} + +function rtr_two_iface_two_customers_setup { + # create namespaces + ip netns add vpp1-cus1-ns + ip netns add vpp1-cus2-ns + ip netns add vpp2-cus1-ns + ip netns add vpp2-cus2-ns + ip netns add vpp1-rtr-ns + ip netns add vpp2-rtr-ns + + # create pair interfaces between vpp[1|2], rtr and odl + ip link add veth_vpp1_rtr type veth peer name vpp1_rtr + ip link add veth_rtr_vpp1 type veth peer name rtr_vpp1 + ip link add veth_vpp2_rtr type veth peer name vpp2_rtr + ip link add veth_rtr_vpp2 type veth peer name rtr_vpp2 + ip link add veth_odl_vpp1 type veth peer name odl_vpp1 + ip link add veth_odl_vpp2 type veth peer name odl_vpp2 + + # enable peer interfaces + ip link set dev vpp1_rtr up + ip link set dev rtr_vpp1 up + ip link set dev vpp2_rtr up + ip link set dev rtr_vpp2 up + ip link set dev odl_vpp1 up + ip link set dev odl_vpp2 up + + # enable veth interfaces and set them in the appropriate ip ns + ip link set dev veth_vpp1_rtr up netns vpp1-rtr-ns + ip link set dev veth_rtr_vpp1 up netns vpp1-rtr-ns + ip link set dev veth_vpp2_rtr up netns vpp2-rtr-ns + ip link set dev veth_rtr_vpp2 up netns vpp2-rtr-ns + ip link set dev veth_odl_vpp1 up netns vpp1-rtr-ns + ip link set dev veth_odl_vpp2 up netns vpp2-rtr-ns + + # vpp1, rtr and odl + ip netns exec vpp1-rtr-ns brctl addbr vppbr1 + ip netns exec vpp1-rtr-ns brctl addif vppbr1 veth_vpp1_rtr + ip netns exec vpp1-rtr-ns brctl addif vppbr1 veth_rtr_vpp1 + ip netns exec vpp1-rtr-ns brctl addif vppbr1 veth_odl_vpp1 + ip netns exec vpp1-rtr-ns ifconfig vppbr1 up + + # vpp2, rtr and odl + ip netns exec vpp2-rtr-ns brctl addbr vppbr2 + ip netns exec vpp2-rtr-ns brctl addif vppbr2 veth_vpp2_rtr + ip netns exec vpp2-rtr-ns brctl addif vppbr2 veth_rtr_vpp2 + ip netns exec vpp2-rtr-ns brctl addif vppbr2 veth_odl_vpp2 + ip netns exec vpp2-rtr-ns ifconfig vppbr2 up + + # vpp1 to client1 + ip link add veth_vpp1_cus1 type veth peer name vpp1_cus1 + ip link set dev vpp1_cus1 up + ip link set dev veth_vpp1_cus1 up netns vpp1-cus1-ns + + ip netns exec vpp1-cus1-ns \ + bash -c " + ip link set dev lo up + ip addr add 6.0.2.2/24 dev veth_vpp1_cus1 + ip addr add 6:0:2::2/64 dev veth_vpp1_cus1 + ip route add 6.0.4.0/24 via 6.0.2.1 + ip route add 6:0:4::0/64 via 6:0:2::1 + " + # vpp1 to client2 + ip link add veth_vpp1_cus2 type veth peer name vpp1_cus2 + ip link set dev vpp1_cus2 up + ip link set dev veth_vpp1_cus2 up netns vpp1-cus2-ns + + ip netns exec vpp1-cus2-ns \ + bash -c " + ip link set dev lo up + ip addr add 6.0.2.2/24 dev veth_vpp1_cus2 + ip addr add 6:0:2::2/64 dev veth_vpp1_cus2 + ip route add 6.0.4.0/24 via 6.0.2.1 + ip route add 6:0:4::0/64 via 6:0:2::1 + " + + # vpp2 to client1 + ip link add veth_vpp2_cus1 type veth peer name vpp2_cus1 + ip link set dev vpp2_cus1 up + ip link set dev veth_vpp2_cus1 up netns vpp2-cus1-ns + + ip netns exec vpp2-cus1-ns \ + bash -c " + ip link set dev lo up + ip addr add 6.0.4.4/24 dev veth_vpp2_cus1 + ip addr add 6:0:4::4/64 dev veth_vpp2_cus1 + ip route add 6.0.2.0/24 via 6.0.4.1 + ip route add 6:0:2::0/64 via 6:0:4::1 + " + # vpp2 to client2 + ip link add veth_vpp2_cus2 type veth peer name vpp2_cus2 + ip link set dev vpp2_cus2 up + ip link set dev veth_vpp2_cus2 up netns vpp2-cus2-ns + + ip netns exec vpp2-cus2-ns \ + bash -c " + ip link set dev lo up + ip addr add 6.0.4.4/24 dev veth_vpp2_cus2 + ip addr add 6:0:4::4/64 dev veth_vpp2_cus2 + ip route add 6.0.2.0/24 via 6.0.4.1 + ip route add 6:0:2::0/64 via 6:0:4::1 + " + + # vpp1 to odl + ip addr add 6.0.3.100/24 dev odl_vpp1 + ip addr add 6:0:3::100/64 dev odl_vpp1 + ethtool --offload odl_vpp1 rx off tx off + + # vpp2 to odl + ip addr add 6.0.5.100/24 dev odl_vpp2 + ip addr add 6:0:5::100/64 dev odl_vpp2 + ethtool --offload odl_vpp2 rx off tx off + + ${VPP_LITE_BIN} \ + unix { log /tmp/vpp1.log cli-listen \ + localhost:5002 full-coredump \ + exec ${VPP_LITE_CONF}/vpp1.config } \ + api-trace { on } api-segment {prefix xtr1} + + ${VPP_LITE_BIN} \ + unix { log /tmp/vpp2.log cli-listen \ + localhost:5003 full-coredump \ + exec ${VPP_LITE_CONF}/vpp2.config } \ + api-trace { on } api-segment {prefix xtr2} + + ${VPP_LITE_BIN} \ + unix { log /tmp/rtr.log cli-listen \ + localhost:5004 full-coredump \ + exec ${VPP_LITE_CONF}/rtr.config } \ + api-trace { on } api-segment {prefix rtr} + + post_curl "add-mapping" ${ODL_CONFIG_FILE1} + post_curl "add-mapping" ${ODL_CONFIG_FILE2} + post_curl "add-mapping" ${ODL_CONFIG_FILE3} + post_curl "add-mapping" ${ODL_CONFIG_FILE4} +} |