The test aims to verify that updating existing MFC route works properly.
The test logic is:
- Add a simple route
- Verify it is functional
- Updates it with a new route which has a different set of output VIFs
- Verify the new route is functional
Signed-off-by: Yotam Gigi <yotamg(a)mellanox.com>
---
recipes/switchdev/mr-004-route_replace.py | 73 ++++++++++++++++++++++++++++++
recipes/switchdev/mr-004-route_replace.xml | 5 ++
2 files changed, 78 insertions(+)
create mode 100644 recipes/switchdev/mr-004-route_replace.py
create mode 100644 recipes/switchdev/mr-004-route_replace.xml
diff --git a/recipes/switchdev/mr-004-route_replace.py
b/recipes/switchdev/mr-004-route_replace.py
new file mode 100644
index 0000000..94e71c5
--- /dev/null
+++ b/recipes/switchdev/mr-004-route_replace.py
@@ -0,0 +1,73 @@
+"""
+Copyright 2017 Mellanox Technologies. All rights reserved.
+Licensed under the GNU General Public License, version 2 as
+published by the Free Software Foundation; see COPYING for details.
+"""
+
+__author__ = """
+yotamg(a)mellanox.com (Yotam Gigi)
+"""
+
+from lnst.Controller.Task import ctl
+from lnst.Common.Consts import MROUTE
+from TestLib import TestLib
+from time import sleep
+from mr_common import MrouteTest
+
+def test_ip(major, minor):
+ return ["192.168.%d.%d" % (major, minor),
+ "2002:%d::%d" % (major, minor)]
+def ipv4(ip):
+ return ip[0]
+
+def mcgrp(num):
+ return "239.255.%d.%d" % (num/0x100, num%0x100)
+
+def do_task(ctl, hosts, ifaces, aliases):
+ m1, m2, sw = hosts
+ m1_if1, m1_if2, m2_if1, m2_if2, m2_if3, m2_if4, sw_if1, \
+ sw_br_m1, sw_br_m2, sw_if3, sw_if4, sw_if5, sw_if2 = ifaces
+
+ sw_ports = [sw_if1, sw_if2, sw_if3, sw_if4, sw_if5]
+
+ tl = TestLib(ctl, aliases)
+ mt = MrouteTest(tl, hosts, ifaces)
+
+ sleep(30)
+ mt.init()
+
+ # add vifs
+ mt.add_vif(sw_if1, 0)
+ mt.add_vif(sw_if2, 1)
+ mt.add_vif(sw_if3, 2)
+ mt.add_vif(sw_if4, 3)
+ mt.add_vif(sw_if5, 4)
+
+ # add an (S,G) route
+ sg = mt.mroute_create(ipv4(test_ip(5,2)), mcgrp(1), 4, [0, 2, 3])
+
+ # replace it with a different route
+ sg = mt.mroute_create(ipv4(test_ip(5,2)), mcgrp(1), 4, [0, 1])
+
+ # clean
+ mt.mroute_remove(sg)
+
+ mt.fini()
+
+do_task(ctl, [ctl.get_host("machine1"),
+ ctl.get_host("machine2"),
+ ctl.get_host("switch")],
+ [ctl.get_host("machine1").get_interface("if1"),
+ ctl.get_host("machine1").get_interface("if2"),
+ ctl.get_host("machine2").get_interface("if1"),
+ ctl.get_host("machine2").get_interface("if2"),
+ ctl.get_host("machine2").get_interface("if3"),
+ ctl.get_host("machine2").get_interface("if4"),
+ ctl.get_host("switch").get_interface("if1"),
+ ctl.get_host("switch").get_interface("if2"),
+ ctl.get_host("switch").get_interface("if3"),
+ ctl.get_host("switch").get_interface("if4"),
+ ctl.get_host("switch").get_interface("if5"),
+ ctl.get_host("switch").get_interface("if6"),
+ ctl.get_host("switch").get_interface("br0")],
+ ctl.get_aliases())
diff --git a/recipes/switchdev/mr-004-route_replace.xml
b/recipes/switchdev/mr-004-route_replace.xml
new file mode 100644
index 0000000..742f7d0
--- /dev/null
+++ b/recipes/switchdev/mr-004-route_replace.xml
@@ -0,0 +1,5 @@
+<lnstrecipe
xmlns:xi="http://www.w3.org/2003/XInclude">
+ <xi:include href="default_aliases.xml" />
+ <xi:include href="mr_common_topology.xml" />
+ <task python="mr-004-route_replace.py" />
+</lnstrecipe>
--
2.8.4