#!/usr/bin/env python
##############################################################################
-#Copyright (c) 2017 Orange, Inc. and others. All rights reserved.
+# Copyright (c) 2017 Orange, Inc. and others. All rights reserved.
#
# All rights reserved. This program and the accompanying materials
# are made available under the terms of the Apache License, Version 2.0
##############################################################################
import json
-import os
-import psutil
-import requests
import signal
-import shutil
-import subprocess
import time
import unittest
-import logging
+import requests
+import psutil
+import test_utils
+
class TransportPCEtesting(unittest.TestCase):
odl_process = None
restconf_baseurl = "http://localhost:8181/restconf"
-#START_IGNORE_XTESTING
-
- @classmethod
- def __init_logfile(cls):
- if not os.path.exists("transportpce_tests/log"):
- os.makedirs("transportpce_tests/log")
- if os.path.isfile("./transportpce_tests/log/topoPortMap.log"):
- os.remove("transportpce_tests/log/topoPortMap.log")
-
- @classmethod
- def __start_honeynode1(cls):
- executable = ("./honeynode/2.1/honeynode-distribution/target/honeynode-distribution-1.18.01-hc"
- "/honeynode-distribution-1.18.01/honeycomb-tpce")
- if os.path.isfile(executable):
- with open('honeynode1.log', 'w') as outfile:
- cls.honeynode_process1 = subprocess.Popen(
- [executable, "17830", "sample_configs/openroadm/2.1/oper-XPDRA.xml"],
- stdout=outfile)
-
-
- @classmethod
- def __start_honeynode2(cls):
- executable = ("./honeynode/2.1/honeynode-distribution/target/honeynode-distribution-1.18.01-hc"
- "/honeynode-distribution-1.18.01/honeycomb-tpce")
- if os.path.isfile(executable):
- with open('honeynode2.log', 'w') as outfile:
- cls.honeynode_process2 = subprocess.Popen(
- [executable, "17831", "sample_configs/openroadm/2.1/oper-ROADMA.xml"],
- stdout=outfile)
-
-
- @classmethod
- def __start_odl(cls):
- executable = "../karaf/target/assembly/bin/karaf"
- with open('transportpce_tests/log/odl.log', 'w') as outfile:
- cls.odl_process = subprocess.Popen(
- ["bash", executable, "server"], stdout=outfile,
- stdin=open(os.devnull))
+# START_IGNORE_XTESTING
@classmethod
def setUpClass(cls):
- cls.__init_logfile()
- time.sleep(2)
- cls.__start_honeynode1()
+ print("starting honeynode1...")
+ cls.honeynode_process1 = test_utils.start_xpdra_honeynode()
time.sleep(20)
- cls.__start_honeynode2()
+
+ print("starting honeynode2...")
+ cls.honeynode_process2 = test_utils.start_roadma_honeynode()
time.sleep(20)
- cls.__start_odl()
+
+ print("starting opendaylight...")
+ cls.odl_process = test_utils.start_tpce()
time.sleep(60)
+ print("opendaylight started")
@classmethod
def tearDownClass(cls):
def setUp(self):
time.sleep(10)
-#END_IGNORE_XTESTING
+# END_IGNORE_XTESTING
- #Connect the ROADMA
- def test_01_connect_roadma(self):
- #Config ROADMA
+ # Connect the ROADMA
+ def test_01_connect_rdm(self):
+ # Config ROADMA
url = ("{}/config/network-topology:"
- "network-topology/topology/topology-netconf/node/ROADMA"
+ "network-topology/topology/topology-netconf/node/ROADMA01"
.format(self.restconf_baseurl))
data = {"node": [{
- "node-id": "ROADMA",
- "netconf-node-topology:username": "admin",
- "netconf-node-topology:password": "admin",
- "netconf-node-topology:host": "127.0.0.1",
- "netconf-node-topology:port": "17831",
- "netconf-node-topology:tcp-only": "false",
- "netconf-node-topology:pass-through": {}}]}
+ "node-id": "ROADMA01",
+ "netconf-node-topology:username": "admin",
+ "netconf-node-topology:password": "admin",
+ "netconf-node-topology:host": "127.0.0.1",
+ "netconf-node-topology:port": "17831",
+ "netconf-node-topology:tcp-only": "false",
+ "netconf-node-topology:pass-through": {}}]}
headers = {'content-type': 'application/json'}
response = requests.request(
- "PUT", url, data=json.dumps(data), headers=headers,
- auth=('admin', 'admin'))
+ "PUT", url, data=json.dumps(data), headers=headers,
+ auth=('admin', 'admin'))
self.assertEqual(response.status_code, requests.codes.created)
- #seems sometimes to return 200 instead of 201
- #self.assertEqual(response.status_code, requests.codes.ok)
- time.sleep(10)
-
- #Verify the termination points of the ROADMA
- def test_02_compareOpenroadmTopologyPortMapping(self):
- #Verify the termination points related to the SRGs
- nbSrg=1
- for s in range(1,nbSrg+1):
- url_topo="{}/config/ietf-network:networks/network/openroadm-topology/node/ROADMA-SRG"+`s`
- with open('./transportpce_tests/log/topoPortMap.log', 'a') as outfile1:
- outfile1.write('Config: '+`s`+' : '+url_topo+'\n')
- url = (url_topo.format(self.restconf_baseurl))
- headers = {'content-type': 'application/json'}
- response_topo = requests.request(
- "GET", url, headers=headers, auth=('admin', 'admin'))
- self.assertEqual(response_topo.status_code, requests.codes.ok)
- res_topo = response_topo.json()
- nbTP=len(res_topo['node'][0]['ietf-network-topology:termination-point'])
- for i in range(0,nbTP):
- tp_id=res_topo['node'][0]['ietf-network-topology:termination-point'][i]['tp-id']
- if(not "CP" in tp_id):
- url_map="{}/config/transportpce-portmapping:network/nodes/ROADMA/mapping/"+tp_id
- with open('./transportpce_tests/log/topoPortMap.log', 'a') as outfile1:
- outfile1.write('Config: '+`i`+'/'+ `nbTP`+' : '+url_map+'\n')
- url = (url_map.format(self.restconf_baseurl))
- headers = {'content-type': 'application/json'}
- response_portMap = requests.request(
- "GET", url, headers=headers, auth=('admin', 'admin'))
- self.assertEqual(response_portMap.status_code, requests.codes.ok)
-
- #Verify the termination points related to the degrees
- nbDeg=2
- for d in range(1,nbDeg+1):
- url_topo="{}/config/ietf-network:networks/network/openroadm-topology/node/ROADMA-DEG"+`d`
- with open('./transportpce_tests/log/topoPortMap.log', 'a') as outfile1:
- outfile1.write(url_topo+'\n')
- url = (url_topo.format(self.restconf_baseurl))
- headers = {'content-type': 'application/json'}
- response_topo = requests.request(
- "GET", url, headers=headers, auth=('admin', 'admin'))
- self.assertEqual(response_topo.status_code, requests.codes.ok)
- res_topo = response_topo.json()
- nbTP=len(res_topo['node'][0]['ietf-network-topology:termination-point'])
- for i in range(0,nbTP):
- tp_id=res_topo['node'][0]['ietf-network-topology:termination-point'][i]['tp-id']
- if(not "CTP" in tp_id):
- url_map ="{}/config/transportpce-portmapping:network/nodes/ROADMA/mapping/"+tp_id
- with open('./transportpce_tests/log/topoPortMap.log', 'a') as outfile1:
- outfile1.write('Config: '+`i`+'/'+ `nbTP`+' : '+url_map+'\n')
- url = (url_map.format(self.restconf_baseurl))
- headers = {'content-type': 'application/json'}
- response_portMap = requests.request(
- "GET", url, headers=headers, auth=('admin', 'admin'))
- self.assertEqual(response_portMap.status_code, requests.codes.ok)
- time.sleep(1)
+ time.sleep(20)
- #Disconnect the ROADMA
- def test_03_disconnect_device(self):
+ # Verify the termination points of the ROADMA
+ def test_02_compareOpenroadmTopologyPortMapping_rdm(self):
+ urlTopo = ("{}/config/ietf-network:networks/network/openroadm-topology"
+ .format(self.restconf_baseurl))
+ headers = {'content-type': 'application/json'}
+ responseTopo = requests.request("GET", urlTopo, headers=headers, auth=('admin', 'admin'))
+ resTopo = responseTopo.json()
+ nbNode = len(resTopo['network'][0]['node'])
+ nbMapCumul = 0
+ nbMappings = 0
+ for i in range(0, nbNode):
+ nodeId = resTopo['network'][0]['node'][i]['node-id']
+ nodeMapId = nodeId.split("-")[0]
+ urlMapList = "{}/config/transportpce-portmapping:network/nodes/" + nodeMapId
+ urlMapListFull = urlMapList.format(self.restconf_baseurl)
+ responseMapList = requests.request("GET", urlMapListFull, headers=headers, auth=('admin', 'admin'))
+ resMapList = responseMapList.json()
+
+ nbMappings = len(resMapList['nodes'][0]['mapping']) - nbMapCumul
+ nbTp = len(resTopo['network'][0]['node'][i]['ietf-network-topology:termination-point'])
+ nbMapCurrent = 0
+ for j in range(0, nbTp):
+ tpId = resTopo['network'][0]['node'][i]['ietf-network-topology:termination-point'][j]['tp-id']
+ if((not "CP" in tpId) and (not "CTP" in tpId)):
+ urlMap = "{}/config/transportpce-portmapping:network/nodes/" + nodeMapId + "/mapping/" + tpId
+ urlMapFull = urlMap.format(self.restconf_baseurl)
+ responseMap = requests.request("GET", urlMapFull, headers=headers, auth=('admin', 'admin'))
+ self.assertEqual(responseMap.status_code, requests.codes.ok)
+ if responseMap.status_code == requests.codes.ok:
+ nbMapCurrent += 1
+ nbMapCumul += nbMapCurrent
+ nbMappings -= nbMapCurrent
+ self.assertEqual(nbMappings, 0)
+
+ # Disconnect the ROADMA
+ def test_03_disconnect_rdm(self):
url = ("{}/config/network-topology:"
- "network-topology/topology/topology-netconf/node/ROADMA"
+ "network-topology/topology/topology-netconf/node/ROADMA01"
.format(self.restconf_baseurl))
data = {}
headers = {'content-type': 'application/json'}
response = requests.request(
- "DELETE", url, data=json.dumps(data), headers=headers,
- auth=('admin', 'admin'))
+ "DELETE", url, data=json.dumps(data), headers=headers,
+ auth=('admin', 'admin'))
self.assertEqual(response.status_code, requests.codes.ok)
- #Delete in the openroadm-network
-# url = ("{}/config/ietf-network:networks/network/openroadm-network/node/ROADMA"
-# .format(self.restconf_baseurl))
-# data = {}
-# headers = {'content-type': 'application/json'}
-# response = requests.request(
-# "DELETE", url, data=json.dumps(data), headers=headers,
-# auth=('admin', 'admin'))
-# self.assertEqual(response.status_code, requests.codes.ok)
-# time.sleep(5)
- #Connect the XPDRA
+# #Connect the XPDRA
def test_04_connect_xpdr(self):
- #Config XPDRA
- url = ("{}/config/network-topology:"
- "network-topology/topology/topology-netconf/node/XPDRA"
- .format(self.restconf_baseurl))
- data = {"node": [{
- "node-id": "XPDRA",
- "netconf-node-topology:username": "admin",
- "netconf-node-topology:password": "admin",
- "netconf-node-topology:host": "127.0.0.1",
- "netconf-node-topology:port": "17830",
- "netconf-node-topology:tcp-only": "false",
- "netconf-node-topology:pass-through": {}}]}
- headers = {'content-type': 'application/json'}
- response = requests.request(
- "PUT", url, data=json.dumps(data), headers=headers,
- auth=('admin', 'admin'))
- self.assertEqual(response.status_code, requests.codes.created)
- #seems sometimes to return 200 instead of 201
- #self.assertEqual(response.status_code, requests.codes.ok)
- time.sleep(15)
+ # Config XPDRA
+ url = ("{}/config/network-topology:"
+ "network-topology/topology/topology-netconf/node/XPDRA01"
+ .format(self.restconf_baseurl))
+ data = {"node": [{
+ "node-id": "XPDRA01",
+ "netconf-node-topology:username": "admin",
+ "netconf-node-topology:password": "admin",
+ "netconf-node-topology:host": "127.0.0.1",
+ "netconf-node-topology:port": "17830",
+ "netconf-node-topology:tcp-only": "false",
+ "netconf-node-topology:pass-through": {}}]}
+ headers = {'content-type': 'application/json'}
+ response = requests.request(
+ "PUT", url, data=json.dumps(data), headers=headers,
+ auth=('admin', 'admin'))
+ self.assertEqual(response.status_code, requests.codes.created)
+ time.sleep(20)
- #Verify the termination points related to XPDR
- @unittest.expectedFailure
- def test_05_compareOpenroadmTopologyPortMapping(self):
- nbXPDR=1
- for p in(1,nbXPDR+1):
- if(p > nbXPDR):
- break;
- url_topo = "{}/config/ietf-network:networks/network/openroadm-topology/node/XPDRA-XPDR"+`p`
- with open('./transportpce_tests/log/topoPortMap.log', 'a') as outfile1:
- outfile1.write('Config: '+`p`+' : '+url_topo+'\n')
- url = (url_topo.format(self.restconf_baseurl))
- headers = {'content-type': 'application/json'}
- response_topo = requests.request(
- "GET", url, headers=headers, auth=('admin', 'admin'))
- self.assertEqual(response_topo.status_code, requests.codes.ok)
- res_topo = response_topo.json()
- nbTP=len(res_topo['node'][0]['ietf-network-topology:termination-point'])
- for i in range(0,nbTP):
- tp_id=res_topo['node'][0]['ietf-network-topology:termination-point'][i]['tp-id']
- url_map = "{}/config/transportpce-portmapping:network/nodes/XPDRA/mapping/"+tp_id
- with open('./transportpce_tests/log/topoPortMap.log', 'a') as outfile1:
- outfile1.write('Config: '+`i`+'/'+ `nbTP`+' : '+url_map+'\n')
- url = url_map.format(self.restconf_baseurl)
- headers = {'content-type': 'application/json'}
- response_portMap = requests.request(
- "GET", url, headers=headers, auth=('admin', 'admin'))
- self.assertEqual(response_portMap.status_code, requests.codes.ok)
- if("CLIENT" in tp_id):
- #Verify the tail equipment id of the client
- xpdr_client=res_topo['node'][0]['ietf-network-topology:termination-point'][i]["org-openroadm-network-topology:xpdr-client-attributes"]["tail-equipment-id"]
- url_map = "{}/config/transportpce-portmapping:network/nodes/XPDRA/mapping/"+xpdr_client
- with open('./transportpce_tests/log/topoPortMap.log', 'a') as outfile1:
- outfile1.write('Config: '+`i`+'/'+ `nbTP`+' : '+xpdr_client+'\n')
- url = url_map.format(self.restconf_baseurl)
- headers = {'content-type': 'application/json'}
- response_xpdrClient = requests.request(
- "GET", url, headers=headers, auth=('admin', 'admin'))
- self.assertEqual(response_xpdrClient.status_code, requests.codes.ok)
- if("NETWORK" in tp_id):
- #Verify the tail equipment id of the network
- xpdr_network=res_topo['node'][0]['ietf-network-topology:termination-point'][i]["org-openroadm-network-topology:xpdr-network-attributes"]["tail-equipment-id"]
- url_map = "{}/config/transportpce-portmapping:network/nodes/XPDRA/mapping/"+xpdr_network
- with open('./transportpce_tests/log/topoPortMap.log', 'a') as outfile1:
- outfile1.write('Config: '+`i`+'/'+ `nbTP`+' : '+xpdr_network+'\n')
- url = url_map.format(self.restconf_baseurl)
- headers = {'content-type': 'application/json'}
- response_xpdrNetwork = requests.request(
- "GET", url, headers=headers, auth=('admin', 'admin'))
- self.assertEqual(response_xpdrNetwork.status_code, requests.codes.ok)
+# #Verify the termination points related to XPDR
+ def test_05_compareOpenroadmTopologyPortMapping_xpdr(self):
+ self.test_02_compareOpenroadmTopologyPortMapping_rdm()
- #Disconnect the XPDRA
+ # Disconnect the XPDRA
def test_06_disconnect_device(self):
url = ("{}/config/network-topology:"
- "network-topology/topology/topology-netconf/node/XPDRA"
- .format(self.restconf_baseurl))
+ "network-topology/topology/topology-netconf/node/XPDRA01"
+ .format(self.restconf_baseurl))
data = {}
headers = {'content-type': 'application/json'}
response = requests.request(
"DELETE", url, data=json.dumps(data), headers=headers,
auth=('admin', 'admin'))
self.assertEqual(response.status_code, requests.codes.ok)
- #Delete in the openroadm-network
-# url = ("{}/config/ietf-network:networks/network/openroadm-network/node/XPDRA"
-# .format(self.restconf_baseurl))
-# data = {}
-# headers = {'content-type': 'application/json'}
-# response = requests.request(
-# "DELETE", url, data=json.dumps(data), headers=headers,
-# auth=('admin', 'admin'))
-# self.assertEqual(response.status_code, requests.codes.ok)
if __name__ == "__main__":
- #logging.basicConfig(filename='./transportpce_tests/log/response.log',filemode='w',level=logging.DEBUG)
+ # logging.basicConfig(filename='./transportpce_tests/log/response.log',filemode='w',level=logging.DEBUG)
#logging.debug('I am there')
unittest.main(verbosity=2)