summaryrefslogtreecommitdiffstats
path: root/tests/data_plane/vpp_lite_topo
diff options
context:
space:
mode:
Diffstat (limited to 'tests/data_plane/vpp_lite_topo')
-rw-r--r--tests/data_plane/vpp_lite_topo/odl_utils.sh2
-rw-r--r--tests/data_plane/vpp_lite_topo/test_driver/two_customers_topo.sh54
-rwxr-xr-xtests/data_plane/vpp_lite_topo/test_eid_virtualization_4o4.sh22
-rwxr-xr-xtests/data_plane/vpp_lite_topo/test_eid_virtualization_4o6.sh22
-rwxr-xr-xtests/data_plane/vpp_lite_topo/test_eid_virtualization_6o4.sh22
-rwxr-xr-xtests/data_plane/vpp_lite_topo/test_eid_virtualization_6o6.sh22
-rwxr-xr-xtests/data_plane/vpp_lite_topo/test_rtr_single_iface_4o4.sh2
-rwxr-xr-xtests/data_plane/vpp_lite_topo/test_rtr_single_iface_4o6.sh2
-rw-r--r--tests/data_plane/vpp_lite_topo/topologies/two_customers_topo.sh128
9 files changed, 273 insertions, 3 deletions
diff --git a/tests/data_plane/vpp_lite_topo/odl_utils.sh b/tests/data_plane/vpp_lite_topo/odl_utils.sh
index f3edc28..8a2b8bc 100644
--- a/tests/data_plane/vpp_lite_topo/odl_utils.sh
+++ b/tests/data_plane/vpp_lite_topo/odl_utils.sh
@@ -2,7 +2,7 @@
function post_curl {
echo "Sending mapping from ${2} to ODL; operation: ${1}"
until [ "`curl -X POST "http://${ODL_IP}:${ODL_PORT}/restconf/operations/odl-mappingservice:${1}" \
- -H "Content-Type: application/json" --data-binary "@${ODL_CONFIG_DIR}${2}" \
+ -H "Content-Type: application/json" --data-binary "@${ODL_CONFIG_DIR}/${2}" \
-u ${ODL_USER}:${ODL_PASSWD} -s -o /dev/null -w "%{http_code}"`" == "200" ]
do
echo "Updating failed; trying again.."
diff --git a/tests/data_plane/vpp_lite_topo/test_driver/two_customers_topo.sh b/tests/data_plane/vpp_lite_topo/test_driver/two_customers_topo.sh
new file mode 100644
index 0000000..79349b6
--- /dev/null
+++ b/tests/data_plane/vpp_lite_topo/test_driver/two_customers_topo.sh
@@ -0,0 +1,54 @@
+source config.sh
+source odl_utils.sh
+source topologies/two_customers_topo.sh
+
+ODL_CONFIG_FILE1="vpp1_customer1.json"
+ODL_CONFIG_FILE2="vpp2_customer1.json"
+ODL_CONFIG_FILE3="vpp1_customer2.json"
+ODL_CONFIG_FILE4="vpp2_customer2.json"
+
+if [ "$1" == "clean" ] ; then
+ two_customers_topo_clean
+ exit 0
+fi
+
+if [[ $(id -u) != 0 ]]; then
+ echo "Error: run this as a root."
+ exit 1
+fi
+
+function test_eid_virtualization {
+ two_customers_topo_clean
+ sleep 1
+ two_customers_topo_setup
+
+ # init to test failed
+ test_result=1
+
+ #read -p "press any key to continue .." -n1
+
+ ip netns exec vpp1-cus1-ns "${1}" -w 20 -c 1 "${2}"
+ rc=$?
+ if [ $rc -ne 0 ] ; then
+ echo "Error: customer 1 did not reveive any response!"
+ fi
+
+ #read -p "press any key to continue .." -n1
+
+ ip netns exec vpp1-cus2-ns "${1}" -w 20 -c 1 "${2}"
+ rc=$?
+ if [ $rc -ne 0 ] ; then
+ echo "Error: customer 2 did not reveive any response!"
+ fi
+
+# two_customers_topo_clean
+
+ if [ $rc -ne 0 ] ; then
+ echo "Test failed!";
+ else
+ echo "Test passed."
+ test_result=0
+ fi
+
+ exit $test_result
+}
diff --git a/tests/data_plane/vpp_lite_topo/test_eid_virtualization_4o4.sh b/tests/data_plane/vpp_lite_topo/test_eid_virtualization_4o4.sh
new file mode 100755
index 0000000..2038fd2
--- /dev/null
+++ b/tests/data_plane/vpp_lite_topo/test_eid_virtualization_4o4.sh
@@ -0,0 +1,22 @@
+#!/usr/bin/env bash
+
+# Test EID virualization (4over4)
+#
+# This test configures two LISP XTRs with two customers. Both customers
+# have two client nodes (EID) as depict here:
+#
+# eid1 ______ _______ eid2
+# customer1 -| | | |- customer1
+# | xTR |----| xTR |
+# customer2 -|_____| | |_____|- customer2
+# eid3 | eid4
+# ODL
+#
+# In this scenario both eid1 and eid3 are equal.
+
+VPP_LITE_CONF=`pwd`"/../configs/vpp_lite_config/eid_virt/4o4"
+ODL_CONFIG_DIR=`pwd`"/../configs/odl/eid_virt/4o4"
+
+source test_driver/two_customers_topo.sh
+
+test_eid_virtualization ping "6.0.4.4"
diff --git a/tests/data_plane/vpp_lite_topo/test_eid_virtualization_4o6.sh b/tests/data_plane/vpp_lite_topo/test_eid_virtualization_4o6.sh
new file mode 100755
index 0000000..391da92
--- /dev/null
+++ b/tests/data_plane/vpp_lite_topo/test_eid_virtualization_4o6.sh
@@ -0,0 +1,22 @@
+#!/usr/bin/env bash
+
+# Test EID virualization (4over6)
+#
+# This test configures two LISP XTRs with two customers. Both customers
+# have two client nodes (EID) as depict here:
+#
+# eid1 ______ _______ eid2
+# customer1 -| | | |- customer1
+# | xTR |----| xTR |
+# customer2 -|_____| | |_____|- customer2
+# eid3 | eid4
+# ODL
+#
+# In this scenario both eid1 and eid3 are equal.
+
+VPP_LITE_CONF=`pwd`"/../configs/vpp_lite_config/eid_virt/4o6"
+ODL_CONFIG_DIR=`pwd`"/../configs/odl/eid_virt/4o6"
+
+source test_driver/two_customers_topo.sh
+
+test_eid_virtualization ping "6.0.4.4"
diff --git a/tests/data_plane/vpp_lite_topo/test_eid_virtualization_6o4.sh b/tests/data_plane/vpp_lite_topo/test_eid_virtualization_6o4.sh
new file mode 100755
index 0000000..5d7f975
--- /dev/null
+++ b/tests/data_plane/vpp_lite_topo/test_eid_virtualization_6o4.sh
@@ -0,0 +1,22 @@
+#!/usr/bin/env bash
+
+# Test EID virualization (6over4)
+#
+# This test configures two LISP XTRs with two customers. Both customers
+# have two client nodes (EID) as depict here:
+#
+# eid1 ______ _______ eid2
+# customer1 -| | | |- customer1
+# | xTR |----| xTR |
+# customer2 -|_____| | |_____|- customer2
+# eid3 | eid4
+# ODL
+#
+# In this scenario both eid1 and eid3 are equal.
+
+VPP_LITE_CONF=`pwd`"/../configs/vpp_lite_config/eid_virt/6o4"
+ODL_CONFIG_DIR=`pwd`"/../configs/odl/eid_virt/6o4"
+
+source test_driver/two_customers_topo.sh
+
+test_eid_virtualization ping6 "6:0:4::4"
diff --git a/tests/data_plane/vpp_lite_topo/test_eid_virtualization_6o6.sh b/tests/data_plane/vpp_lite_topo/test_eid_virtualization_6o6.sh
new file mode 100755
index 0000000..2b6d463
--- /dev/null
+++ b/tests/data_plane/vpp_lite_topo/test_eid_virtualization_6o6.sh
@@ -0,0 +1,22 @@
+#!/usr/bin/env bash
+
+# Test EID virualization (6over6)
+#
+# This test configures two LISP XTRs with two customers. Both customers
+# have two client nodes (EID) as depict here:
+#
+# eid1 ______ _______ eid2
+# customer1 -| | | |- customer1
+# | xTR |----| xTR |
+# customer2 -|_____| | |_____|- customer2
+# eid3 | eid4
+# ODL
+#
+# In this scenario both eid1 and eid3 are equal.
+
+VPP_LITE_CONF=`pwd`"/../configs/vpp_lite_config/eid_virt/6o6"
+ODL_CONFIG_DIR=`pwd`"/../configs/odl/eid_virt/6o6"
+
+source test_driver/two_customers_topo.sh
+
+test_eid_virtualization ping6 "6:0:4::4"
diff --git a/tests/data_plane/vpp_lite_topo/test_rtr_single_iface_4o4.sh b/tests/data_plane/vpp_lite_topo/test_rtr_single_iface_4o4.sh
index f2e1a60..2729c7e 100755
--- a/tests/data_plane/vpp_lite_topo/test_rtr_single_iface_4o4.sh
+++ b/tests/data_plane/vpp_lite_topo/test_rtr_single_iface_4o4.sh
@@ -13,7 +13,7 @@
#
VPP_LITE_CONF=`pwd`"/../configs/vpp_lite_config/rtr_single_iface/4o4"
-ODL_CONFIG_DIR=`pwd`"/../configs/odl/rtr_single_iface/4o4/"
+ODL_CONFIG_DIR=`pwd`"/../configs/odl/rtr_single_iface/4o4"
source test_driver/rtr_single_iface.sh
diff --git a/tests/data_plane/vpp_lite_topo/test_rtr_single_iface_4o6.sh b/tests/data_plane/vpp_lite_topo/test_rtr_single_iface_4o6.sh
index 59c75d1..fe1e3da 100755
--- a/tests/data_plane/vpp_lite_topo/test_rtr_single_iface_4o6.sh
+++ b/tests/data_plane/vpp_lite_topo/test_rtr_single_iface_4o6.sh
@@ -13,7 +13,7 @@
#
VPP_LITE_CONF=`pwd`"/../configs/vpp_lite_config/rtr_single_iface/4o6/"
-ODL_CONFIG_DIR=`pwd`"/../configs/odl/rtr_single_iface/4o6/"
+ODL_CONFIG_DIR=`pwd`"/../configs/odl/rtr_single_iface/4o6"
source test_driver/rtr_single_iface.sh
diff --git a/tests/data_plane/vpp_lite_topo/topologies/two_customers_topo.sh b/tests/data_plane/vpp_lite_topo/topologies/two_customers_topo.sh
new file mode 100644
index 0000000..2f62913
--- /dev/null
+++ b/tests/data_plane/vpp_lite_topo/topologies/two_customers_topo.sh
@@ -0,0 +1,128 @@
+#!/usr/bin/env bash
+
+function two_customers_topo_clean {
+ echo "Clearing all VPP instances.."
+ pkill vpp --signal 9
+ rm /dev/shm/*
+
+ echo "Cleaning topology.."
+ ip netns exec intervpp-ns ifconfig vppbr1 down
+ ip netns exec intervpp-ns brctl delbr vppbr1
+ ip link del dev vpp1_cus1 &> /dev/null
+ ip link del dev vpp2_cus1 &> /dev/null
+ ip link del dev vpp1_cus2 &> /dev/null
+ ip link del dev vpp2_cus2 &> /dev/null
+ ip link del dev intervpp1 &> /dev/null
+ ip link del dev intervpp2 &> /dev/null
+ ip link del dev odl &> /dev/null
+
+ ip netns del vpp1-cus1-ns &> /dev/null
+ ip netns del vpp1-cus2-ns &> /dev/null
+ ip netns del vpp2-cus1-ns &> /dev/null
+ ip netns del vpp2-cus2-ns &> /dev/null
+ ip netns del intervpp-ns &> /dev/null
+
+ odl_clear_all
+}
+
+function two_customers_topo_setup {
+ echo "Configuring topology..."
+ 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 intervpp-ns
+
+ ip link add veth_intervpp1 type veth peer name intervpp1
+ ip link add veth_intervpp2 type veth peer name intervpp2
+ ip link add veth_odl type veth peer name odl
+ ip link set dev intervpp1 up
+ ip link set dev intervpp2 up
+ ip link set dev odl up
+ ip link set dev veth_intervpp1 up netns intervpp-ns
+ ip link set dev veth_intervpp2 up netns intervpp-ns
+ ip link set dev veth_odl up netns intervpp-ns
+
+ ip netns exec intervpp-ns brctl addbr vppbr1
+ ip netns exec intervpp-ns brctl addif vppbr1 veth_intervpp1
+ ip netns exec intervpp-ns brctl addif vppbr1 veth_intervpp2
+ ip netns exec intervpp-ns brctl addif vppbr1 veth_odl
+ ip netns exec intervpp-ns ifconfig vppbr1 up
+
+ # customer1 configuration on vpp1
+ 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
+ "
+
+ # customer2 configuration on vpp1
+ 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
+ "
+
+ # customer1 configuration on vpp2
+ 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
+ "
+
+ # customer2 configuration on vpp2
+ 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
+ "
+
+ ip addr add 6.0.3.100/24 dev odl
+ ip addr add 6:0:3::100/64 dev odl
+ ethtool --offload odl 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 }
+
+ 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}
+}