cls.init_failed = False
cls.odl_process = test_utils.start_tpce()
+ # TAPI feature is not installed by default in Karaf
if "USE_LIGHTY" not in os.environ or os.environ['USE_LIGHTY'] != 'True':
- karaf_log = os.path.join(
- os.path.dirname(os.path.realpath(__file__)),
- "..", "..", "..", "karaf", "target", "assembly", "data", "log", "karaf.log")
- searched_expr = re.escape("Blueprint container for bundle "
- "org.opendaylight.netconf.restconf") + ".* was successfully created"
- found = test_utils.wait_until_log_contains(karaf_log, searched_expr, time_to_wait=60)
- cls.init_failed = not found
- if not cls.init_failed:
- print("opendaylight started")
- print("installing tapi feature...")
- result = test_utils.install_karaf_feature("odl-transportpce-tapi")
- if result.returncode != 0:
- cls.init_failed = True
- print("Restarting opendaylight...")
- test_utils.shutdown_process(cls.odl_process)
- cls.odl_process = test_utils.start_tpce()
- found = test_utils.wait_until_log_contains(karaf_log, searched_expr, time_to_wait=60)
- cls.init_failed = not found
- if not cls.init_failed:
- cls.sim_process1 = test_utils.start_sim('xpdra')
-
- cls.sim_process2 = test_utils.start_sim('roadma')
-
- cls.sim_process3 = test_utils.start_sim('roadmc')
-
- cls.sim_process4 = test_utils.start_sim('xpdrc')
-
- cls.sim_process5 = test_utils.start_sim('spdrav2')
- print("all sims started")
+ print("installing tapi feature...")
+ result = test_utils.install_karaf_feature("odl-transportpce-tapi")
+ if result.returncode != 0:
+ cls.init_failed = True
+ print("Restarting opendaylight...")
+ test_utils.shutdown_process(cls.odl_process)
+ cls.odl_process = test_utils.start_tpce()
+ cls.init_failed = not test_utils.wait_until_log_contains(
+ test_utils.karaf_log, test_utils.KARAF_OK_START_MSG, time_to_wait=60)
+ if cls.init_failed:
+ print("tapi installaiton feature failed...")
+ test_utils.shutdown_process(cls.odl_process)
+ exit(2)
+ cls.sim_process1 = test_utils.start_sim('xpdra')
+ cls.sim_process2 = test_utils.start_sim('roadma')
+ cls.sim_process3 = test_utils.start_sim('roadmc')
+ cls.sim_process4 = test_utils.start_sim('xpdrc')
+ cls.sim_process5 = test_utils.start_sim('spdrav2')
@classmethod
def tearDownClass(cls):
}
HONEYNODE_OK_START_MSG = re.escape("Netconf SSH endpoint started successfully at 0.0.0.0")
+KARAF_OK_START_MSG = re.escape("Blueprint container for bundle "
+ "org.opendaylight.netconf.restconf") + ".* was successfully created"
TYPE_APPLICATION_JSON = {'content-type': 'application/json'}
log_directory = os.path.dirname(os.path.realpath(__file__))
+karaf_log = os.path.join(
+ os.path.dirname(os.path.realpath(__file__)),
+ "..", "..", "..", "karaf", "target", "assembly", "data", "log", "karaf.log")
+
def start_sim(sim):
print("starting simulator for " + sim + "...")
log_file = os.path.join(log_directory, sims[sim]['logfile'])
- process = start_node(log_file, sims[sim]['port'], sims[sim]['configfile'])
+ process = start_honeynode(log_file, sims[sim]['port'], sims[sim]['configfile'])
if wait_until_log_contains(log_file, HONEYNODE_OK_START_MSG, 5000):
print("simulator for " + sim + " started")
else:
def start_tpce():
print("starting opendaylight...")
if "USE_LIGHTY" in os.environ and os.environ['USE_LIGHTY'] == 'True':
- print("starting LIGHTY.IO TransportPCE build...")
- executable = os.path.join(
- os.path.dirname(os.path.realpath(__file__)),
- "..", "..", "..", "lighty", "target", "tpce",
- "clean-start-controller.sh")
- with open('odl.log', 'w') as outfile:
- return subprocess.Popen(
- ["sh", executable], stdout=outfile, stderr=outfile, stdin=None)
+ process = start_lighty()
+ # TODO: add some sort of health check similar to Karaf below
else:
- print("starting KARAF TransportPCE build...")
- executable = os.path.join(
- os.path.dirname(os.path.realpath(__file__)),
- "..", "..", "..", "karaf", "target", "assembly", "bin", "karaf")
- with open('odl.log', 'w') as outfile:
- return subprocess.Popen(
- ["sh", executable, "server"], stdout=outfile, stderr=outfile, stdin=None)
+ process = start_karaf()
+ if wait_until_log_contains(karaf_log, KARAF_OK_START_MSG, time_to_wait=60):
+ print("opendaylight started")
+ else:
+ print("opendaylight failed to start")
+ shutdown_process(process)
+ exit(1)
+ return process
+
+
+def start_karaf():
+ print("starting KARAF TransportPCE build...")
+ executable = os.path.join(
+ os.path.dirname(os.path.realpath(__file__)),
+ "..", "..", "..", "karaf", "target", "assembly", "bin", "karaf")
+ with open('odl.log', 'w') as outfile:
+ return subprocess.Popen(
+ ["sh", executable, "server"], stdout=outfile, stderr=outfile, stdin=None)
+
+
+def start_lighty():
+ print("starting LIGHTY.IO TransportPCE build...")
+ executable = os.path.join(
+ os.path.dirname(os.path.realpath(__file__)),
+ "..", "..", "..", "lighty", "target", "tpce",
+ "clean-start-controller.sh")
+ with open('odl.log', 'w') as outfile:
+ return subprocess.Popen(
+ ["sh", executable], stdout=outfile, stderr=outfile, stdin=None)
def install_karaf_feature(feature_name: str):
process.send_signal(signal.SIGINT)
-def start_node(log_file: str, node_port: str, node_config_file_name: str):
+def start_honeynode(log_file: str, node_port: str, node_config_file_name: str):
if os.path.isfile(honeynode_executable):
with open(log_file, 'w') as outfile:
return subprocess.Popen(