3 #############################################################################
4 # Copyright (c) 2017 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 #############################################################################
16 from common import test_utils
19 class TransportOlmTesting(unittest.TestCase):
25 cls.processes = test_utils.start_tpce()
26 cls.processes = test_utils.start_sims(['xpdra', 'roadma', 'roadmc', 'xpdrc'])
29 def tearDownClass(cls):
30 for process in cls.processes:
31 test_utils.shutdown_process(process)
32 print("all processes killed")
35 print("execution of {}".format(self.id().split(".")[-1]))
38 def test_01_xpdrA_device_connected(self):
39 response = test_utils.mount_device("XPDR-A1", 'xpdra')
40 self.assertEqual(response.status_code, requests.codes.created, test_utils.CODE_SHOULD_BE_201)
42 def test_02_xpdrC_device_connected(self):
43 response = test_utils.mount_device("XPDR-C1", 'xpdrc')
44 self.assertEqual(response.status_code, requests.codes.created, test_utils.CODE_SHOULD_BE_201)
46 def test_03_rdmA_device_connected(self):
47 response = test_utils.mount_device("ROADM-A1", 'roadma')
48 self.assertEqual(response.status_code, requests.codes.created, test_utils.CODE_SHOULD_BE_201)
50 def test_04_rdmC_device_connected(self):
51 response = test_utils.mount_device("ROADM-C1", 'roadmc')
52 self.assertEqual(response.status_code, requests.codes.created, test_utils.CODE_SHOULD_BE_201)
54 def test_05_connect_xprdA_to_roadmA(self):
55 response = test_utils.connect_xpdr_to_rdm_request("XPDR-A1", "1", "1",
56 "ROADM-A1", "1", "SRG1-PP1-TXRX")
57 self.assertEqual(response.status_code, requests.codes.ok)
59 self.assertIn('Xponder Roadm Link created successfully', res["output"]["result"])
61 def test_06_connect_roadmA_to_xpdrA(self):
62 response = test_utils.connect_rdm_to_xpdr_request("XPDR-A1", "1", "1",
63 "ROADM-A1", "1", "SRG1-PP1-TXRX")
64 self.assertEqual(response.status_code, requests.codes.ok)
66 self.assertIn('Roadm Xponder links created successfully', res["output"]["result"])
68 def test_07_connect_xprdC_to_roadmC(self):
69 response = test_utils.connect_xpdr_to_rdm_request("XPDR-C1", "1", "1",
70 "ROADM-C1", "1", "SRG1-PP1-TXRX")
71 self.assertEqual(response.status_code, requests.codes.ok)
73 self.assertIn('Xponder Roadm Link created successfully', res["output"]["result"])
75 def test_08_connect_roadmC_to_xpdrC(self):
76 response = test_utils.connect_rdm_to_xpdr_request("XPDR-C1", "1", "1",
77 "ROADM-C1", "1", "SRG1-PP1-TXRX")
78 self.assertEqual(response.status_code, requests.codes.ok)
80 self.assertIn('Roadm Xponder links created successfully', res["output"]["result"])
82 def test_09_create_OTS_ROADMA(self):
83 url = "{}/operations/transportpce-device-renderer:create-ots-oms"
86 "node-id": "ROADM-A1",
87 "logical-connection-point": "DEG1-TTP-TXRX"
90 response = test_utils.post_request(url, data)
92 self.assertEqual(response.status_code, requests.codes.ok)
94 self.assertIn('Interfaces OTS-DEG1-TTP-TXRX - OMS-DEG1-TTP-TXRX successfully created on node ROADM-A1',
95 res["output"]["result"])
97 def test_10_create_OTS_ROADMC(self):
98 url = "{}/operations/transportpce-device-renderer:create-ots-oms"
101 "node-id": "ROADM-C1",
102 "logical-connection-point": "DEG2-TTP-TXRX"
105 response = test_utils.post_request(url, data)
106 self.assertEqual(response.status_code, requests.codes.ok)
107 res = response.json()
108 self.assertIn('Interfaces OTS-DEG2-TTP-TXRX - OMS-DEG2-TTP-TXRX successfully created on node ROADM-C1',
109 res["output"]["result"])
111 def test_11_get_PM_ROADMA(self):
112 url = "{}/operations/transportpce-olm:get-pm"
115 "node-id": "ROADM-A1",
116 "resource-type": "interface",
117 "granularity": "15min",
118 "resource-identifier": {
119 "resource-name": "OTS-DEG2-TTP-TXRX"
123 response = test_utils.post_request(url, data)
124 self.assertEqual(response.status_code, requests.codes.ok)
125 res = response.json()
127 "pmparameter-name": "OpticalPowerOutput",
128 "pmparameter-value": "2.5"
129 }, res["output"]["measurements"])
131 "pmparameter-name": "OpticalReturnLoss",
132 "pmparameter-value": "40"
133 }, res["output"]["measurements"])
135 "pmparameter-name": "OpticalPowerInput",
136 "pmparameter-value": "-21.1"
137 }, res["output"]["measurements"])
139 def test_12_get_PM_ROADMC(self):
140 url = "{}/operations/transportpce-olm:get-pm"
143 "node-id": "ROADM-C1",
144 "resource-type": "interface",
145 "granularity": "15min",
146 "resource-identifier": {
147 "resource-name": "OTS-DEG1-TTP-TXRX"
151 response = test_utils.post_request(url, data)
152 self.assertEqual(response.status_code, requests.codes.ok)
153 res = response.json()
155 "pmparameter-name": "OpticalPowerOutput",
156 "pmparameter-value": "4.6"
157 }, res["output"]["measurements"])
159 "pmparameter-name": "OpticalReturnLoss",
160 "pmparameter-value": "49.1"
161 }, res["output"]["measurements"])
163 "pmparameter-name": "OpticalPowerInput",
164 "pmparameter-value": "-15.1"
165 }, res["output"]["measurements"])
167 def test_13_calculate_span_loss_base_ROADMA_ROADMC(self):
168 url = "{}/operations/transportpce-olm:calculate-spanloss-base"
172 "link-id": "ROADM-A1-DEG2-DEG2-TTP-TXRXtoROADM-C1-DEG1-DEG1-TTP-TXRX"
175 response = test_utils.post_request(url, data)
176 self.assertEqual(response.status_code, requests.codes.ok)
177 res = response.json()
178 self.assertIn('Success',
179 res["output"]["result"])
182 "link-id": "ROADM-A1-DEG2-DEG2-TTP-TXRXtoROADM-C1-DEG1-DEG1-TTP-TXRX"
183 }, res["output"]["spans"])
186 def test_14_calculate_span_loss_base_all(self):
187 url = "{}/operations/transportpce-olm:calculate-spanloss-base"
193 response = test_utils.post_request(url, data)
194 self.assertEqual(response.status_code, requests.codes.ok)
195 res = response.json()
196 self.assertIn('Success',
197 res["output"]["result"])
200 "link-id": "ROADM-C1-DEG1-DEG1-TTP-TXRXtoROADM-A1-DEG2-DEG2-TTP-TXRX"
201 }, res["output"]["spans"])
204 "link-id": "ROADM-A1-DEG2-DEG2-TTP-TXRXtoROADM-C1-DEG1-DEG1-TTP-TXRX"
205 }, res["output"]["spans"])
208 def test_15_get_OTS_DEG2_TTP_TXRX_ROADMA(self):
209 response = test_utils.check_netconf_node_request(
211 "interface/OTS-DEG2-TTP-TXRX/org-openroadm-optical-transport-interfaces:ots")
212 self.assertEqual(response.status_code, requests.codes.ok)
213 res = response.json()
214 self.assertEqual(17.6, res['org-openroadm-optical-transport-interfaces:ots']['span-loss-transmit'])
215 self.assertEqual(25.7, res['org-openroadm-optical-transport-interfaces:ots']['span-loss-receive'])
217 def test_16_get_OTS_DEG1_TTP_TXRX_ROADMC(self):
218 response = test_utils.check_netconf_node_request(
220 "interface/OTS-DEG1-TTP-TXRX/org-openroadm-optical-transport-interfaces:ots")
221 self.assertEqual(response.status_code, requests.codes.ok)
222 res = response.json()
223 self.assertEqual(25.7, res['org-openroadm-optical-transport-interfaces:ots']['span-loss-transmit'])
224 self.assertEqual(17.6, res['org-openroadm-optical-transport-interfaces:ots']['span-loss-receive'])
226 def test_17_servicePath_create_AToZ(self):
227 url = "{}/operations/transportpce-device-renderer:service-path"
230 "service-name": "test",
232 "modulation-format": "qpsk",
233 "operation": "create",
236 "dest-tp": "XPDR1-NETWORK1",
237 "src-tp": "XPDR1-CLIENT1",
241 "dest-tp": "DEG2-TTP-TXRX",
242 "src-tp": "SRG1-PP1-TXRX",
243 "node-id": "ROADM-A1"
246 "dest-tp": "SRG1-PP1-TXRX",
247 "src-tp": "DEG1-TTP-TXRX",
248 "node-id": "ROADM-C1"
251 "dest-tp": "XPDR1-CLIENT1",
252 "src-tp": "XPDR1-NETWORK1",
258 response = test_utils.post_request(url, data)
259 self.assertEqual(response.status_code, requests.codes.ok)
260 res = response.json()
261 self.assertIn('Roadm-connection successfully created for nodes', res["output"]["result"])
265 def test_18_servicePath_create_ZToA(self):
266 url = "{}/operations/transportpce-device-renderer:service-path"
269 "service-name": "test",
271 "modulation-format": "qpsk",
272 "operation": "create",
275 "dest-tp": "XPDR1-NETWORK1",
276 "src-tp": "XPDR1-CLIENT1",
280 "dest-tp": "DEG1-TTP-TXRX",
281 "src-tp": "SRG1-PP1-TXRX",
282 "node-id": "ROADM-C1"
285 "src-tp": "DEG2-TTP-TXRX",
286 "dest-tp": "SRG1-PP1-TXRX",
287 "node-id": "ROADM-A1"
290 "src-tp": "XPDR1-NETWORK1",
291 "dest-tp": "XPDR1-CLIENT1",
297 response = test_utils.post_request(url, data)
298 self.assertEqual(response.status_code, requests.codes.ok)
299 res = response.json()
300 self.assertIn('Roadm-connection successfully created for nodes', res["output"]["result"])
304 def test_19_service_power_setup_XPDRA_XPDRC(self):
305 url = "{}/operations/transportpce-olm:service-power-setup"
308 "service-name": "test",
312 "dest-tp": "XPDR1-NETWORK1",
313 "src-tp": "XPDR1-CLIENT1",
317 "dest-tp": "DEG2-TTP-TXRX",
318 "src-tp": "SRG1-PP1-TXRX",
319 "node-id": "ROADM-A1"
322 "dest-tp": "SRG1-PP1-TXRX",
323 "src-tp": "DEG1-TTP-TXRX",
324 "node-id": "ROADM-C1"
327 "dest-tp": "XPDR1-CLIENT1",
328 "src-tp": "XPDR1-NETWORK1",
334 response = test_utils.post_request(url, data)
335 self.assertEqual(response.status_code, requests.codes.ok)
336 res = response.json()
337 self.assertIn('Success', res["output"]["result"])
339 def test_20_get_interface_XPDRA_XPDR1_NETWORK1(self):
340 response = test_utils.check_netconf_node_request(
342 "interface/XPDR1-NETWORK1-1/org-openroadm-optical-channel-interfaces:och")
343 self.assertEqual(response.status_code, requests.codes.ok)
344 res = response.json()
345 self.assertEqual(-5, res['org-openroadm-optical-channel-interfaces:och']['transmit-power'])
346 self.assertEqual(196.1, res['org-openroadm-optical-channel-interfaces:och']['frequency'])
348 def test_21_get_roadmconnection_ROADMA(self):
349 response = test_utils.check_netconf_node_request("ROADM-A1", "roadm-connections/SRG1-PP1-TXRX-DEG2-TTP-TXRX-1")
350 self.assertEqual(response.status_code, requests.codes.ok)
351 res = response.json()
352 self.assertEqual("gainLoss", res['roadm-connections'][0]['opticalControlMode'])
353 self.assertEqual(2.0, res['roadm-connections'][0]['target-output-power'])
355 def test_22_get_roadmconnection_ROADMC(self):
356 response = test_utils.check_netconf_node_request("ROADM-C1", "roadm-connections/DEG1-TTP-TXRX-SRG1-PP1-TXRX-1")
357 self.assertEqual(response.status_code, requests.codes.ok)
358 res = response.json()
359 self.assertEqual("power", res['roadm-connections'][0]['opticalControlMode'])
361 def test_23_service_power_setup_XPDRC_XPDRA(self):
362 url = "{}/operations/transportpce-olm:service-power-setup"
365 "service-name": "test",
369 "dest-tp": "XPDR1-NETWORK1",
370 "src-tp": "XPDR1-CLIENT1",
374 "dest-tp": "DEG1-TTP-TXRX",
375 "src-tp": "SRG1-PP1-TXRX",
376 "node-id": "ROADM-C1"
379 "src-tp": "DEG2-TTP-TXRX",
380 "dest-tp": "SRG1-PP1-TXRX",
381 "node-id": "ROADM-A1"
384 "src-tp": "XPDR1-NETWORK1",
385 "dest-tp": "XPDR1-CLIENT1",
391 response = test_utils.post_request(url, data)
392 self.assertEqual(response.status_code, requests.codes.ok)
393 res = response.json()
394 self.assertIn('Success', res["output"]["result"])
396 def test_24_get_interface_XPDRC_XPDR1_NETWORK1(self):
397 response = test_utils.check_netconf_node_request(
399 "interface/XPDR1-NETWORK1-1/org-openroadm-optical-channel-interfaces:och")
400 self.assertEqual(response.status_code, requests.codes.ok)
401 res = response.json()
402 self.assertEqual(-5, res['org-openroadm-optical-channel-interfaces:och']['transmit-power'])
403 self.assertEqual(196.1, res['org-openroadm-optical-channel-interfaces:och']['frequency'])
405 def test_25_get_roadmconnection_ROADMC(self):
406 response = test_utils.check_netconf_node_request("ROADM-C1", "roadm-connections/SRG1-PP1-TXRX-DEG1-TTP-TXRX-1")
407 self.assertEqual(response.status_code, requests.codes.ok)
408 res = response.json()
409 self.assertEqual("gainLoss", res['roadm-connections'][0]['opticalControlMode'])
410 self.assertEqual(2.0, res['roadm-connections'][0]['target-output-power'])
412 def test_26_service_power_turndown_XPDRA_XPDRC(self):
413 url = "{}/operations/transportpce-olm:service-power-turndown"
416 "service-name": "test",
420 "dest-tp": "XPDR1-NETWORK1",
421 "src-tp": "XPDR1-CLIENT1",
425 "dest-tp": "DEG2-TTP-TXRX",
426 "src-tp": "SRG1-PP1-TXRX",
427 "node-id": "ROADM-A1"
430 "dest-tp": "SRG1-PP1-TXRX",
431 "src-tp": "DEG1-TTP-TXRX",
432 "node-id": "ROADM-C1"
435 "dest-tp": "XPDR1-CLIENT1",
436 "src-tp": "XPDR1-NETWORK1",
442 response = test_utils.post_request(url, data)
443 self.assertEqual(response.status_code, requests.codes.ok)
444 res = response.json()
445 self.assertIn('Success', res["output"]["result"])
447 def test_27_get_roadmconnection_ROADMA(self):
448 response = test_utils.check_netconf_node_request("ROADM-A1", "roadm-connections/SRG1-PP1-TXRX-DEG2-TTP-TXRX-1")
449 self.assertEqual(response.status_code, requests.codes.ok)
450 res = response.json()
451 self.assertEqual("off", res['roadm-connections'][0]['opticalControlMode'])
452 self.assertEqual(-60, res['roadm-connections'][0]['target-output-power'])
454 def test_28_get_roadmconnection_ROADMC(self):
455 response = test_utils.check_netconf_node_request("ROADM-C1", "roadm-connections/DEG1-TTP-TXRX-SRG1-PP1-TXRX-1")
456 self.assertEqual(response.status_code, requests.codes.ok)
457 res = response.json()
458 self.assertEqual("off", res['roadm-connections'][0]['opticalControlMode'])
460 def test_29_servicePath_delete_AToZ(self):
461 url = "{}/operations/transportpce-device-renderer:service-path"
464 "service-name": "test",
466 "modulation-format": "qpsk",
467 "operation": "delete",
470 "dest-tp": "XPDR1-NETWORK1",
471 "src-tp": "XPDR1-CLIENT1",
475 "dest-tp": "DEG2-TTP-TXRX",
476 "src-tp": "SRG1-PP1-TXRX",
477 "node-id": "ROADM-A1"
480 "dest-tp": "SRG1-PP1-TXRX",
481 "src-tp": "DEG1-TTP-TXRX",
482 "node-id": "ROADM-C1"
485 "dest-tp": "XPDR1-CLIENT1",
486 "src-tp": "XPDR1-NETWORK1",
492 response = test_utils.post_request(url, data)
493 self.assertEqual(response.status_code, requests.codes.ok)
494 res = response.json()
495 self.assertIn('Request processed', res["output"]["result"])
498 def test_30_servicePath_delete_ZToA(self):
499 url = "{}/operations/transportpce-device-renderer:service-path"
502 "service-name": "test",
504 "modulation-format": "qpsk",
505 "operation": "delete",
508 "dest-tp": "XPDR1-NETWORK1",
509 "src-tp": "XPDR1-CLIENT1",
513 "dest-tp": "DEG1-TTP-TXRX",
514 "src-tp": "SRG1-PP1-TXRX",
515 "node-id": "ROADM-C1"
518 "src-tp": "DEG2-TTP-TXRX",
519 "dest-tp": "SRG1-PP1-TXRX",
520 "node-id": "ROADM-A1"
523 "src-tp": "XPDR1-NETWORK1",
524 "dest-tp": "XPDR1-CLIENT1",
530 response = test_utils.post_request(url, data)
531 self.assertEqual(response.status_code, requests.codes.ok)
532 res = response.json()
533 self.assertIn('Request processed', res["output"]["result"])
536 """to test case where SRG where the xpdr is connected to has no optical range data"""
538 def test_31_connect_xprdA_to_roadmA(self):
539 response = test_utils.connect_xpdr_to_rdm_request("XPDR-A1", "1", "2",
540 "ROADM-A1", "1", "SRG1-PP2-TXRX")
541 self.assertEqual(response.status_code, requests.codes.ok)
542 res = response.json()
543 self.assertIn('Xponder Roadm Link created successfully', res["output"]["result"])
545 def test_32_connect_roadmA_to_xpdrA(self):
546 response = test_utils.connect_rdm_to_xpdr_request("XPDR-A1", "1", "2",
547 "ROADM-A1", "1", "SRG1-PP2-TXRX")
548 self.assertEqual(response.status_code, requests.codes.ok)
549 res = response.json()
550 self.assertIn('Roadm Xponder links created successfully', res["output"]["result"])
552 def test_33_servicePath_create_AToZ(self):
553 url = "{}/operations/transportpce-device-renderer:service-path"
556 "service-name": "test2",
558 "modulation-format": "qpsk",
559 "operation": "create",
562 "dest-tp": "XPDR1-NETWORK2",
563 "src-tp": "XPDR1-CLIENT2",
567 "dest-tp": "DEG2-TTP-TXRX",
568 "src-tp": "SRG1-PP2-TXRX",
569 "node-id": "ROADM-A1"
574 response = test_utils.post_request(url, data)
575 self.assertEqual(response.status_code, requests.codes.ok)
576 res = response.json()
577 self.assertIn('Roadm-connection successfully created for nodes', res["output"]["result"])
581 def test_34_get_interface_XPDRA_XPDR1_NETWORK2(self):
582 response = test_utils.check_netconf_node_request(
584 "interface/XPDR1-NETWORK2-2/org-openroadm-optical-channel-interfaces:och")
585 self.assertEqual(response.status_code, requests.codes.ok)
586 res = response.json()
587 self.assertEqual(-5, res['org-openroadm-optical-channel-interfaces:och']['transmit-power'])
588 # self.assertEqual(2, res['org-openroadm-optical-channel-interfaces:och']['wavelength-number'])
590 def test_35_servicePath_delete_AToZ(self):
591 url = "{}/operations/transportpce-device-renderer:service-path"
594 "service-name": "test",
596 "modulation-format": "qpsk",
597 "operation": "delete",
600 "dest-tp": "XPDR1-NETWORK2",
601 "src-tp": "XPDR1-CLIENT2",
605 "dest-tp": "DEG2-TTP-TXRX",
606 "src-tp": "SRG1-PP2-TXRX",
607 "node-id": "ROADM-A1"
612 response = test_utils.post_request(url, data)
613 self.assertEqual(response.status_code, requests.codes.ok)
614 res = response.json()
615 self.assertIn('Request processed', res["output"]["result"])
618 def test_36_xpdrA_device_disconnected(self):
619 response = test_utils.unmount_device("XPDR-A1")
620 self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200)
622 def test_37_xpdrC_device_disconnected(self):
623 response = test_utils.unmount_device("XPDR-C1")
624 self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200)
626 def test_38_calculate_span_loss_current(self):
627 url = "{}/operations/transportpce-olm:calculate-spanloss-current"
628 response = test_utils.post_request(url, None)
629 self.assertEqual(response.status_code, requests.codes.ok)
630 res = response.json()
631 self.assertIn('Success',
632 res["output"]["result"])
635 def test_39_rdmA_device_disconnected(self):
636 response = test_utils.unmount_device("ROADM-A1")
637 self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200)
639 def test_40_rdmC_device_disconnected(self):
640 response = test_utils.unmount_device("ROADM-C1")
641 self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200)
644 if __name__ == "__main__":
645 unittest.main(verbosity=2)