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 #############################################################################
12 # pylint: disable=no-member
13 # pylint: disable=too-many-public-methods
18 # pylint: disable=wrong-import-order
20 sys.path.append('transportpce_tests/common/')
21 # pylint: disable=wrong-import-position
22 # pylint: disable=import-error
23 import test_utils # nopep8
26 class TransportOlmTesting(unittest.TestCase):
29 NODE_VERSION = '1.2.1'
33 cls.processes = test_utils.start_tpce()
34 cls.processes = test_utils.start_sims([('xpdra', cls.NODE_VERSION),
35 ('roadma-full', cls.NODE_VERSION),
36 ('roadmc-full', cls.NODE_VERSION),
37 ('xpdrc', cls.NODE_VERSION)])
40 def tearDownClass(cls):
41 # pylint: disable=not-an-iterable
42 for process in cls.processes:
43 test_utils.shutdown_process(process)
44 print("all processes killed")
47 # pylint: disable=consider-using-f-string
48 print("execution of {}".format(self.id().split(".")[-1]))
51 def test_01_xpdrA_device_connected(self):
52 response = test_utils.mount_device("XPDRA01", ('xpdra', self.NODE_VERSION))
53 self.assertEqual(response.status_code, requests.codes.created, test_utils.CODE_SHOULD_BE_201)
55 def test_02_xpdrC_device_connected(self):
56 response = test_utils.mount_device("XPDRC01", ('xpdrc', self.NODE_VERSION))
57 self.assertEqual(response.status_code, requests.codes.created, test_utils.CODE_SHOULD_BE_201)
59 def test_03_rdmA_device_connected(self):
60 response = test_utils.mount_device("ROADMA01", ('roadma-full', self.NODE_VERSION))
61 self.assertEqual(response.status_code, requests.codes.created, test_utils.CODE_SHOULD_BE_201)
63 def test_04_rdmC_device_connected(self):
64 response = test_utils.mount_device("ROADMC01", ('roadmc-full', self.NODE_VERSION))
65 self.assertEqual(response.status_code, requests.codes.created, test_utils.CODE_SHOULD_BE_201)
67 def test_05_connect_xprdA_to_roadmA(self):
68 response = test_utils.connect_xpdr_to_rdm_request("XPDRA01", "1", "1",
69 "ROADMA01", "1", "SRG1-PP1-TXRX")
70 self.assertEqual(response.status_code, requests.codes.ok)
72 self.assertIn('Xponder Roadm Link created successfully', res["output"]["result"])
74 def test_06_connect_roadmA_to_xpdrA(self):
75 response = test_utils.connect_rdm_to_xpdr_request("XPDRA01", "1", "1",
76 "ROADMA01", "1", "SRG1-PP1-TXRX")
77 self.assertEqual(response.status_code, requests.codes.ok)
79 self.assertIn('Roadm Xponder links created successfully', res["output"]["result"])
81 def test_07_connect_xprdC_to_roadmC(self):
82 response = test_utils.connect_xpdr_to_rdm_request("XPDRC01", "1", "1",
83 "ROADMC01", "1", "SRG1-PP1-TXRX")
84 self.assertEqual(response.status_code, requests.codes.ok)
86 self.assertIn('Xponder Roadm Link created successfully', res["output"]["result"])
88 def test_08_connect_roadmC_to_xpdrC(self):
89 response = test_utils.connect_rdm_to_xpdr_request("XPDRC01", "1", "1",
90 "ROADMC01", "1", "SRG1-PP1-TXRX")
91 self.assertEqual(response.status_code, requests.codes.ok)
93 self.assertIn('Roadm Xponder links created successfully', res["output"]["result"])
95 def test_09_create_OTS_ROADMA(self):
96 response = test_utils.create_ots_oms_request("ROADMA01", "DEG1-TTP-TXRX")
97 self.assertEqual(response.status_code, requests.codes.ok)
99 self.assertIn('Interfaces OTS-DEG1-TTP-TXRX - OMS-DEG1-TTP-TXRX successfully created on node ROADMA01',
100 res["output"]["result"])
102 def test_10_create_OTS_ROADMC(self):
103 response = test_utils.create_ots_oms_request("ROADMC01", "DEG2-TTP-TXRX")
104 self.assertEqual(response.status_code, requests.codes.ok)
105 res = response.json()
106 self.assertIn('Interfaces OTS-DEG2-TTP-TXRX - OMS-DEG2-TTP-TXRX successfully created on node ROADMC01',
107 res["output"]["result"])
109 def test_11_get_PM_ROADMA(self):
110 url = "{}/operations/transportpce-olm:get-pm"
113 "node-id": "ROADMA01",
114 "resource-type": "interface",
115 "granularity": "15min",
116 "resource-identifier": {
117 "resource-name": "OTS-DEG1-TTP-TXRX"
121 response = test_utils.post_request(url, data)
122 self.assertEqual(response.status_code, requests.codes.ok)
123 res = response.json()
125 "pmparameter-name": "OpticalPowerOutput",
126 "pmparameter-value": "2.5"
127 }, res["output"]["measurements"])
129 "pmparameter-name": "OpticalReturnLoss",
130 "pmparameter-value": "49.9"
131 }, res["output"]["measurements"])
133 "pmparameter-name": "OpticalPowerInput",
134 "pmparameter-value": "3"
135 }, res["output"]["measurements"])
137 def test_12_get_PM_ROADMC(self):
138 url = "{}/operations/transportpce-olm:get-pm"
141 "node-id": "ROADMC01",
142 "resource-type": "interface",
143 "granularity": "15min",
144 "resource-identifier": {
145 "resource-name": "OTS-DEG2-TTP-TXRX"
149 response = test_utils.post_request(url, data)
150 self.assertEqual(response.status_code, requests.codes.ok)
151 res = response.json()
153 "pmparameter-name": "OpticalPowerOutput",
154 "pmparameter-value": "18.1"
155 }, res["output"]["measurements"])
157 "pmparameter-name": "OpticalReturnLoss",
158 "pmparameter-value": "48.8"
159 }, res["output"]["measurements"])
161 "pmparameter-name": "OpticalPowerInput",
162 "pmparameter-value": "-3.2"
163 }, res["output"]["measurements"])
165 def test_13_calculate_span_loss_base_ROADMA_ROADMC(self):
166 url = "{}/operations/transportpce-olm:calculate-spanloss-base"
170 "link-id": "ROADMA01-DEG1-DEG1-TTP-TXRXtoROADMC01-DEG2-DEG2-TTP-TXRX"
173 response = test_utils.post_request(url, data)
174 self.assertEqual(response.status_code, requests.codes.ok)
175 res = response.json()
176 self.assertIn('Success',
177 res["output"]["result"])
180 "link-id": "ROADMA01-DEG1-DEG1-TTP-TXRXtoROADMC01-DEG2-DEG2-TTP-TXRX"
181 }, res["output"]["spans"])
184 def test_14_calculate_span_loss_base_all(self):
185 url = "{}/operations/transportpce-olm:calculate-spanloss-base"
191 response = test_utils.post_request(url, data)
192 self.assertEqual(response.status_code, requests.codes.ok)
193 res = response.json()
194 self.assertIn('Success',
195 res["output"]["result"])
198 "link-id": "ROADMC01-DEG2-DEG2-TTP-TXRXtoROADMA01-DEG1-DEG1-TTP-TXRX"
199 }, res["output"]["spans"])
202 "link-id": "ROADMA01-DEG1-DEG1-TTP-TXRXtoROADMC01-DEG2-DEG2-TTP-TXRX"
203 }, res["output"]["spans"])
206 def test_15_get_OTS_DEG1_TTP_TXRX_ROADMA(self):
207 response = test_utils.check_netconf_node_request(
209 "interface/OTS-DEG1-TTP-TXRX/org-openroadm-optical-transport-interfaces:ots")
210 self.assertEqual(response.status_code, requests.codes.ok)
211 res = response.json()
212 self.assertEqual(5.7, res['org-openroadm-optical-transport-interfaces:ots']['span-loss-transmit'])
213 self.assertEqual(15.1, res['org-openroadm-optical-transport-interfaces:ots']['span-loss-receive'])
215 def test_16_get_OTS_DEG2_TTP_TXRX_ROADMC(self):
216 response = test_utils.check_netconf_node_request(
218 "interface/OTS-DEG2-TTP-TXRX/org-openroadm-optical-transport-interfaces:ots")
219 self.assertEqual(response.status_code, requests.codes.ok)
220 res = response.json()
221 self.assertEqual(15.1, res['org-openroadm-optical-transport-interfaces:ots']['span-loss-transmit'])
222 self.assertEqual(5.7, res['org-openroadm-optical-transport-interfaces:ots']['span-loss-receive'])
224 def test_17_servicePath_create_AToZ(self):
225 response = test_utils.service_path_request("create", "test", "1",
226 [{"node-id": "XPDRA01",
227 "dest-tp": "XPDR1-NETWORK1", "src-tp": "XPDR1-CLIENT1"},
228 {"node-id": "ROADMA01",
229 "dest-tp": "DEG1-TTP-TXRX", "src-tp": "SRG1-PP1-TXRX"},
230 {"node-id": "ROADMC01",
231 "dest-tp": "SRG1-PP1-TXRX", "src-tp": "DEG2-TTP-TXRX"},
232 {"node-id": "XPDRC01",
233 "dest-tp": "XPDR1-CLIENT1", "src-tp": "XPDR1-NETWORK1"}],
234 196.1, 40, 196.075, 196.125, 761,
236 self.assertEqual(response.status_code, requests.codes.ok)
237 res = response.json()
238 self.assertIn('Roadm-connection successfully created for nodes', res["output"]["result"])
242 def test_18_servicePath_create_ZToA(self):
243 response = test_utils.service_path_request("create", "test", "1",
244 [{"node-id": "XPDRC01",
245 "dest-tp": "XPDR1-NETWORK1", "src-tp": "XPDR1-CLIENT1"},
246 {"node-id": "ROADMC01",
247 "dest-tp": "DEG2-TTP-TXRX", "src-tp": "SRG1-PP1-TXRX"},
248 {"node-id": "ROADMA01",
249 "src-tp": "DEG1-TTP-TXRX", "dest-tp": "SRG1-PP1-TXRX"},
250 {"node-id": "XPDRA01",
251 "src-tp": "XPDR1-NETWORK1", "dest-tp": "XPDR1-CLIENT1"}],
252 196.1, 40, 196.075, 196.125, 761,
254 self.assertEqual(response.status_code, requests.codes.ok)
255 res = response.json()
256 self.assertIn('Roadm-connection successfully created for nodes', res["output"]["result"])
260 def test_19_service_power_setup_XPDRA_XPDRC(self):
261 url = "{}/operations/transportpce-olm:service-power-setup"
264 "service-name": "test",
268 "dest-tp": "XPDR1-NETWORK1",
269 "src-tp": "XPDR1-CLIENT1",
273 "dest-tp": "DEG1-TTP-TXRX",
274 "src-tp": "SRG1-PP1-TXRX",
275 "node-id": "ROADMA01"
278 "dest-tp": "SRG1-PP1-TXRX",
279 "src-tp": "DEG2-TTP-TXRX",
280 "node-id": "ROADMC01"
283 "dest-tp": "XPDR1-CLIENT1",
284 "src-tp": "XPDR1-NETWORK1",
288 "center-freq": 196.1,
292 "lower-spectral-slot-number": 761,
293 "higher-spectral-slot-number": 768
296 response = test_utils.post_request(url, data)
297 self.assertEqual(response.status_code, requests.codes.ok)
298 res = response.json()
299 self.assertIn('Success', res["output"]["result"])
301 def test_20_get_interface_XPDRA_XPDR1_NETWORK1(self):
302 response = test_utils.check_netconf_node_request(
304 "interface/XPDR1-NETWORK1-761:768/org-openroadm-optical-channel-interfaces:och")
305 self.assertEqual(response.status_code, requests.codes.ok)
306 res = response.json()
307 self.assertEqual(0, res['org-openroadm-optical-channel-interfaces:och']['transmit-power'])
308 self.assertEqual(1, res['org-openroadm-optical-channel-interfaces:och']['wavelength-number'])
310 def test_21_get_roadmconnection_ROADMA(self):
311 response = test_utils.check_netconf_node_request(
312 "ROADMA01", "roadm-connections/SRG1-PP1-TXRX-DEG1-TTP-TXRX-761:768")
313 self.assertEqual(response.status_code, requests.codes.ok)
314 res = response.json()
315 self.assertEqual("gainLoss", res['roadm-connections'][0]['opticalControlMode'])
316 self.assertEqual(-3.3, res['roadm-connections'][0]['target-output-power'])
318 def test_22_get_roadmconnection_ROADMC(self):
319 response = test_utils.check_netconf_node_request(
320 "ROADMC01", "roadm-connections/DEG2-TTP-TXRX-SRG1-PP1-TXRX-761:768")
321 self.assertEqual(response.status_code, requests.codes.ok)
322 res = response.json()
323 self.assertEqual("power", res['roadm-connections'][0]['opticalControlMode'])
325 def test_23_service_power_setup_XPDRC_XPDRA(self):
326 url = "{}/operations/transportpce-olm:service-power-setup"
329 "service-name": "test",
333 "dest-tp": "XPDR1-NETWORK1",
334 "src-tp": "XPDR1-CLIENT1",
338 "dest-tp": "DEG2-TTP-TXRX",
339 "src-tp": "SRG1-PP1-TXRX",
340 "node-id": "ROADMC01"
343 "src-tp": "DEG1-TTP-TXRX",
344 "dest-tp": "SRG1-PP1-TXRX",
345 "node-id": "ROADMA01"
348 "src-tp": "XPDR1-NETWORK1",
349 "dest-tp": "XPDR1-CLIENT1",
353 "center-freq": 196.1,
357 "lower-spectral-slot-number": 761,
358 "higher-spectral-slot-number": 768
361 response = test_utils.post_request(url, data)
362 self.assertEqual(response.status_code, requests.codes.ok)
363 res = response.json()
364 self.assertIn('Success', res["output"]["result"])
366 def test_24_get_interface_XPDRC_XPDR1_NETWORK1(self):
367 response = test_utils.check_netconf_node_request(
369 "interface/XPDR1-NETWORK1-761:768/org-openroadm-optical-channel-interfaces:och")
370 self.assertEqual(response.status_code, requests.codes.ok)
371 res = response.json()
372 self.assertEqual(0, res['org-openroadm-optical-channel-interfaces:och']['transmit-power'])
373 self.assertEqual(1, res['org-openroadm-optical-channel-interfaces:och']['wavelength-number'])
375 def test_25_get_roadmconnection_ROADMC(self):
376 response = test_utils.check_netconf_node_request(
377 "ROADMC01", "roadm-connections/SRG1-PP1-TXRX-DEG2-TTP-TXRX-761:768")
378 self.assertEqual(response.status_code, requests.codes.ok)
379 res = response.json()
380 self.assertEqual("gainLoss", res['roadm-connections'][0]['opticalControlMode'])
381 self.assertEqual(2, res['roadm-connections'][0]['target-output-power'])
383 def test_26_service_power_turndown_XPDRA_XPDRC(self):
384 url = "{}/operations/transportpce-olm:service-power-turndown"
387 "service-name": "test",
391 "dest-tp": "XPDR1-NETWORK1",
392 "src-tp": "XPDR1-CLIENT1",
396 "dest-tp": "DEG1-TTP-TXRX",
397 "src-tp": "SRG1-PP1-TXRX",
398 "node-id": "ROADMA01"
401 "dest-tp": "SRG1-PP1-TXRX",
402 "src-tp": "DEG2-TTP-TXRX",
403 "node-id": "ROADMC01"
406 "dest-tp": "XPDR1-CLIENT1",
407 "src-tp": "XPDR1-NETWORK1",
411 "center-freq": 196.1,
415 "lower-spectral-slot-number": 761,
416 "higher-spectral-slot-number": 768
419 response = test_utils.post_request(url, data)
420 print(response.json())
421 self.assertEqual(response.status_code, requests.codes.ok)
422 res = response.json()
423 self.assertIn('Success', res["output"]["result"])
425 def test_27_get_roadmconnection_ROADMA(self):
426 response = test_utils.check_netconf_node_request(
427 "ROADMA01", "roadm-connections/SRG1-PP1-TXRX-DEG1-TTP-TXRX-761:768")
428 self.assertEqual(response.status_code, requests.codes.ok)
429 res = response.json()
430 self.assertEqual("off", res['roadm-connections'][0]['opticalControlMode'])
431 self.assertEqual(-60, res['roadm-connections'][0]['target-output-power'])
433 def test_28_get_roadmconnection_ROADMC(self):
434 response = test_utils.check_netconf_node_request(
435 "ROADMC01", "roadm-connections/DEG2-TTP-TXRX-SRG1-PP1-TXRX-761:768")
436 self.assertEqual(response.status_code, requests.codes.ok)
437 res = response.json()
438 self.assertEqual("off", res['roadm-connections'][0]['opticalControlMode'])
440 def test_29_servicePath_delete_AToZ(self):
441 response = test_utils.service_path_request("delete", "test", "1",
442 [{"node-id": "XPDRA01",
443 "dest-tp": "XPDR1-NETWORK1", "src-tp": "XPDR1-CLIENT1"},
444 {"node-id": "ROADMA01",
445 "dest-tp": "DEG1-TTP-TXRX", "src-tp": "SRG1-PP1-TXRX"},
446 {"node-id": "ROADMC01",
447 "dest-tp": "SRG1-PP1-TXRX", "src-tp": "DEG2-TTP-TXRX"},
448 {"node-id": "XPDRC01",
449 "dest-tp": "XPDR1-CLIENT1", "src-tp": "XPDR1-NETWORK1"}],
450 196.1, 40, 196.075, 196.125, 761,
452 self.assertEqual(response.status_code, requests.codes.ok)
453 res = response.json()
454 self.assertIn('Request processed', res["output"]["result"])
457 def test_30_servicePath_delete_ZToA(self):
458 response = test_utils.service_path_request("delete", "test", "1",
459 [{"node-id": "XPDRC01",
460 "dest-tp": "XPDR1-NETWORK1", "src-tp": "XPDR1-CLIENT1"},
461 {"node-id": "ROADMC01",
462 "dest-tp": "DEG2-TTP-TXRX", "src-tp": "SRG1-PP1-TXRX"},
463 {"node-id": "ROADMA01",
464 "src-tp": "DEG1-TTP-TXRX", "dest-tp": "SRG1-PP1-TXRX"},
465 {"node-id": "XPDRA01",
466 "src-tp": "XPDR1-NETWORK1", "dest-tp": "XPDR1-CLIENT1"}],
467 196.1, 40, 196.075, 196.125, 761,
469 self.assertEqual(response.status_code, requests.codes.ok)
470 res = response.json()
471 self.assertIn('Request processed', res["output"]["result"])
474 #"""to test case where SRG where the xpdr is connected to has no optical range data"""
476 def test_31_connect_xprdA_to_roadmA(self):
477 response = test_utils.connect_xpdr_to_rdm_request("XPDRA01", "1", "2",
478 "ROADMA01", "1", "SRG1-PP2-TXRX")
479 self.assertEqual(response.status_code, requests.codes.ok)
480 res = response.json()
481 self.assertIn('Xponder Roadm Link created successfully', res["output"]["result"])
483 def test_32_connect_roadmA_to_xpdrA(self):
484 response = test_utils.connect_rdm_to_xpdr_request("XPDRA01", "1", "2",
485 "ROADMA01", "1", "SRG1-PP2-TXRX")
486 self.assertEqual(response.status_code, requests.codes.ok)
487 res = response.json()
488 self.assertIn('Roadm Xponder links created successfully', res["output"]["result"])
490 def test_33_servicePath_create_AToZ(self):
491 response = test_utils.service_path_request("create", "test2", "2",
492 [{"node-id": "XPDRA01",
493 "dest-tp": "XPDR1-NETWORK2", "src-tp": "XPDR1-CLIENT2"},
494 {"node-id": "ROADMA01",
495 "dest-tp": "DEG1-TTP-TXRX", "src-tp": "SRG1-PP2-TXRX"}],
496 196.05, 40, 196.025, 196.075, 753,
498 self.assertEqual(response.status_code, requests.codes.ok)
499 res = response.json()
500 self.assertIn('Roadm-connection successfully created for nodes', res["output"]["result"])
504 def test_34_get_interface_XPDRA_XPDR1_NETWORK2(self):
505 response = test_utils.check_netconf_node_request(
507 "interface/XPDR1-NETWORK2-753:760/org-openroadm-optical-channel-interfaces:och")
508 self.assertEqual(response.status_code, requests.codes.ok)
509 res = response.json()
510 self.assertEqual(-5, res['org-openroadm-optical-channel-interfaces:och']['transmit-power'])
511 self.assertEqual(2, res['org-openroadm-optical-channel-interfaces:och']['wavelength-number'])
513 def test_35_servicePath_delete_AToZ(self):
514 response = test_utils.service_path_request("delete", "test", "1",
515 [{"node-id": "XPDRA01",
516 "dest-tp": "XPDR1-NETWORK2", "src-tp": "XPDR1-CLIENT2"},
517 {"node-id": "ROADMA01",
518 "dest-tp": "DEG1-TTP-TXRX", "src-tp": "SRG1-PP2-TXRX"}],
519 196.1, 40, 196.075, 196.125, 761,
521 self.assertEqual(response.status_code, requests.codes.ok)
522 res = response.json()
523 self.assertIn('Request processed', res["output"]["result"])
526 def test_36_xpdrA_device_disconnected(self):
527 response = test_utils.unmount_device("XPDRA01")
528 self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200)
530 def test_37_xpdrC_device_disconnected(self):
531 response = test_utils.unmount_device("XPDRC01")
532 self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200)
534 def test_38_calculate_span_loss_current(self):
535 url = "{}/operations/transportpce-olm:calculate-spanloss-current"
536 response = test_utils.post_request(url, None)
537 self.assertEqual(response.status_code, requests.codes.ok)
538 res = response.json()
539 self.assertIn('Success',
540 res["output"]["result"])
543 def test_39_rdmA_device_disconnected(self):
544 response = test_utils.unmount_device("ROADMA01")
545 self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200)
547 def test_40_rdmC_device_disconnected(self):
548 response = test_utils.unmount_device("ROADMC01")
549 self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200)
552 if __name__ == "__main__":
553 unittest.main(verbosity=2)