]>
git.proxmox.com Git - mirror_frr.git/blob - tests/topotests/bfd_topo1/test_bfd_topo1.py
2 # SPDX-License-Identifier: ISC
6 # Part of NetDEF Topology Tests
8 # Copyright (c) 2018 by
9 # Network Device Education Foundation, Inc. ("NetDEF")
13 test_bfd_topo1.py: Test the FRR BFD daemon.
19 from functools
import partial
22 # Save the Current Working Directory to find configuration files.
23 CWD
= os
.path
.dirname(os
.path
.realpath(__file__
))
24 sys
.path
.append(os
.path
.join(CWD
, "../"))
26 # pylint: disable=C0413
27 # Import topogen and topotest helpers
28 from lib
import topotest
29 from lib
.topogen
import Topogen
, TopoRouter
, get_topogen
30 from lib
.topolog
import logger
32 pytestmark
= [pytest
.mark
.bfdd
, pytest
.mark
.bgpd
]
35 def setup_module(mod
):
36 "Sets up the pytest environment"
42 tgen
= Topogen(topodef
, mod
.__name
__)
45 router_list
= tgen
.routers()
46 for rname
, router
in router_list
.items():
48 TopoRouter
.RD_ZEBRA
, os
.path
.join(CWD
, "{}/zebra.conf".format(rname
))
51 TopoRouter
.RD_BFD
, os
.path
.join(CWD
, "{}/bfdd.conf".format(rname
))
54 TopoRouter
.RD_BGP
, os
.path
.join(CWD
, "{}/bgpd.conf".format(rname
))
57 # Initialize all routers.
60 # Verify that we are using the proper version and that the BFD
62 for router
in router_list
.values():
64 if router
.has_version("<", "5.1"):
65 tgen
.set_error("Unsupported FRR version")
69 def teardown_module(_mod
):
70 "Teardown the pytest environment"
75 def test_bfd_connection():
76 "Assert that the BFD peers can find themselves."
78 if tgen
.routers_have_failure():
79 pytest
.skip(tgen
.errors
)
81 logger
.info("waiting for bfd peers to go up")
83 for router
in tgen
.routers().values():
84 json_file
= "{}/{}/peers.json".format(CWD
, router
.name
)
85 expected
= json
.loads(open(json_file
).read())
88 topotest
.router_json_cmp
, router
, "show bfd peers json", expected
90 _
, result
= topotest
.run_and_expect(test_func
, None, count
=30, wait
=0.5)
91 assertmsg
= '"{}" JSON output mismatches'.format(router
.name
)
92 assert result
is None, assertmsg
95 def test_bgp_convergence():
96 "Assert that BGP is converging."
98 if tgen
.routers_have_failure():
99 pytest
.skip(tgen
.errors
)
101 logger
.info("waiting for bgp peers to go up")
103 for router
in tgen
.routers().values():
104 ref_file
= "{}/{}/bgp_summary.json".format(CWD
, router
.name
)
105 expected
= json
.loads(open(ref_file
).read())
107 topotest
.router_json_cmp
, router
, "show ip bgp summary json", expected
109 _
, res
= topotest
.run_and_expect(test_func
, None, count
=125, wait
=1.0)
110 assertmsg
= "{}: bgp did not converge".format(router
.name
)
111 assert res
is None, assertmsg
114 def test_bgp_fast_convergence():
115 "Assert that BGP is converging before setting a link down."
117 if tgen
.routers_have_failure():
118 pytest
.skip(tgen
.errors
)
120 logger
.info("waiting for bgp peers converge")
122 for router
in tgen
.routers().values():
123 ref_file
= "{}/{}/bgp_prefixes.json".format(CWD
, router
.name
)
124 expected
= json
.loads(open(ref_file
).read())
126 topotest
.router_json_cmp
, router
, "show ip bgp json", expected
128 _
, res
= topotest
.run_and_expect(test_func
, None, count
=40, wait
=0.5)
129 assertmsg
= "{}: bgp did not converge".format(router
.name
)
130 assert res
is None, assertmsg
133 def test_bfd_fast_convergence():
135 Assert that BFD notices the link down after simulating network
139 if tgen
.routers_have_failure():
140 pytest
.skip(tgen
.errors
)
142 # Disable r1-eth0 link.
143 tgen
.gears
["r1"].link_enable("r1-eth0", enabled
=False)
145 # Wait the minimum time we can before checking that BGP/BFD
147 logger
.info("waiting for BFD converge")
149 # Check that BGP converged quickly.
150 for router
in tgen
.routers().values():
151 json_file
= "{}/{}/peers.json".format(CWD
, router
.name
)
152 expected
= json
.loads(open(json_file
).read())
154 # Load the same file as previous test, but expect R1 to be down.
155 if router
.name
== "r1":
156 for peer
in expected
:
157 if peer
["peer"] == "192.168.0.2":
158 peer
["status"] = "down"
160 for peer
in expected
:
161 if peer
["peer"] == "192.168.0.1":
162 peer
["status"] = "down"
165 topotest
.router_json_cmp
, router
, "show bfd peers json", expected
167 _
, res
= topotest
.run_and_expect(test_func
, None, count
=20, wait
=0.5)
168 assertmsg
= '"{}" JSON output mismatches'.format(router
.name
)
169 assert res
is None, assertmsg
172 def test_bgp_fast_reconvergence():
173 "Assert that BGP is converging after setting a link down."
175 if tgen
.routers_have_failure():
176 pytest
.skip(tgen
.errors
)
178 logger
.info("waiting for BGP re convergence")
180 # Check that BGP converged quickly.
181 for router
in tgen
.routers().values():
182 ref_file
= "{}/{}/bgp_prefixes.json".format(CWD
, router
.name
)
183 expected
= json
.loads(open(ref_file
).read())
185 # Load the same file as previous test, but set networks to None
187 if router
.name
== "r1":
188 expected
["routes"]["10.254.254.2/32"] = None
189 expected
["routes"]["10.254.254.3/32"] = None
190 expected
["routes"]["10.254.254.4/32"] = None
192 expected
["routes"]["10.254.254.1/32"] = None
195 topotest
.router_json_cmp
, router
, "show ip bgp json", expected
197 _
, res
= topotest
.run_and_expect(test_func
, None, count
=5, wait
=1)
198 assertmsg
= "{}: bgp did not converge".format(router
.name
)
199 assert res
is None, assertmsg
202 def test_memory_leak():
203 "Run the memory leak test and report results."
205 if not tgen
.is_memleak_enabled():
206 pytest
.skip("Memory leak test/report is disabled")
208 tgen
.report_memory_leaks()
211 if __name__
== "__main__":
212 args
= ["-s"] + sys
.argv
[1:]
213 sys
.exit(pytest
.main(args
))