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 # pylint: disable=too-few-public-methods
30 # pylint: disable=invalid-name
36 class TransportPCEtesting(unittest.TestCase):
39 WAITING = 20 # nominal value is 300
40 NODE_VERSION = '2.2.1'
41 uuid_services = UuidServices()
43 cr_serv_sample_data = {
47 "layer-protocol-name": "PHOTONIC_MEDIA",
48 "service-interface-point": {
49 "service-interface-point-uuid": "b1a0d883-32b8-3b0b-93d6-7ed074f6f107"
51 "administrative-state": "UNLOCKED",
52 "operational-state": "ENABLED",
53 "direction": "BIDIRECTIONAL",
55 "protection-role": "WORK",
56 "local-id": "SPDR-SA1-XPDR1",
59 "value-name": "OpenROADM node id",
60 "value": "SPDR-SA1-XPDR1"
65 "layer-protocol-name": "PHOTONIC_MEDIA",
66 "service-interface-point": {
67 "service-interface-point-uuid": "d1d6305e-179b-346f-b02d-8260aebe1ce8"
69 "administrative-state": "UNLOCKED",
70 "operational-state": "ENABLED",
71 "direction": "BIDIRECTIONAL",
73 "protection-role": "WORK",
74 "local-id": "SPDR-SC1-XPDR1",
77 "value-name": "OpenROADM node id",
78 "value": "SPDR-SC1-XPDR1"
83 "connectivity-constraint": {
84 "service-layer": "PHOTONIC_MEDIA",
85 "service-type": "POINT_TO_POINT_CONNECTIVITY",
86 "service-level": "Some service-level",
87 "requested-capacity": {
94 "state": "Some state"}}
98 # pylint: disable=unsubscriptable-object
99 cls.init_failed = False
100 os.environ['JAVA_MIN_MEM'] = '1024M'
101 os.environ['JAVA_MAX_MEM'] = '4096M'
102 cls.processes = test_utils.start_tpce()
103 # TAPI feature is not installed by default in Karaf
104 if "USE_LIGHTY" not in os.environ or os.environ['USE_LIGHTY'] != 'True':
105 print("installing tapi feature...")
106 result = test_utils.install_karaf_feature("odl-transportpce-tapi")
107 if result.returncode != 0:
108 cls.init_failed = True
109 print("Restarting OpenDaylight...")
110 test_utils.shutdown_process(cls.processes[0])
111 cls.processes[0] = test_utils.start_karaf()
112 test_utils.process_list[0] = cls.processes[0]
113 cls.init_failed = not test_utils.wait_until_log_contains(
114 test_utils.KARAF_LOG, test_utils.KARAF_OK_START_MSG, time_to_wait=60)
116 print("tapi installation feature failed...")
117 test_utils.shutdown_process(cls.processes[0])
119 cls.processes = test_utils.start_sims([('spdra', cls.NODE_VERSION),
120 ('roadma', cls.NODE_VERSION),
121 ('roadmc', cls.NODE_VERSION),
122 ('spdrc', cls.NODE_VERSION)])
125 def tearDownClass(cls):
126 # pylint: disable=not-an-iterable
127 for process in cls.processes:
128 test_utils.shutdown_process(process)
129 print("all processes killed")
134 def test_01_connect_spdrA(self):
135 print("Connecting SPDRA")
136 response = test_utils.mount_tapi_device("SPDR-SA1", ('spdra', self.NODE_VERSION))
137 self.assertEqual(response.status_code,
138 requests.codes.created, test_utils.CODE_SHOULD_BE_201)
140 def test_02_connect_spdrC(self):
141 print("Connecting SPDRC")
142 response = test_utils.mount_tapi_device("SPDR-SC1", ('spdrc', self.NODE_VERSION))
143 self.assertEqual(response.status_code,
144 requests.codes.created, test_utils.CODE_SHOULD_BE_201)
146 def test_03_connect_rdmA(self):
147 print("Connecting ROADMA")
148 response = test_utils.mount_tapi_device("ROADM-A1", ('roadma', self.NODE_VERSION))
149 self.assertEqual(response.status_code,
150 requests.codes.created, test_utils.CODE_SHOULD_BE_201)
153 def test_04_connect_rdmC(self):
154 print("Connecting ROADMC")
155 response = test_utils.mount_tapi_device("ROADM-C1", ('roadmc', self.NODE_VERSION))
156 self.assertEqual(response.status_code,
157 requests.codes.created, test_utils.CODE_SHOULD_BE_201)
159 def test_05_connect_sprdA_1_N1_to_roadmA_PP1(self):
160 response = test_utils.connect_xpdr_to_rdm_request("SPDR-SA1", "1", "1",
161 "ROADM-A1", "1", "SRG1-PP1-TXRX")
162 self.assertEqual(response.status_code, requests.codes.ok)
163 res = response.json()
164 self.assertIn('Xponder Roadm Link created successfully',
165 res["output"]["result"])
168 def test_06_connect_roadmA_PP1_to_spdrA_1_N1(self):
169 response = test_utils.connect_rdm_to_xpdr_request("SPDR-SA1", "1", "1",
170 "ROADM-A1", "1", "SRG1-PP1-TXRX")
171 self.assertEqual(response.status_code, requests.codes.ok)
172 res = response.json()
173 self.assertIn('Roadm Xponder links created successfully',
174 res["output"]["result"])
177 def test_07_connect_roadmA_PP1_to_spdrA_1_N1_tapi(self):
178 response = test_utils.connect_xpdr_to_rdm_tapi_request("SPDR-SA1-XPDR1", "XPDR1-NETWORK1",
179 "ROADM-A1", "SRG1-PP1-TXRX")
180 self.assertEqual(response.status_code, requests.codes.ok)
181 res = response.json()
182 self.assertIn('Link created in tapi topology',
183 res["output"]["result"])
186 def test_08_connect_sprdC_1_N1_to_roadmC_PP1(self):
187 response = test_utils.connect_xpdr_to_rdm_request("SPDR-SC1", "1", "1",
188 "ROADM-C1", "1", "SRG1-PP1-TXRX")
189 self.assertEqual(response.status_code, requests.codes.ok)
190 res = response.json()
191 self.assertIn('Xponder Roadm Link created successfully',
192 res["output"]["result"])
195 def test_09_connect_roadmC_PP1_to_spdrC_1_N1(self):
196 response = test_utils.connect_rdm_to_xpdr_request("SPDR-SC1", "1", "1",
197 "ROADM-C1", "1", "SRG1-PP1-TXRX")
198 self.assertEqual(response.status_code, requests.codes.ok)
199 res = response.json()
200 self.assertIn('Roadm Xponder links created successfully',
201 res["output"]["result"])
204 def test_10_connect_roadmC_PP1_to_spdrC_1_N1_tapi(self):
205 response = test_utils.connect_xpdr_to_rdm_tapi_request("SPDR-SC1-XPDR1", "XPDR1-NETWORK1",
206 "ROADM-C1", "SRG1-PP1-TXRX")
207 self.assertEqual(response.status_code, requests.codes.ok)
208 res = response.json()
209 self.assertIn('Link created in tapi topology',
210 res["output"]["result"])
213 def test_11_add_omsAttributes_ROADMA_ROADMC(self):
214 # Config ROADMA-ROADMC oms-attributes
216 "auto-spanloss": "true",
217 "spanloss-base": 11.4,
218 "spanloss-current": 12,
219 "engineered-spanloss": 12.2,
220 "link-concatenation": [{
223 "SRLG-length": 100000,
225 response = test_utils.add_oms_attr_request(
226 "ROADM-A1-DEG2-DEG2-TTP-TXRXtoROADM-C1-DEG1-DEG1-TTP-TXRX", data)
227 self.assertEqual(response.status_code, requests.codes.created)
230 def test_12_add_omsAttributes_ROADMC_ROADMA(self):
231 # Config ROADMC-ROADMA oms-attributes
233 "auto-spanloss": "true",
234 "spanloss-base": 11.4,
235 "spanloss-current": 12,
236 "engineered-spanloss": 12.2,
237 "link-concatenation": [{
240 "SRLG-length": 100000,
242 response = test_utils.add_oms_attr_request(
243 "ROADM-C1-DEG1-DEG1-TTP-TXRXtoROADM-A1-DEG2-DEG2-TTP-TXRX", data)
244 self.assertEqual(response.status_code, requests.codes.created)
247 def test_13_check_otn_topology(self):
248 response = test_utils.get_otn_topo_request()
249 self.assertEqual(response.status_code, requests.codes.ok)
250 res = response.json()
251 nbNode = len(res['network'][0]['node'])
252 self.assertEqual(nbNode, 6, 'There should be 6 otn nodes')
253 self.assertNotIn('ietf-network-topology:link', res['network'][0])
256 def test_14_check_openroadm_topology(self):
257 response = test_utils.get_ordm_topo_request("")
258 self.assertEqual(response.status_code, requests.codes.ok)
259 res = response.json()
260 nbNode = len(res['network'][0]['node'])
261 nbLink = len(res['network'][0]['ietf-network-topology:link'])
262 self.assertEqual(nbNode, 13, 'There should be 13 openroadm nodes')
263 self.assertEqual(nbLink, 22, 'There should be 22 openroadm links')
266 def test_15_get_tapi_topology_details(self):
267 response = test_utils.tapi_get_topology_details_request(
268 "T0 - Full Multi-layer topology")
270 self.assertEqual(response.status_code, requests.codes.ok)
271 res = response.json()
272 nbNode = len(res['output']['topology']['node'])
273 nbLink = len(res['output']['topology']['link'])
274 self.assertEqual(nbNode, 14, 'There should be 14 TAPI nodes')
275 self.assertEqual(nbLink, 15, 'There should be 15 TAPI links')
278 def test_16_check_sip_details(self):
279 response = test_utils.tapi_get_sip_details_request()
280 self.assertEqual(response.status_code, requests.codes.ok)
281 res = response.json()
282 nbSip = len(res['output']['sip'])
283 self.assertEqual(nbSip, 60, 'There should be 60 service interface point')
286 # test create connectivity service from spdrA to spdrC for Photonic_media
287 def test_17_create_connectivity_service_PhotonicMedia(self):
288 response = test_utils.tapi_create_connectivity_request(self.cr_serv_sample_data)
289 time.sleep(self.WAITING)
290 self.assertEqual(response.status_code, requests.codes.ok)
291 res = response.json()
292 self.uuid_services.pm = res['output']['service']['uuid']
293 # pylint: disable=consider-using-f-string
294 print("photonic media service uuid : {}".format(self.uuid_services.pm))
296 input_dict_1 = {'administrative-state': 'LOCKED',
297 'lifecycle-state': 'PLANNED',
298 'operational-state': 'DISABLED',
299 'service-type': 'POINT_TO_POINT_CONNECTIVITY',
300 'service-layer': 'PHOTONIC_MEDIA',
301 'connectivity-direction': 'BIDIRECTIONAL'
303 input_dict_2 = {'value-name': 'OpenROADM node id',
304 'value': 'SPDR-SC1-XPDR1'}
305 input_dict_3 = {'value-name': 'OpenROADM node id',
306 'value': 'SPDR-SA1-XPDR1'}
308 self.assertDictEqual(dict(input_dict_1, **res['output']['service']),
309 res['output']['service'])
310 self.assertDictEqual(dict(input_dict_2, **res['output']['service']['end-point'][0]['name'][0]),
311 res['output']['service']['end-point'][0]['name'][0])
312 self.assertDictEqual(dict(input_dict_3, **res['output']['service']['end-point'][1]['name'][0]),
313 res['output']['service']['end-point'][1]['name'][0])
314 # If the gate fails is because of the waiting time not being enough
315 time.sleep(self.WAITING)
317 def test_18_get_service_PhotonicMedia(self):
318 response = test_utils.get_service_list_request(
319 "services/" + str(self.uuid_services.pm))
320 self.assertEqual(response.status_code, requests.codes.ok)
321 res = response.json()
323 res['services'][0]['administrative-state'], 'inService')
325 res['services'][0]['service-name'], self.uuid_services.pm)
327 res['services'][0]['connection-type'], 'infrastructure')
329 res['services'][0]['lifecycle-state'], 'planned')
332 # test create connectivity service from spdrA to spdrC for odu
333 def test_19_create_connectivity_service_ODU(self):
334 # pylint: disable=line-too-long
335 self.cr_serv_sample_data["input"]["end-point"][0]["layer-protocol-name"] = "ODU"
336 self.cr_serv_sample_data["input"]["end-point"][0]["service-interface-point"]["service-interface-point-uuid"] = "eecbfa6e-57ab-3651-9606-c22c8ce73f18"
337 self.cr_serv_sample_data["input"]["end-point"][1]["layer-protocol-name"] = "ODU"
338 self.cr_serv_sample_data["input"]["end-point"][1]["service-interface-point"]["service-interface-point-uuid"] = "31f83b1f-29b2-3a8e-af9b-6423dbc5aa22"
339 self.cr_serv_sample_data["input"]["connectivity-constraint"]["service-layer"] = "ODU"
341 response = test_utils.tapi_create_connectivity_request(self.cr_serv_sample_data)
342 time.sleep(self.WAITING)
343 self.assertEqual(response.status_code, requests.codes.ok)
344 res = response.json()
345 self.uuid_services.odu = res['output']['service']['uuid']
346 # pylint: disable=consider-using-f-string
347 print("odu service uuid : {}".format(self.uuid_services.odu))
349 input_dict_1 = {'administrative-state': 'LOCKED',
350 'lifecycle-state': 'PLANNED',
351 'operational-state': 'DISABLED',
352 'service-type': 'POINT_TO_POINT_CONNECTIVITY',
353 'service-layer': 'ODU',
354 'connectivity-direction': 'BIDIRECTIONAL'
356 input_dict_2 = {'value-name': 'OpenROADM node id',
357 'value': 'SPDR-SC1-XPDR1'}
358 input_dict_3 = {'value-name': 'OpenROADM node id',
359 'value': 'SPDR-SA1-XPDR1'}
361 self.assertDictEqual(dict(input_dict_1, **res['output']['service']),
362 res['output']['service'])
363 self.assertDictEqual(dict(input_dict_2, **res['output']['service']['end-point'][0]['name'][0]),
364 res['output']['service']['end-point'][0]['name'][0])
365 self.assertDictEqual(dict(input_dict_3, **res['output']['service']['end-point'][1]['name'][0]),
366 res['output']['service']['end-point'][1]['name'][0])
367 # If the gate fails is because of the waiting time not being enough
368 time.sleep(self.WAITING)
370 def test_20_get_service_ODU(self):
371 response = test_utils.get_service_list_request(
372 "services/" + str(self.uuid_services.odu))
373 self.assertEqual(response.status_code, requests.codes.ok)
374 res = response.json()
376 res['services'][0]['administrative-state'], 'inService')
378 res['services'][0]['service-name'], self.uuid_services.odu)
380 res['services'][0]['connection-type'], 'infrastructure')
382 res['services'][0]['lifecycle-state'], 'planned')
385 # test create connectivity service from spdrA to spdrC for dsr
386 def test_21_create_connectivity_service_DSR(self):
387 # pylint: disable=line-too-long
388 self.cr_serv_sample_data["input"]["end-point"][0]["layer-protocol-name"] = "DSR"
389 self.cr_serv_sample_data["input"]["end-point"][0]["service-interface-point"]["service-interface-point-uuid"] = "c14797a0-adcc-3875-a1fe-df8949d1a2d7"
390 self.cr_serv_sample_data["input"]["end-point"][1]["layer-protocol-name"] = "DSR"
391 self.cr_serv_sample_data["input"]["end-point"][1]["service-interface-point"]["service-interface-point-uuid"] = "25812ef2-625d-3bf8-af55-5e93946d1c22"
392 self.cr_serv_sample_data["input"]["connectivity-constraint"]["service-layer"] = "DSR"
393 self.cr_serv_sample_data["input"]["connectivity-constraint"]["requested-capacity"]["total-size"]["value"] = "10"
395 response = test_utils.tapi_create_connectivity_request(self.cr_serv_sample_data)
396 time.sleep(self.WAITING)
397 self.assertEqual(response.status_code, requests.codes.ok)
398 res = response.json()
399 self.uuid_services.dsr = res['output']['service']['uuid']
400 # pylint: disable=consider-using-f-string
401 print("dsr service uuid : {}".format(self.uuid_services.dsr))
403 input_dict_1 = {'administrative-state': 'LOCKED',
404 'lifecycle-state': 'PLANNED',
405 'operational-state': 'DISABLED',
406 'service-type': 'POINT_TO_POINT_CONNECTIVITY',
407 'service-layer': 'DSR',
408 'connectivity-direction': 'BIDIRECTIONAL'
410 input_dict_2 = {'value-name': 'OpenROADM node id',
411 'value': 'SPDR-SC1-XPDR1'}
412 input_dict_3 = {'value-name': 'OpenROADM node id',
413 'value': 'SPDR-SA1-XPDR1'}
415 self.assertDictEqual(dict(input_dict_1,
416 **res['output']['service']),
417 res['output']['service'])
418 self.assertDictEqual(dict(input_dict_2,
419 **res['output']['service']['end-point'][0]['name'][0]),
420 res['output']['service']['end-point'][0]['name'][0])
421 self.assertDictEqual(dict(input_dict_3,
422 **res['output']['service']['end-point'][1]['name'][0]),
423 res['output']['service']['end-point'][1]['name'][0])
424 # The sleep here is okey as the DSR service creation is very fast
425 time.sleep(self.WAITING)
427 def test_22_get_service_DSR(self):
428 response = test_utils.get_service_list_request(
429 "services/" + str(self.uuid_services.dsr))
430 self.assertEqual(response.status_code, requests.codes.ok)
431 res = response.json()
433 res['services'][0]['administrative-state'], 'inService')
435 res['services'][0]['service-name'], self.uuid_services.dsr)
437 res['services'][0]['connection-type'], 'service')
439 res['services'][0]['lifecycle-state'], 'planned')
442 def test_23_get_connectivity_service_list(self):
443 response = test_utils.tapi_get_service_list_request()
444 self.assertEqual(response.status_code, requests.codes.ok)
445 res = response.json()
446 liste_service = res['output']['service']
447 for ele in liste_service:
448 if ele['uuid'] == self.uuid_services.pm:
449 self.assertEqual(ele['operational-state'], 'ENABLED')
450 self.assertEqual(ele['service-layer'], 'PHOTONIC_MEDIA')
451 nbconnection = len(ele['connection'])
452 self.assertEqual(nbconnection, 9, 'There should be 9 connections')
453 elif ele['uuid'] == self.uuid_services.odu:
454 self.assertEqual(ele['operational-state'], 'ENABLED')
455 self.assertEqual(ele['service-layer'], 'ODU')
456 nbconnection = len(ele['connection'])
457 self.assertEqual(nbconnection, 3, 'There should be 3 connections')
458 elif ele['uuid'] == self.uuid_services.dsr:
459 self.assertEqual(ele['operational-state'], 'ENABLED')
460 self.assertEqual(ele['service-layer'], 'DSR')
461 nbconnection = len(ele['connection'])
462 self.assertEqual(nbconnection, 1, 'There should be 1 connection')
464 self.fail("get connectivity service failed")
467 def test_24_delete_connectivity_service_DSR(self):
468 response = test_utils.tapi_delete_connectivity_request(self.uuid_services.dsr)
469 self.assertEqual(response.status_code, requests.codes.no_content)
470 time.sleep(self.WAITING)
472 def test_25_delete_connectivity_service_ODU(self):
473 response = test_utils.tapi_delete_connectivity_request(self.uuid_services.odu)
474 self.assertEqual(response.status_code, requests.codes.no_content)
475 time.sleep(self.WAITING)
477 def test_26_delete_connectivity_service_PhotonicMedia(self):
478 response = test_utils.tapi_delete_connectivity_request(self.uuid_services.pm)
479 self.assertEqual(response.status_code, requests.codes.no_content)
480 time.sleep(self.WAITING)
482 def test_27_get_no_tapi_services(self):
483 response = test_utils.tapi_get_service_list_request()
484 res = response.json()
486 {"error-type": "rpc", "error-tag": "operation-failed",
487 "error-message": "No services exist in datastore",
488 "error-info": "<severity>error</severity>"},
489 res['errors']['error'])
492 def test_28_get_no_openroadm_services(self):
493 response = test_utils.get_service_list_request("")
494 self.assertEqual(response.status_code, requests.codes.conflict)
495 res = response.json()
497 {"error-type": "application", "error-tag": "data-missing",
498 "error-message": "Request could not be completed because the relevant data model content does not exist"},
499 res['errors']['error'])
502 def test_29_disconnect_spdrA(self):
503 response = test_utils.unmount_device("SPDR-SA1")
504 self.assertEqual(response.status_code, requests.codes.ok,
505 test_utils.CODE_SHOULD_BE_200)
507 def test_30_disconnect_spdrC(self):
508 response = test_utils.unmount_device("SPDR-SC1")
509 self.assertEqual(response.status_code, requests.codes.ok,
510 test_utils.CODE_SHOULD_BE_200)
512 def test_31_disconnect_roadmA(self):
513 response = test_utils.unmount_device("ROADM-A1")
514 self.assertEqual(response.status_code, requests.codes.ok,
515 test_utils.CODE_SHOULD_BE_200)
517 def test_32_disconnect_roadmC(self):
518 response = test_utils.unmount_device("ROADM-C1")
519 self.assertEqual(response.status_code, requests.codes.ok,
520 test_utils.CODE_SHOULD_BE_200)
523 if __name__ == "__main__":
524 unittest.main(verbosity=2)