3 ##############################################################################
4 # Copyright (c) 2021 Orange, Inc. and others. All rights reserved.
6 # All rights reserved. This program and the accompanying materials
7 # are made available under the terms of the Apache License, Version 2.0
8 # which accompanies this distribution, and is available at
9 # http://www.apache.org/licenses/LICENSE-2.0
10 ##############################################################################
12 # pylint: disable=no-member
13 # pylint: disable=too-many-public-methods
19 # pylint: disable=wrong-import-order
21 sys.path.append('transportpce_tests/common/')
22 # pylint: disable=wrong-import-position
23 # pylint: disable=import-error
24 import test_utils # nopep8
27 class TransportPCEtesting(unittest.TestCase):
30 WAITING = 20 # nominal value is 300
31 NODE_VERSION = '2.2.1'
33 cr_serv_sample_data = {
37 "layer-protocol-name": "PHOTONIC_MEDIA",
38 "service-interface-point": {
39 "service-interface-point-uuid": "b1a0d883-32b8-3b0b-93d6-7ed074f6f107"
41 "administrative-state": "UNLOCKED",
42 "operational-state": "ENABLED",
43 "direction": "BIDIRECTIONAL",
45 "protection-role": "WORK",
46 "local-id": "SPDR-SA1-XPDR1",
49 "value-name": "OpenROADM node id",
50 "value": "SPDR-SA1-XPDR1"
55 "layer-protocol-name": "PHOTONIC_MEDIA",
56 "service-interface-point": {
57 "service-interface-point-uuid": "d1d6305e-179b-346f-b02d-8260aebe1ce8"
59 "administrative-state": "UNLOCKED",
60 "operational-state": "ENABLED",
61 "direction": "BIDIRECTIONAL",
63 "protection-role": "WORK",
64 "local-id": "SPDR-SC1-XPDR1",
67 "value-name": "OpenROADM node id",
68 "value": "SPDR-SC1-XPDR1"
73 "connectivity-constraint": {
74 "service-layer": "PHOTONIC_MEDIA",
75 "service-type": "POINT_TO_POINT_CONNECTIVITY",
76 "service-level": "Some service-level",
77 "requested-capacity": {
84 "state": "Some state"}}
88 cls.init_failed = False
89 os.environ['JAVA_MIN_MEM'] = '1024M'
90 os.environ['JAVA_MAX_MEM'] = '4096M'
91 cls.processes = test_utils.start_tpce()
92 # TAPI feature is not installed by default in Karaf
93 if "USE_LIGHTY" not in os.environ or os.environ['USE_LIGHTY'] != 'True':
94 print("installing tapi feature...")
95 result = test_utils.install_karaf_feature("odl-transportpce-tapi")
96 if result.returncode != 0:
97 cls.init_failed = True
98 print("Restarting OpenDaylight...")
99 test_utils.shutdown_process(cls.processes[0])
100 cls.processes[0] = test_utils.start_karaf()
101 test_utils.process_list[0] = cls.processes[0]
102 cls.init_failed = not test_utils.wait_until_log_contains(
103 test_utils.KARAF_LOG, test_utils.KARAF_OK_START_MSG, time_to_wait=60)
105 print("tapi installation feature failed...")
106 test_utils.shutdown_process(cls.processes[0])
108 cls.processes = test_utils.start_sims([('spdra', cls.NODE_VERSION),
109 ('roadma', cls.NODE_VERSION),
110 ('roadmc', cls.NODE_VERSION),
111 ('spdrc', cls.NODE_VERSION)])
114 def tearDownClass(cls):
115 # pylint: disable=not-an-iterable
116 for process in cls.processes:
117 test_utils.shutdown_process(process)
118 print("all processes killed")
123 def test_01_connect_spdrA(self):
124 response = test_utils.mount_device("SPDR-SA1", ('spdra', self.NODE_VERSION))
125 self.assertEqual(response.status_code,
126 requests.codes.created, test_utils.CODE_SHOULD_BE_201)
128 def test_02_connect_spdrC(self):
129 response = test_utils.mount_device("SPDR-SC1", ('spdrc', self.NODE_VERSION))
130 self.assertEqual(response.status_code,
131 requests.codes.created, test_utils.CODE_SHOULD_BE_201)
133 def test_03_connect_rdmA(self):
134 response = test_utils.mount_device("ROADM-A1", ('roadma', self.NODE_VERSION))
135 self.assertEqual(response.status_code,
136 requests.codes.created, test_utils.CODE_SHOULD_BE_201)
138 def test_04_connect_rdmC(self):
139 response = test_utils.mount_device("ROADM-C1", ('roadmc', self.NODE_VERSION))
140 self.assertEqual(response.status_code,
141 requests.codes.created, test_utils.CODE_SHOULD_BE_201)
143 def test_05_connect_sprdA_1_N1_to_roadmA_PP1(self):
144 response = test_utils.connect_xpdr_to_rdm_request("SPDR-SA1", "1", "1",
145 "ROADM-A1", "1", "SRG1-PP1-TXRX")
146 self.assertEqual(response.status_code, requests.codes.ok)
147 res = response.json()
148 self.assertIn('Xponder Roadm Link created successfully',
149 res["output"]["result"])
152 def test_06_connect_roadmA_PP1_to_spdrA_1_N1(self):
153 response = test_utils.connect_rdm_to_xpdr_request("SPDR-SA1", "1", "1",
154 "ROADM-A1", "1", "SRG1-PP1-TXRX")
155 self.assertEqual(response.status_code, requests.codes.ok)
156 res = response.json()
157 self.assertIn('Roadm Xponder links created successfully',
158 res["output"]["result"])
161 def test_07_connect_sprdC_1_N1_to_roadmC_PP1(self):
162 response = test_utils.connect_xpdr_to_rdm_request("SPDR-SC1", "1", "1",
163 "ROADM-C1", "1", "SRG1-PP1-TXRX")
164 self.assertEqual(response.status_code, requests.codes.ok)
165 res = response.json()
166 self.assertIn('Xponder Roadm Link created successfully',
167 res["output"]["result"])
170 def test_08_connect_roadmC_PP1_to_spdrC_1_N1(self):
171 response = test_utils.connect_rdm_to_xpdr_request("SPDR-SC1", "1", "1",
172 "ROADM-C1", "1", "SRG1-PP1-TXRX")
173 self.assertEqual(response.status_code, requests.codes.ok)
174 res = response.json()
175 self.assertIn('Roadm Xponder links created successfully',
176 res["output"]["result"])
179 def test_09_add_omsAttributes_ROADMA_ROADMC(self):
180 # Config ROADMA-ROADMC oms-attributes
182 "auto-spanloss": "true",
183 "spanloss-base": 11.4,
184 "spanloss-current": 12,
185 "engineered-spanloss": 12.2,
186 "link-concatenation": [{
189 "SRLG-length": 100000,
191 response = test_utils.add_oms_attr_request(
192 "ROADM-A1-DEG2-DEG2-TTP-TXRXtoROADM-C1-DEG1-DEG1-TTP-TXRX", data)
193 self.assertEqual(response.status_code, requests.codes.created)
196 def test_10_add_omsAttributes_ROADMC_ROADMA(self):
197 # Config ROADMC-ROADMA oms-attributes
199 "auto-spanloss": "true",
200 "spanloss-base": 11.4,
201 "spanloss-current": 12,
202 "engineered-spanloss": 12.2,
203 "link-concatenation": [{
206 "SRLG-length": 100000,
208 response = test_utils.add_oms_attr_request(
209 "ROADM-C1-DEG1-DEG1-TTP-TXRXtoROADM-A1-DEG2-DEG2-TTP-TXRX", data)
210 self.assertEqual(response.status_code, requests.codes.created)
213 def test_11_check_otn_topology(self):
214 response = test_utils.get_otn_topo_request()
215 self.assertEqual(response.status_code, requests.codes.ok)
216 res = response.json()
217 nbNode = len(res['network'][0]['node'])
218 self.assertEqual(nbNode, 6, 'There should be 6 otn nodes')
219 self.assertNotIn('ietf-network-topology:link', res['network'][0])
222 def test_12_check_openroadm_topology(self):
223 response = test_utils.get_ordm_topo_request("")
224 self.assertEqual(response.status_code, requests.codes.ok)
225 res = response.json()
226 nbNode = len(res['network'][0]['node'])
227 nbLink = len(res['network'][0]['ietf-network-topology:link'])
228 self.assertEqual(nbNode, 13, 'There should be 13 openroadm nodes')
229 self.assertEqual(nbLink, 22, 'There should be 22 openroadm links')
232 def test_13_get_tapi_topology_details(self):
233 response = test_utils.tapi_get_topology_details_request(
234 "T0 - Full Multi-layer topology")
236 self.assertEqual(response.status_code, requests.codes.ok)
237 res = response.json()
238 nbNode = len(res['output']['topology']['node'])
239 nbLink = len(res['output']['topology']['link'])
240 self.assertEqual(nbNode, 14, 'There should be 14 TAPI nodes')
241 self.assertEqual(nbLink, 13, 'There should be 13 TAPI links')
244 def test_14_check_sip_details(self):
245 response = test_utils.tapi_get_sip_details_request()
246 self.assertEqual(response.status_code, requests.codes.ok)
247 res = response.json()
248 nbSip = len(res['output']['sip'])
249 self.assertEqual(nbSip, 60, 'There should be 60 service interface point')
252 # test create connectivity service from spdrA to spdrC for Photonic_media
253 def test_15_create_connectivity_service_PhotonicMedia(self):
254 response = test_utils.tapi_create_connectivity_request(self.cr_serv_sample_data)
255 time.sleep(self.WAITING)
256 self.assertEqual(response.status_code, requests.codes.ok)
257 res = response.json()
258 global service_pm_uuid
259 service_pm_uuid = res['output']['service']['uuid']
260 print("photonic media service uuid : {}".format(res['output']['service']['uuid']))
262 input_dict_1 = {'administrative-state': 'LOCKED',
263 'lifecycle-state': 'PLANNED',
264 'operational-state': 'DISABLED',
265 'service-type': 'POINT_TO_POINT_CONNECTIVITY',
266 'service-layer': 'PHOTONIC_MEDIA',
267 'connectivity-direction': 'BIDIRECTIONAL'
269 input_dict_2 = {'value-name': 'OpenROADM node id',
270 'value': 'SPDR-SC1-XPDR1'}
271 input_dict_3 = {'value-name': 'OpenROADM node id',
272 'value': 'SPDR-SA1-XPDR1'}
274 self.assertDictEqual(dict(input_dict_1, **res['output']['service']),
275 res['output']['service'])
276 self.assertDictEqual(dict(input_dict_2, **res['output']['service']['end-point'][0]['name'][0]),
277 res['output']['service']['end-point'][0]['name'][0])
278 self.assertDictEqual(dict(input_dict_3, **res['output']['service']['end-point'][1]['name'][0]),
279 res['output']['service']['end-point'][1]['name'][0])
280 time.sleep(self.WAITING)
282 def test_16_get_service_PhotonicMedia(self):
283 response = test_utils.get_service_list_request(
284 "services/" + str(service_pm_uuid))
285 self.assertEqual(response.status_code, requests.codes.ok)
286 res = response.json()
288 res['services'][0]['administrative-state'], 'inService')
290 res['services'][0]['service-name'], service_pm_uuid)
292 res['services'][0]['connection-type'], 'infrastructure')
294 res['services'][0]['lifecycle-state'], 'planned')
297 # test create connectivity service from spdrA to spdrC for odu
298 def test_17_create_connectivity_service_ODU(self):
299 # pylint: disable=line-too-long
300 self.cr_serv_sample_data["input"]["end-point"][0]["layer-protocol-name"] = "ODU"
301 self.cr_serv_sample_data["input"]["end-point"][0]["service-interface-point"]["service-interface-point-uuid"] = "eecbfa6e-57ab-3651-9606-c22c8ce73f18"
302 self.cr_serv_sample_data["input"]["end-point"][1]["layer-protocol-name"] = "ODU"
303 self.cr_serv_sample_data["input"]["end-point"][1]["service-interface-point"]["service-interface-point-uuid"] = "31f83b1f-29b2-3a8e-af9b-6423dbc5aa22"
304 self.cr_serv_sample_data["input"]["connectivity-constraint"]["service-layer"] = "ODU"
306 response = test_utils.tapi_create_connectivity_request(self.cr_serv_sample_data)
307 time.sleep(self.WAITING)
308 self.assertEqual(response.status_code, requests.codes.ok)
309 res = response.json()
310 global service_odu_uuid
311 service_odu_uuid = res['output']['service']['uuid']
312 print("odu service uuid : {}".format(res['output']['service']['uuid']))
314 input_dict_1 = {'administrative-state': 'LOCKED',
315 'lifecycle-state': 'PLANNED',
316 'operational-state': 'DISABLED',
317 'service-type': 'POINT_TO_POINT_CONNECTIVITY',
318 'service-layer': 'ODU',
319 'connectivity-direction': 'BIDIRECTIONAL'
321 input_dict_2 = {'value-name': 'OpenROADM node id',
322 'value': 'SPDR-SC1-XPDR1'}
323 input_dict_3 = {'value-name': 'OpenROADM node id',
324 'value': 'SPDR-SA1-XPDR1'}
326 self.assertDictEqual(dict(input_dict_1, **res['output']['service']),
327 res['output']['service'])
328 self.assertDictEqual(dict(input_dict_2, **res['output']['service']['end-point'][0]['name'][0]),
329 res['output']['service']['end-point'][0]['name'][0])
330 self.assertDictEqual(dict(input_dict_3, **res['output']['service']['end-point'][1]['name'][0]),
331 res['output']['service']['end-point'][1]['name'][0])
332 time.sleep(self.WAITING)
334 def test_18_get_service_ODU(self):
335 response = test_utils.get_service_list_request(
336 "services/" + str(service_odu_uuid))
337 self.assertEqual(response.status_code, requests.codes.ok)
338 res = response.json()
340 res['services'][0]['administrative-state'], 'inService')
342 res['services'][0]['service-name'], service_odu_uuid)
344 res['services'][0]['connection-type'], 'infrastructure')
346 res['services'][0]['lifecycle-state'], 'planned')
349 # test create connectivity service from spdrA to spdrC for dsr
350 def test_19_create_connectivity_service_DSR(self):
351 # pylint: disable=line-too-long
352 self.cr_serv_sample_data["input"]["end-point"][0]["layer-protocol-name"] = "DSR"
353 self.cr_serv_sample_data["input"]["end-point"][0]["service-interface-point"]["service-interface-point-uuid"] = "c14797a0-adcc-3875-a1fe-df8949d1a2d7"
354 self.cr_serv_sample_data["input"]["end-point"][1]["layer-protocol-name"] = "DSR"
355 self.cr_serv_sample_data["input"]["end-point"][1]["service-interface-point"]["service-interface-point-uuid"] = "25812ef2-625d-3bf8-af55-5e93946d1c22"
356 self.cr_serv_sample_data["input"]["connectivity-constraint"]["service-layer"] = "DSR"
357 self.cr_serv_sample_data["input"]["connectivity-constraint"]["requested-capacity"]["total-size"]["value"] = "10"
359 response = test_utils.tapi_create_connectivity_request(self.cr_serv_sample_data)
360 time.sleep(self.WAITING)
361 self.assertEqual(response.status_code, requests.codes.ok)
362 res = response.json()
363 global service_dsr_uuid
364 service_dsr_uuid = res['output']['service']['uuid']
365 print("dsr service uuid : {}".format(res['output']['service']['uuid']))
367 input_dict_1 = {'administrative-state': 'LOCKED',
368 'lifecycle-state': 'PLANNED',
369 'operational-state': 'DISABLED',
370 'service-type': 'POINT_TO_POINT_CONNECTIVITY',
371 'service-layer': 'DSR',
372 'connectivity-direction': 'BIDIRECTIONAL'
374 input_dict_2 = {'value-name': 'OpenROADM node id',
375 'value': 'SPDR-SC1-XPDR1'}
376 input_dict_3 = {'value-name': 'OpenROADM node id',
377 'value': 'SPDR-SA1-XPDR1'}
379 self.assertDictEqual(dict(input_dict_1,
380 **res['output']['service']),
381 res['output']['service'])
382 self.assertDictEqual(dict(input_dict_2,
383 **res['output']['service']['end-point'][0]['name'][0]),
384 res['output']['service']['end-point'][0]['name'][0])
385 self.assertDictEqual(dict(input_dict_3,
386 **res['output']['service']['end-point'][1]['name'][0]),
387 res['output']['service']['end-point'][1]['name'][0])
388 time.sleep(self.WAITING)
390 def test_20_get_service_DSR(self):
391 response = test_utils.get_service_list_request(
392 "services/" + str(service_dsr_uuid))
393 self.assertEqual(response.status_code, requests.codes.ok)
394 res = response.json()
396 res['services'][0]['administrative-state'], 'inService')
398 res['services'][0]['service-name'], service_dsr_uuid)
400 res['services'][0]['connection-type'], 'service')
402 res['services'][0]['lifecycle-state'], 'planned')
405 def test_21_get_connectivity_service_list(self):
406 response = test_utils.tapi_get_service_list_request()
407 self.assertEqual(response.status_code, requests.codes.ok)
408 res = response.json()
409 liste_service = res['output']['service']
410 for ele in liste_service:
411 if ele['uuid'] == service_pm_uuid:
412 self.assertEqual(ele['operational-state'], 'ENABLED')
413 self.assertEqual(ele['service-layer'], 'PHOTONIC_MEDIA')
414 nbconnection = len(ele['connection'])
415 self.assertEqual(nbconnection, 9, 'There should be 9 connections')
416 elif ele['uuid'] == service_odu_uuid:
417 self.assertEqual(ele['operational-state'], 'ENABLED')
418 self.assertEqual(ele['service-layer'], 'ODU')
419 nbconnection = len(ele['connection'])
420 self.assertEqual(nbconnection, 3, 'There should be 3 connections')
421 elif ele['uuid'] == service_dsr_uuid:
422 self.assertEqual(ele['operational-state'], 'ENABLED')
423 self.assertEqual(ele['service-layer'], 'DSR')
424 nbconnection = len(ele['connection'])
425 self.assertEqual(nbconnection, 1, 'There should be 1 connection')
427 self.fail("get connectivity service failed")
430 def test_22_delete_connectivity_service_DSR(self):
431 response = test_utils.tapi_delete_connectivity_request(service_dsr_uuid)
432 self.assertEqual(response.status_code, requests.codes.no_content)
433 time.sleep(self.WAITING)
435 def test_23_delete_connectivity_service_ODU(self):
436 response = test_utils.tapi_delete_connectivity_request(service_odu_uuid)
437 self.assertEqual(response.status_code, requests.codes.no_content)
438 time.sleep(self.WAITING)
440 def test_24_delete_connectivity_service_PhotonicMedia(self):
441 response = test_utils.tapi_delete_connectivity_request(service_pm_uuid)
442 self.assertEqual(response.status_code, requests.codes.no_content)
443 time.sleep(self.WAITING)
445 def test_25_get_no_tapi_services(self):
446 response = test_utils.tapi_get_service_list_request()
447 res = response.json()
449 {"error-type": "rpc", "error-tag": "operation-failed",
450 "error-message": "No services exist in datastore",
451 "error-info": "<severity>error</severity>"},
452 res['errors']['error'])
455 def test_26_get_no_openroadm_services(self):
456 response = test_utils.get_service_list_request("")
457 self.assertEqual(response.status_code, requests.codes.conflict)
458 res = response.json()
460 {"error-type": "application", "error-tag": "data-missing",
461 "error-message": "Request could not be completed because the relevant data model content does not exist"},
462 res['errors']['error'])
465 def test_27_disconnect_spdrA(self):
466 response = test_utils.unmount_device("SPDR-SA1")
467 self.assertEqual(response.status_code, requests.codes.ok,
468 test_utils.CODE_SHOULD_BE_200)
470 def test_28_disconnect_spdrC(self):
471 response = test_utils.unmount_device("SPDR-SC1")
472 self.assertEqual(response.status_code, requests.codes.ok,
473 test_utils.CODE_SHOULD_BE_200)
475 def test_29_disconnect_roadmA(self):
476 response = test_utils.unmount_device("ROADM-A1")
477 self.assertEqual(response.status_code, requests.codes.ok,
478 test_utils.CODE_SHOULD_BE_200)
480 def test_30_disconnect_roadmC(self):
481 response = test_utils.unmount_device("ROADM-C1")
482 self.assertEqual(response.status_code, requests.codes.ok,
483 test_utils.CODE_SHOULD_BE_200)
486 if __name__ == "__main__":
487 unittest.main(verbosity=2)