mirror of
https://git.proxmox.com/git/mirror_frr
synced 2025-05-06 10:08:31 +00:00

Topogen (Topology Generator) is a helper that wraps around Topotest to simplify some of the boilerplate code. This abstraction will help the development of new tests and new APIs without breaking the existing ones. It also makes the relation of objects clearer, since we no longer touch the Mininet API directly, which in turn also makes us less vulnerable to external API changes.
108 lines
3.4 KiB
Python
108 lines
3.4 KiB
Python
#!/usr/bin/env python
|
|
|
|
#
|
|
# <template>.py
|
|
# Part of NetDEF Topology Tests
|
|
#
|
|
# Copyright (c) 2017 by
|
|
# Network Device Education Foundation, Inc. ("NetDEF")
|
|
#
|
|
# Permission to use, copy, modify, and/or distribute this software
|
|
# for any purpose with or without fee is hereby granted, provided
|
|
# that the above copyright notice and this permission notice appear
|
|
# in all copies.
|
|
#
|
|
# THE SOFTWARE IS PROVIDED "AS IS" AND NETDEF DISCLAIMS ALL WARRANTIES
|
|
# WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
|
# MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL NETDEF BE LIABLE FOR
|
|
# ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY
|
|
# DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS,
|
|
# WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS
|
|
# ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE
|
|
# OF THIS SOFTWARE.
|
|
#
|
|
|
|
"""
|
|
<template>.py: Test <template>.
|
|
"""
|
|
|
|
import os
|
|
import sys
|
|
import pytest
|
|
|
|
# Required to instantiate the topology builder class.
|
|
from mininet.topo import Topo
|
|
|
|
# Save the Current Working Directory to find configuration files.
|
|
CWD = os.path.dirname(os.path.realpath(__file__))
|
|
# Append to the search path the lib location
|
|
sys.path.append(os.path.join(CWD, '..'))
|
|
|
|
# pylint: disable=C0413
|
|
# Import topogen and topotest helpers
|
|
from lib import topotest
|
|
from lib.topogen import Topogen, TopoRouter, get_topogen
|
|
|
|
class TemplateTopo(Topo):
|
|
"Test topology builder"
|
|
def build(self, *_args, **_opts):
|
|
"Build function"
|
|
# pylint: disable=E1101
|
|
# Linter incorrectly detects tgen type as TemplateTopo.
|
|
tgen = get_topogen(self)
|
|
|
|
# This function only purpose is to define allocation and relationship
|
|
# between routers, switches and hosts.
|
|
#
|
|
# Example
|
|
#
|
|
# Create 2 routers
|
|
for _router in range(1, 3):
|
|
tgen.add_router()
|
|
|
|
# Create a switch with just one router connected to it to simulate a
|
|
# empty network.
|
|
switch = tgen.add_switch()
|
|
switch.add_link(tgen.gears['router1'])
|
|
|
|
# Create a connection between router1 and router2
|
|
switch = tgen.add_switch()
|
|
switch.add_link(tgen.gears['router1'])
|
|
switch.add_link(tgen.gears['router2'])
|
|
|
|
def setup_module(_m):
|
|
"Sets up the pytest environment"
|
|
# This function initiates the topology build with Topogen...
|
|
tgen = Topogen(TemplateTopo)
|
|
# ... and here it calls Mininet initialization functions.
|
|
# When deploying tests, please remove the debug logging level.
|
|
tgen.start_topology('debug')
|
|
|
|
# This is a sample of configuration loading.
|
|
router_list = tgen.routers()
|
|
|
|
# For all registred routers, load the zebra configuration file
|
|
for rname, router in router_list.iteritems():
|
|
router.load_config(
|
|
TopoRouter.RD_ZEBRA,
|
|
# Uncomment next line to load configuration from ./router/zebra.conf
|
|
#os.path.join(CWD, '{}/zebra.conf'.format(rname))
|
|
)
|
|
|
|
# After loading the configurations, this function loads configured daemons.
|
|
tgen.start_router()
|
|
|
|
def teardown_module(_m):
|
|
"Teardown the pytest environment"
|
|
tgen = get_topogen()
|
|
# This function tears down the whole topology.
|
|
tgen.stop_topology()
|
|
|
|
def test_call_mininet_cli():
|
|
"Dummy test that just calls mininet CLI so we can interact with the build."
|
|
tgen = get_topogen()
|
|
tgen.mininet_cli()
|
|
|
|
if __name__ == '__main__':
|
|
sys.exit(pytest.main(["-s"]))
|