From: peusterm Date: Mon, 6 Mar 2017 15:53:40 +0000 (+0100) Subject: Merge pull request #201 from cgeoffroy/pr/add_ci_tests X-Git-Tag: v3.1~41 X-Git-Url: https://osm.etsi.org/gitweb/?a=commitdiff_plain;h=07e8a120672ecf1844a76be6eca3c911c67e119b;hp=549e20fa8370d163c45b1e9b9e100baf2148c1e2;p=osm%2Fvim-emu.git Merge pull request #201 from cgeoffroy/pr/add_ci_tests Adding a new ci test --- diff --git a/src/emuvim/examples/profiling.py b/src/emuvim/examples/profiling.py new file mode 100644 index 0000000..daac301 --- /dev/null +++ b/src/emuvim/examples/profiling.py @@ -0,0 +1,116 @@ +""" +Copyright (c) 2015 SONATA-NFV +ALL RIGHTS RESERVED. + +Licensed under the Apache License, Version 2.0 (the "License"); +you may not use this file except in compliance with the License. +You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + +Unless required by applicable law or agreed to in writing, software +distributed under the License is distributed on an "AS IS" BASIS, +WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +See the License for the specific language governing permissions and +limitations under the License. + +Neither the name of the SONATA-NFV [, ANY ADDITIONAL AFFILIATION] +nor the names of its contributors may be used to endorse or promote +products derived from this software without specific prior written +permission. + +This work has been performed in the framework of the SONATA project, +funded by the European Commission under Grant number 671517 through +the Horizon 2020 and 5G-PPP programmes. The authors would like to +acknowledge the contributions of their colleagues of the SONATA +partner consortium (www.sonata-nfv.eu). +""" +""" +A simple topology with a single data center for usage in son-profile. + +""" + +import logging +from mininet.log import setLogLevel +from emuvim.dcemulator.net import DCNetwork +from emuvim.api.rest.rest_api_endpoint import RestApiEndpoint +from emuvim.api.sonata import SonataDummyGatekeeperEndpoint +from mininet.node import RemoteController +from time import sleep +import argparse +import sys +import signal + +logging.basicConfig() +LOG = logging.getLogger("sonata-profiling") +LOG.setLevel(logging.DEBUG) +logging.getLogger("werkzeug").setLevel(logging.WARNING) + +""" + Catches SIGINT and SIGTERM to shut the topology down gracefully. +""" +class GracefulKiller: + def __init__(self, to_be_killed): + signal.signal(signal.SIGINT, self.exit_gracefully) + signal.signal(signal.SIGTERM, self.exit_gracefully) + self.to_be_killed = to_be_killed + + def exit_gracefully(self, signum, frame): + self.to_be_killed.stop_it() + + +""" + A simple topology with only one data center which will stop when another thread tells it to or when a time limit is reached. + :args: an argument list which may contain the time limit +""" +class Profiling: + + stop_now = False + + """ + Set up a simple topology and start it + """ + def __init__(self): + GracefulKiller(self) + # create topology + self.net = DCNetwork(controller=RemoteController, monitor=False, enable_learning=False) + self.dc = self.net.addDatacenter("dc1") + + # add the command line interface endpoint to each DC (REST API) + self.rapi1 = RestApiEndpoint("0.0.0.0", 5001) + self.rapi1.connectDCNetwork(self.net) + self.rapi1.connectDatacenter(self.dc) + # run API endpoint server (in another thread, don't block) + self.rapi1.start() + + # add the SONATA dummy gatekeeper to each DC + self.sdkg1 = SonataDummyGatekeeperEndpoint("0.0.0.0", 5000, deploy_sap=False) + self.sdkg1.connectDatacenter(self.dc) + # run the dummy gatekeeper (in another thread, don't block) + self.sdkg1.start() + + + self.net.start() + LOG.info("Started topology") + while(not self.stop_now): + sleep(1) + self.net.stop() + LOG.info("Stopped topology") + + """ + Set stop value to stop the topology + """ + def stop_it(self): + self.stop_now = True + + +def main(args): + setLogLevel('info') # set Mininet loglevel + p = Profiling() + + +if __name__ == '__main__': + parser = argparse.ArgumentParser(description="Run a simple topology") + parser.add_argument('--time', '-t', metavar='seconds', type=float, help='a time limit', default=-1, required=False, dest='time') + arg_list = vars(parser.parse_args(sys.argv[1:])) + main(arg_list)