mirror of
https://git.proxmox.com/git/mirror_frr
synced 2025-04-29 16:17:38 +00:00
Merge pull request #18292 from FRRouting/mergify/bp/dev/10.3/pr-18289
staticd: Fix `no srv6` command (backport #18289)
This commit is contained in:
commit
ab5f41ef54
@ -1159,7 +1159,7 @@ DEFUN_NOSH (static_srv6, static_srv6_cmd,
|
|||||||
return CMD_SUCCESS;
|
return CMD_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
DEFUN_YANG_NOSH (no_static_srv6, no_static_srv6_cmd,
|
DEFUN_YANG (no_static_srv6, no_static_srv6_cmd,
|
||||||
"no srv6",
|
"no srv6",
|
||||||
NO_STR
|
NO_STR
|
||||||
"Segment Routing SRv6\n")
|
"Segment Routing SRv6\n")
|
||||||
|
@ -0,0 +1 @@
|
|||||||
|
{}
|
@ -251,6 +251,89 @@ def test_srv6_static_sids_sid_readd_all():
|
|||||||
check_srv6_static_sids(router, "expected_srv6_sids.json")
|
check_srv6_static_sids(router, "expected_srv6_sids.json")
|
||||||
|
|
||||||
|
|
||||||
|
def test_srv6_static_sids_srv6_disable():
|
||||||
|
"""
|
||||||
|
Disable SRv6
|
||||||
|
"""
|
||||||
|
tgen = get_topogen()
|
||||||
|
if tgen.routers_have_failure():
|
||||||
|
pytest.skip(tgen.errors)
|
||||||
|
router = tgen.gears["r1"]
|
||||||
|
|
||||||
|
def _check_srv6_static_sids(router, expected_route_file):
|
||||||
|
logger.info("checking zebra srv6 static sids")
|
||||||
|
output = json.loads(router.vtysh_cmd("show ipv6 route static json"))
|
||||||
|
expected = open_json_file("{}/{}".format(CWD, expected_route_file))
|
||||||
|
return topotest.json_cmp(output, expected, exact=True)
|
||||||
|
|
||||||
|
def check_srv6_static_sids(router, expected_file):
|
||||||
|
func = functools.partial(_check_srv6_static_sids, router, expected_file)
|
||||||
|
_, result = topotest.run_and_expect(func, None, count=15, wait=1)
|
||||||
|
assert result is None, "Failed"
|
||||||
|
|
||||||
|
router.vtysh_cmd(
|
||||||
|
"""
|
||||||
|
configure terminal
|
||||||
|
segment-routing
|
||||||
|
no srv6
|
||||||
|
"""
|
||||||
|
)
|
||||||
|
|
||||||
|
# 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 sids configuration")
|
||||||
|
check_srv6_static_sids(router, "expected_srv6_sids_srv6_disable.json")
|
||||||
|
|
||||||
|
|
||||||
|
def test_srv6_static_sids_srv6_reenable():
|
||||||
|
"""
|
||||||
|
Re-enable SRv6
|
||||||
|
"""
|
||||||
|
tgen = get_topogen()
|
||||||
|
if tgen.routers_have_failure():
|
||||||
|
pytest.skip(tgen.errors)
|
||||||
|
router = tgen.gears["r1"]
|
||||||
|
|
||||||
|
def _check_srv6_static_sids(router, expected_route_file):
|
||||||
|
logger.info("checking zebra srv6 static sids")
|
||||||
|
output = json.loads(router.vtysh_cmd("show ipv6 route static json"))
|
||||||
|
expected = open_json_file("{}/{}".format(CWD, expected_route_file))
|
||||||
|
return topotest.json_cmp(output, expected)
|
||||||
|
|
||||||
|
def check_srv6_static_sids(router, expected_file):
|
||||||
|
func = functools.partial(_check_srv6_static_sids, router, expected_file)
|
||||||
|
_, result = topotest.run_and_expect(func, None, count=15, wait=1)
|
||||||
|
assert result is None, "Failed"
|
||||||
|
|
||||||
|
router.vtysh_cmd(
|
||||||
|
"""
|
||||||
|
configure terminal
|
||||||
|
segment-routing
|
||||||
|
srv6
|
||||||
|
locators
|
||||||
|
locator MAIN
|
||||||
|
prefix fcbb:bbbb:1::/48 block-len 32 node-len 16 func-bits 16
|
||||||
|
!
|
||||||
|
!
|
||||||
|
static-sids
|
||||||
|
sid fcbb:bbbb:1::/48 locator MAIN behavior uN
|
||||||
|
sid fcbb:bbbb:1:fe10::/64 locator MAIN behavior uDT4 vrf Vrf10
|
||||||
|
sid fcbb:bbbb:1:fe20::/64 locator MAIN behavior uDT6 vrf Vrf20
|
||||||
|
sid fcbb:bbbb:1:fe30::/64 locator MAIN behavior uDT46 vrf Vrf30
|
||||||
|
sid fcbb:bbbb:1:fe40::/64 locator MAIN behavior uA interface sr0 nexthop 2001::2
|
||||||
|
"""
|
||||||
|
)
|
||||||
|
|
||||||
|
# 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 sids configuration")
|
||||||
|
check_srv6_static_sids(router, "expected_srv6_sids.json")
|
||||||
|
|
||||||
|
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
args = ["-s"] + sys.argv[1:]
|
args = ["-s"] + sys.argv[1:]
|
||||||
sys.exit(pytest.main(args))
|
sys.exit(pytest.main(args))
|
||||||
|
Loading…
Reference in New Issue
Block a user