2019-10-04 12:36:15 -07:00
|
|
|
import logging
|
2020-02-04 09:48:37 -08:00
|
|
|
import time
|
2018-04-20 17:00:47 -07:00
|
|
|
|
2020-02-04 09:48:37 -08:00
|
|
|
import params
|
2018-05-01 10:40:25 -07:00
|
|
|
from core.emulator.coreemu import CoreEmu
|
|
|
|
from core.emulator.emudata import IpPrefixes
|
2019-09-10 14:20:51 -07:00
|
|
|
from core.emulator.enumerations import EventTypes, NodeTypes
|
2019-02-16 09:50:19 -08:00
|
|
|
|
2018-04-20 17:00:47 -07:00
|
|
|
|
2019-10-22 15:13:28 -07:00
|
|
|
def example(args):
|
2018-04-20 17:00:47 -07:00
|
|
|
# ip generator for example
|
2018-04-24 16:24:54 -07:00
|
|
|
prefixes = IpPrefixes(ip4_prefix="10.83.0.0/16")
|
2018-04-20 17:00:47 -07:00
|
|
|
|
|
|
|
# create emulator instance for creating sessions and utility methods
|
|
|
|
coreemu = CoreEmu()
|
2018-04-24 16:24:54 -07:00
|
|
|
session = coreemu.create_session()
|
2018-04-20 17:00:47 -07:00
|
|
|
|
|
|
|
# must be in configuration state for nodes to start, when using "node_add" below
|
2018-04-25 16:33:58 -07:00
|
|
|
session.set_state(EventTypes.CONFIGURATION_STATE)
|
2018-04-20 17:00:47 -07:00
|
|
|
|
|
|
|
# create switch network node
|
2018-04-25 10:55:48 -07:00
|
|
|
switch = session.add_node(_type=NodeTypes.SWITCH)
|
2018-04-20 17:00:47 -07:00
|
|
|
|
|
|
|
# create nodes
|
2019-10-22 15:13:28 -07:00
|
|
|
for _ in range(args.nodes):
|
2018-04-25 10:55:48 -07:00
|
|
|
node = session.add_node()
|
2018-04-24 16:24:54 -07:00
|
|
|
interface = prefixes.create_interface(node)
|
2019-04-26 22:07:51 -07:00
|
|
|
session.add_link(node.id, switch.id, interface_one=interface)
|
2018-04-20 17:00:47 -07:00
|
|
|
|
|
|
|
# instantiate session
|
|
|
|
session.instantiate()
|
|
|
|
|
|
|
|
# get nodes to run example
|
2019-04-29 23:31:47 -07:00
|
|
|
first_node = session.get_node(2)
|
2019-10-22 15:13:28 -07:00
|
|
|
last_node = session.get_node(args.nodes + 1)
|
2018-04-24 16:24:54 -07:00
|
|
|
first_node_address = prefixes.ip4_address(first_node)
|
2020-02-04 09:48:37 -08:00
|
|
|
logging.info("node %s pinging %s", last_node.name, first_node_address)
|
|
|
|
output = last_node.cmd(f"ping -c {args.count} {first_node_address}")
|
2019-10-18 10:33:31 -07:00
|
|
|
logging.info(output)
|
2018-04-20 17:00:47 -07:00
|
|
|
|
|
|
|
# shutdown session
|
|
|
|
coreemu.shutdown()
|
|
|
|
|
|
|
|
|
|
|
|
def main():
|
2019-10-04 12:36:15 -07:00
|
|
|
logging.basicConfig(level=logging.INFO)
|
2020-02-04 09:48:37 -08:00
|
|
|
args = params.parse("switch")
|
|
|
|
start = time.perf_counter()
|
|
|
|
logging.info(
|
|
|
|
"running switch example: nodes(%s) ping count(%s)", args.nodes, args.count
|
|
|
|
)
|
2019-10-22 15:13:28 -07:00
|
|
|
example(args)
|
2020-02-04 09:48:37 -08:00
|
|
|
logging.info("elapsed time: %s", time.perf_counter() - start)
|
2018-04-20 17:00:47 -07:00
|
|
|
|
|
|
|
|
|
|
|
if __name__ == "__main__":
|
|
|
|
main()
|