]> git.puffer.fish Git - matthieu/frr.git/commitdiff
tests: Add topotest for SRv6 IPv4 traffic steering
authorCarmine Scarpitta <cscarpit@cisco.com>
Tue, 24 Dec 2024 08:42:34 +0000 (09:42 +0100)
committerCarmine Scarpitta <cscarpit@cisco.com>
Mon, 3 Feb 2025 21:21:16 +0000 (22:21 +0100)
Add a topotest to verify the newly introduced CLI to support
steering of IPv4 traffic over an SRv6 SID list.

Signed-off-by: Carmine Scarpitta <cscarpit@cisco.com>
tests/topotests/srv6_static_route_ipv4/__init__.py [new file with mode: 0644]
tests/topotests/srv6_static_route_ipv4/expected_srv6_route.json [new file with mode: 0644]
tests/topotests/srv6_static_route_ipv4/r1/frr.conf [new file with mode: 0644]
tests/topotests/srv6_static_route_ipv4/r1/setup.sh [new file with mode: 0644]
tests/topotests/srv6_static_route_ipv4/test_srv6_route.py [new file with mode: 0755]

diff --git a/tests/topotests/srv6_static_route_ipv4/__init__.py b/tests/topotests/srv6_static_route_ipv4/__init__.py
new file mode 100644 (file)
index 0000000..e69de29
diff --git a/tests/topotests/srv6_static_route_ipv4/expected_srv6_route.json b/tests/topotests/srv6_static_route_ipv4/expected_srv6_route.json
new file mode 100644 (file)
index 0000000..57f4c44
--- /dev/null
@@ -0,0 +1,28 @@
+{
+       "192.0.2.0/24": [
+               {
+                       "prefix": "192.0.2.0/24",
+                       "prefixLen": 24,
+                       "protocol": "static",
+                       "selected": true,
+                       "destSelected": true,
+                       "distance": 1,
+                       "metric": 0,
+                       "installed": true,
+                       "nexthops": [
+                               {
+                                       "directlyConnected": true,
+                                       "active": true,
+                                       "weight": 1,
+                                       "seg6local": {
+                                               "action": "unspec"
+                                       },
+                                       "seg6": [
+                                               "fcbb:bbbb:1:2:3:4:5:6",
+                                               "fcbb:bbbb:7:8:fe00::"
+                                       ]
+                               }
+                       ]
+               }
+       ]
+}
diff --git a/tests/topotests/srv6_static_route_ipv4/r1/frr.conf b/tests/topotests/srv6_static_route_ipv4/r1/frr.conf
new file mode 100644 (file)
index 0000000..8ff23ec
--- /dev/null
@@ -0,0 +1,7 @@
+hostname r1
+!
+log stdout notifications
+log commands
+!
+ipv6 route fcbb:bbbb:1::/48 sr0
+ip route 192.0.2.0/24 sr0 segments fcbb:bbbb:1:2:3:4:5:6/fcbb:bbbb:7:8:fe00::
diff --git a/tests/topotests/srv6_static_route_ipv4/r1/setup.sh b/tests/topotests/srv6_static_route_ipv4/r1/setup.sh
new file mode 100644 (file)
index 0000000..4b6cce8
--- /dev/null
@@ -0,0 +1,2 @@
+ip link add sr0 type dummy
+ip link set sr0 up
diff --git a/tests/topotests/srv6_static_route_ipv4/test_srv6_route.py b/tests/topotests/srv6_static_route_ipv4/test_srv6_route.py
new file mode 100755 (executable)
index 0000000..b49a9ce
--- /dev/null
@@ -0,0 +1,82 @@
+#!/usr/bin/env python
+# SPDX-License-Identifier: ISC
+
+#
+# test_srv6_static_route_ipv4.py
+#
+# Copyright 2025
+# Carmine Scarpitta <cscarpit.@cisco.com>
+#
+
+"""
+test_srv6_static_route_ipv4.py:
+Test for SRv6 static route on zebra
+"""
+
+import os
+import sys
+import json
+import pytest
+import functools
+
+CWD = os.path.dirname(os.path.realpath(__file__))
+sys.path.append(os.path.join(CWD, "../"))
+
+# pylint: disable=C0413
+from lib import topotest
+from lib.topogen import Topogen, TopoRouter, get_topogen
+from lib.topolog import logger
+
+pytestmark = [pytest.mark.staticd]
+
+
+def open_json_file(filename):
+    try:
+        with open(filename, "r") as f:
+            return json.load(f)
+    except IOError:
+        assert False, "Could not read file {}".format(filename)
+
+
+def setup_module(mod):
+    tgen = Topogen({None: "r1"}, mod.__name__)
+    tgen.start_topology()
+    for rname, router in tgen.routers().items():
+        router.run("/bin/bash {}/{}/setup.sh".format(CWD, rname))
+        router.load_frr_config("frr.conf")
+    tgen.start_router()
+
+
+def teardown_module():
+    tgen = get_topogen()
+    tgen.stop_topology()
+
+
+def test_srv6_static_route():
+    tgen = get_topogen()
+    if tgen.routers_have_failure():
+        pytest.skip(tgen.errors)
+    router = tgen.gears["r1"]
+
+    def _check_srv6_static_route(router, expected_route_file):
+        logger.info("checking zebra srv6 static route with multiple segs status")
+        output = json.loads(router.vtysh_cmd("show ip route static json"))
+        expected = open_json_file("{}/{}".format(CWD, expected_route_file))
+        return topotest.json_cmp(output, expected)
+
+    def check_srv6_static_route(router, expected_file):
+        func = functools.partial(_check_srv6_static_route, router, expected_file)
+        _, result = topotest.run_and_expect(func, None, count=15, wait=1)
+        assert result is None, "Failed"
+
+    # FOR DEVELOPER:
+    # If you want to stop some specific line and start interactive shell,
+    # please use tgen.mininet_cli() to start it.
+
+    logger.info("Test for srv6 route configuration")
+    check_srv6_static_route(router, "expected_srv6_route.json")
+
+
+if __name__ == "__main__":
+    args = ["-s"] + sys.argv[1:]
+    sys.exit(pytest.main(args))