]>
git.proxmox.com Git - mirror_frr.git/blob - tests/topotests/pim_basic_topo2/test_pim_basic_topo2.py
4 # test_pim_basic_topo2.py
5 # Part of NetDEF Topology Tests
7 # Copyright (c) 2021 by
8 # Network Device Education Foundation, Inc. ("NetDEF")
10 # Permission to use, copy, modify, and/or distribute this software
11 # for any purpose with or without fee is hereby granted, provided
12 # that the above copyright notice and this permission notice appear
15 # THE SOFTWARE IS PROVIDED "AS IS" AND NETDEF DISCLAIMS ALL WARRANTIES
16 # WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
17 # MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL NETDEF BE LIABLE FOR
18 # ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY
19 # DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS,
20 # WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS
21 # ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE
26 test_pim_basic_topo2.py: Test the FRR PIM protocol convergence.
31 from functools
import partial
34 # Save the Current Working Directory to find configuration files.
35 CWD
= os
.path
.dirname(os
.path
.realpath(__file__
))
36 sys
.path
.append(os
.path
.join(CWD
, "../"))
38 # pylint: disable=C0413
39 # Import topogen and topotest helpers
40 from lib
import topotest
41 from lib
.topogen
import Topogen
, TopoRouter
, get_topogen
42 from lib
.topolog
import logger
44 # Required to instantiate the topology builder class.
46 pytestmark
= [pytest
.mark
.bfdd
, pytest
.mark
.pimd
]
53 for routern
in range(1, 5):
54 tgen
.add_router("r{}".format(routern
))
56 switch
= tgen
.add_switch("s1")
57 switch
.add_link(tgen
.gears
["r1"])
58 switch
.add_link(tgen
.gears
["r2"])
60 switch
= tgen
.add_switch("s2")
61 switch
.add_link(tgen
.gears
["r2"])
62 switch
.add_link(tgen
.gears
["r3"])
64 switch
= tgen
.add_switch("s3")
65 switch
.add_link(tgen
.gears
["r2"])
66 switch
.add_link(tgen
.gears
["r4"])
69 def setup_module(mod
):
70 "Sets up the pytest environment"
71 tgen
= Topogen(build_topo
, mod
.__name
__)
74 router_list
= tgen
.routers()
75 for rname
, router
in router_list
.items():
76 daemon_file
= "{}/{}/bfdd.conf".format(CWD
, rname
)
77 if os
.path
.isfile(daemon_file
):
78 router
.load_config(TopoRouter
.RD_BFD
, daemon_file
)
80 daemon_file
= "{}/{}/pimd.conf".format(CWD
, rname
)
81 if os
.path
.isfile(daemon_file
):
82 router
.load_config(TopoRouter
.RD_PIM
, daemon_file
)
84 daemon_file
= "{}/{}/zebra.conf".format(CWD
, rname
)
85 if os
.path
.isfile(daemon_file
):
86 router
.load_config(TopoRouter
.RD_ZEBRA
, daemon_file
)
88 # Initialize all routers.
92 def teardown_module(_mod
):
93 "Teardown the pytest environment"
98 def expect_neighbor(router
, interface
, peer
):
99 "Wait until peer is present on interface."
100 logger
.info("waiting peer {} in {}".format(peer
, interface
))
103 topotest
.router_json_cmp
,
105 "show ip pim neighbor json",
106 {interface
: {peer
: {}}},
108 _
, result
= topotest
.run_and_expect(test_func
, None, count
=130, wait
=1)
109 assertmsg
= '"{}" PIM convergence failure'.format(router
)
110 assert result
is None, assertmsg
113 def test_wait_pim_convergence():
114 "Wait for PIM to converge"
116 if tgen
.routers_have_failure():
117 pytest
.skip(tgen
.errors
)
119 logger
.info("waiting for PIM to converge")
121 expect_neighbor("r1", "r1-eth0", "192.168.1.2")
122 expect_neighbor("r2", "r2-eth0", "192.168.1.1")
124 expect_neighbor("r2", "r2-eth1", "192.168.2.3")
125 expect_neighbor("r2", "r2-eth2", "192.168.3.4")
127 expect_neighbor("r3", "r3-eth0", "192.168.2.1")
128 expect_neighbor("r4", "r4-eth0", "192.168.3.1")
131 def test_bfd_peers():
132 "Wait for BFD peers to show up."
134 if tgen
.routers_have_failure():
135 pytest
.skip(tgen
.errors
)
137 logger
.info("waiting for BFD to converge")
139 def expect_bfd_peer(router
, peer
):
140 "Wait until peer is present on interface."
141 logger
.info("waiting BFD peer {} in {}".format(peer
, router
))
143 topotest
.router_json_cmp
,
145 "show bfd peers json",
146 [{"peer": peer
, "status": "up"}],
148 _
, result
= topotest
.run_and_expect(test_func
, None, count
=10, wait
=1)
149 assertmsg
= '"{}" BFD convergence failure'.format(router
)
150 assert result
is None, assertmsg
152 expect_bfd_peer("r1", "192.168.1.2")
153 expect_bfd_peer("r2", "192.168.1.1")
154 expect_bfd_peer("r2", "192.168.2.3")
155 expect_bfd_peer("r2", "192.168.3.4")
156 expect_bfd_peer("r3", "192.168.2.1")
157 expect_bfd_peer("r4", "192.168.3.1")
160 def test_pim_reconvergence():
161 "Disconnect a peer and expect it to disconnect."
163 if tgen
.routers_have_failure():
164 pytest
.skip(tgen
.errors
)
166 logger
.info("waiting for disconnect convergence")
167 tgen
.gears
["r4"].link_enable("r4-eth0", enabled
=False)
169 def expect_neighbor_down(router
, interface
, peer
):
170 "Wait until peer is present on interface."
171 logger
.info("waiting peer {} in {} to disappear".format(peer
, interface
))
173 topotest
.router_json_cmp
,
175 "show ip pim neighbor json",
176 {interface
: {peer
: None}},
178 _
, result
= topotest
.run_and_expect(test_func
, None, count
=5, wait
=1)
179 assertmsg
= '"{}" PIM convergence failure'.format(router
)
180 assert result
is None, assertmsg
182 expect_neighbor_down("r2", "r2-eth2", "192.168.3.4")
184 logger
.info("waiting for reconvergence")
185 tgen
.gears
["r4"].link_enable("r4-eth0", enabled
=True)
186 expect_neighbor("r2", "r2-eth2", "192.168.3.4")
189 def test_pim_bfd_profile():
190 "Test that the BFD profile is properly applied in BFD."
192 if tgen
.routers_have_failure():
193 pytest
.skip(tgen
.errors
)
195 def expect_bfd_peer_settings(router
, settings
):
196 "Expect the following BFD configuration"
197 logger
.info("Verifying BFD peer {} in {}".format(settings
["peer"], router
))
199 topotest
.router_json_cmp
,
201 "show bfd peers json",
204 _
, result
= topotest
.run_and_expect(test_func
, None, count
=5, wait
=1)
205 assertmsg
= '"{}" BFD convergence failure'.format(router
)
206 assert result
is None, assertmsg
208 expect_bfd_peer_settings(
211 "peer": "192.168.1.2",
212 "receive-interval": 250,
213 "transmit-interval": 250,
217 expect_bfd_peer_settings(
220 "peer": "192.168.1.1",
221 "remote-receive-interval": 250,
222 "remote-transmit-interval": 250,
227 def test_memory_leak():
228 "Run the memory leak test and report results."
230 if not tgen
.is_memleak_enabled():
231 pytest
.skip("Memory leak test/report is disabled")
233 tgen
.report_memory_leaks()
236 if __name__
== "__main__":
237 args
= ["-s"] + sys
.argv
[1:]
238 sys
.exit(pytest
.main(args
))