]>
git.proxmox.com Git - mirror_frr.git/blob - tests/topotests/babel_topo1/test_babel_topo1.py
2 # SPDX-License-Identifier: ISC
7 # Copyright (c) 2017 by
8 # Cumulus Networks, Inc.
13 test_babel_topo1.py: Testing BABEL
23 pytestmark
= [pytest
.mark
.babeld
]
25 # Save the Current Working Directory to find configuration files.
26 CWD
= os
.path
.dirname(os
.path
.realpath(__file__
))
27 sys
.path
.append(os
.path
.join(CWD
, "../"))
29 # pylint: disable=C0413
30 # Import topogen and topotest helpers
31 from lib
import topotest
32 from lib
.topogen
import Topogen
, TopoRouter
, get_topogen
33 from lib
.topolog
import logger
35 # Required to instantiate the topology builder class.
37 #####################################################
39 ## Network Topology Definition
41 #####################################################
45 for routern
in range(1, 4):
46 tgen
.add_router("r{}".format(routern
))
49 # First switch is for a dummy interface (for local network)
50 switch
= tgen
.add_switch("sw1")
51 switch
.add_link(tgen
.gears
["r1"])
54 # switch 2 switch is for connection to BABEL router
55 switch
= tgen
.add_switch("sw2")
56 switch
.add_link(tgen
.gears
["r1"])
57 switch
.add_link(tgen
.gears
["r2"])
59 # switch 4 is stub on remote BABEL router
60 switch
= tgen
.add_switch("sw4")
61 switch
.add_link(tgen
.gears
["r3"])
63 # switch 3 is between BABEL routers
64 switch
= tgen
.add_switch("sw3")
65 switch
.add_link(tgen
.gears
["r2"])
66 switch
.add_link(tgen
.gears
["r3"])
69 #####################################################
73 #####################################################
76 def setup_module(module
):
78 tgen
= Topogen(build_topo
, module
.__name
__)
81 # This is a sample of configuration loading.
82 router_list
= tgen
.routers()
83 for rname
, router
in router_list
.items():
85 TopoRouter
.RD_ZEBRA
, os
.path
.join(CWD
, "{}/zebra.conf".format(rname
))
88 TopoRouter
.RD_BABEL
, os
.path
.join(CWD
, "{}/babeld.conf".format(rname
))
94 def teardown_module(_mod
):
95 "Teardown the pytest environment"
98 # This function tears down the whole topology.
102 def test_converge_protocols():
103 "Wait for protocol convergence"
106 # Don't run this test if we have any failure.
107 if tgen
.routers_have_failure():
108 pytest
.skip(tgen
.errors
)
110 topotest
.sleep(10, "Waiting for BABEL convergence")
113 def test_zebra_ipv4_routingTable():
114 "Test 'show ip route'"
117 # Don't run this test if we have any failure.
118 if tgen
.routers_have_failure():
119 pytest
.skip(tgen
.errors
)
122 router_list
= tgen
.routers().values()
123 for router
in router_list
:
124 output
= router
.vtysh_cmd("show ip route json", isjson
=True)
125 refTableFile
= "{}/{}/show_ip_route.json_ref".format(CWD
, router
.name
)
126 expected
= json
.loads(open(refTableFile
).read())
128 assertmsg
= "Zebra IPv4 Routing Table verification failed for router {}".format(
131 assert topotest
.json_cmp(output
, expected
) is None, assertmsg
133 def test_shutdown_check_stderr():
134 if os
.environ
.get("TOPOTESTS_CHECK_STDERR") is None:
135 pytest
.skip("Skipping test for Stderr output and memory leaks")
138 # Don't run this test if we have any failure.
139 if tgen
.routers_have_failure():
140 pytest
.skip(tgen
.errors
)
142 logger
.info("Verifying unexpected STDERR output from daemons")
144 router_list
= tgen
.routers().values()
145 for router
in router_list
:
148 log
= tgen
.net
[router
.name
].getStdErr("babeld")
150 logger
.error("BABELd StdErr Log:" + log
)
151 log
= tgen
.net
[router
.name
].getStdErr("zebra")
153 logger
.error("Zebra StdErr Log:" + log
)
156 if __name__
== "__main__":
157 args
= ["-s"] + sys
.argv
[1:]
158 sys
.exit(pytest
.main(args
))