review SPDR sims nomenclature
[transportpce.git] / tests / transportpce_tests / 2.2.1 / test_tapi.py
1 #!/usr/bin/env python
2 ##############################################################################
3 # Copyright (c) 2020 Orange, Inc. and others.  All rights reserved.
4 #
5 # All rights reserved. This program and the accompanying materials
6 # are made available under the terms of the Apache License, Version 2.0
7 # which accompanies this distribution, and is available at
8 # http://www.apache.org/licenses/LICENSE-2.0
9 ##############################################################################
10 import os
11 import sys
12 import time
13 import unittest
14
15 import requests
16
17 from common import test_utils
18
19
20 CREATED_SUCCESSFULLY = 'Result message should contain Xponder Roadm Link created successfully'
21
22
23 class TransportTapitesting(unittest.TestCase):
24
25     processes = None
26
27     @classmethod
28     def setUpClass(cls):
29         cls.init_failed = False
30
31         cls.processes = test_utils.start_tpce()
32         # TAPI feature is not installed by default in Karaf
33         if "USE_LIGHTY" not in os.environ or os.environ['USE_LIGHTY'] != 'True':
34             print("installing tapi feature...")
35             result = test_utils.install_karaf_feature("odl-transportpce-tapi")
36             if result.returncode != 0:
37                 cls.init_failed = True
38             print("Restarting OpenDaylight...")
39             test_utils.shutdown_process(cls.processes[0])
40             cls.processes[0] = test_utils.start_karaf()
41             test_utils.process_list[0] = cls.processes[0]
42             cls.init_failed = not test_utils.wait_until_log_contains(
43                 test_utils.KARAF_LOG, test_utils.KARAF_OK_START_MSG, time_to_wait=60)
44         if cls.init_failed:
45             print("tapi installation feature failed...")
46             test_utils.shutdown_process(cls.processes[0])
47             sys.exit(2)
48         cls.processes = test_utils.start_sims(['xpdra', 'roadma', 'roadmc', 'xpdrc', 'spdra'])
49
50     @classmethod
51     def tearDownClass(cls):
52         for process in cls.processes:
53             test_utils.shutdown_process(process)
54         print("all processes killed")
55
56     def setUp(self):  # instruction executed before each test method
57         if self.init_failed:
58             self.fail('Feature installation failed')
59         print("execution of {}".format(self.id().split(".")[-1]))
60
61     def test_00_connect_spdr_sa1(self):
62         response = test_utils.mount_device("SPDR-SA1", 'spdra')
63         self.assertEqual(response.status_code, requests.codes.created, test_utils.CODE_SHOULD_BE_201)
64         time.sleep(10)
65         # TODO replace connect and disconnect timers with test_utils.wait_until_log_contains
66
67     def test_01_connect_xpdra(self):
68         response = test_utils.mount_device("XPDR-A1", 'xpdra')
69         self.assertEqual(response.status_code, requests.codes.created, test_utils.CODE_SHOULD_BE_201)
70         time.sleep(10)
71
72     def test_02_connect_xpdrc(self):
73         response = test_utils.mount_device("XPDR-C1", 'xpdrc')
74         self.assertEqual(response.status_code, requests.codes.created, test_utils.CODE_SHOULD_BE_201)
75         time.sleep(10)
76
77     def test_03_connect_rdma(self):
78         response = test_utils.mount_device("ROADM-A1", 'roadma')
79         self.assertEqual(response.status_code, requests.codes.created, test_utils.CODE_SHOULD_BE_201)
80         time.sleep(20)
81
82     def test_04_connect_rdmc(self):
83         response = test_utils.mount_device("ROADM-C1", 'roadmc')
84         self.assertEqual(response.status_code, requests.codes.created, test_utils.CODE_SHOULD_BE_201)
85         time.sleep(20)
86
87     def test_05_connect_xprda_n1_to_roadma_pp1(self):
88         url = "{}/operations/transportpce-networkutils:init-xpdr-rdm-links".format(test_utils.RESTCONF_BASE_URL)
89         data = test_utils.generate_link_data("XPDR-A1", "1", "1", "ROADM-A1", "1", "SRG1-PP1-TXRX")
90         response = test_utils.post_request(url, data, test_utils.ODL_LOGIN, test_utils.ODL_PWD)
91         self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200)
92         res = response.json()
93         self.assertIn('Xponder Roadm Link created successfully', res["output"]["result"],
94                       CREATED_SUCCESSFULLY)
95         time.sleep(2)
96
97     def test_06_connect_roadma_pp1_to_xpdra_n1(self):
98         url = "{}/operations/transportpce-networkutils:init-rdm-xpdr-links".format(test_utils.RESTCONF_BASE_URL)
99         data = test_utils.generate_link_data("XPDR-A1", "1", "1", "ROADM-A1", "1", "SRG1-PP1-TXRX")
100         response = test_utils.post_request(url, data, test_utils.ODL_LOGIN, test_utils.ODL_PWD)
101         self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200)
102         res = response.json()
103         self.assertIn('Roadm Xponder links created successfully', res["output"]["result"],
104                       CREATED_SUCCESSFULLY)
105         time.sleep(2)
106
107     def test_07_connect_xprdc_n1_to_roadmc_pp1(self):
108         url = "{}/operations/transportpce-networkutils:init-xpdr-rdm-links".format(test_utils.RESTCONF_BASE_URL)
109         data = test_utils.generate_link_data("XPDR-C1", "1", "1", "ROADM-C1", "1", "SRG1-PP1-TXRX")
110         response = test_utils.post_request(url, data, test_utils.ODL_LOGIN, test_utils.ODL_PWD)
111         self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200)
112         res = response.json()
113         self.assertIn('Xponder Roadm Link created successfully', res["output"]["result"],
114                       CREATED_SUCCESSFULLY)
115         time.sleep(2)
116
117     def test_08_connect_roadmc_pp1_to_xpdrc_n1(self):
118         url = "{}/operations/transportpce-networkutils:init-rdm-xpdr-links".format(test_utils.RESTCONF_BASE_URL)
119         data = test_utils.generate_link_data("XPDR-C1", "1", "1", "ROADM-C1", "1", "SRG1-PP1-TXRX")
120         response = test_utils.post_request(url, data, test_utils.ODL_LOGIN, test_utils.ODL_PWD)
121         self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200)
122         res = response.json()
123         self.assertIn('Roadm Xponder links created successfully', res["output"]["result"],
124                       CREATED_SUCCESSFULLY)
125         time.sleep(2)
126
127     def test_09_connect_xprda_n2_to_roadma_pp2(self):
128         url = "{}/operations/transportpce-networkutils:init-xpdr-rdm-links".format(test_utils.RESTCONF_BASE_URL)
129         data = test_utils.generate_link_data("XPDR-A1", "1", "2", "ROADM-A1", "1", "SRG1-PP2-TXRX")
130         response = test_utils.post_request(url, data, test_utils.ODL_LOGIN, test_utils.ODL_PWD)
131         self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200)
132         res = response.json()
133         self.assertIn('Xponder Roadm Link created successfully', res["output"]["result"],
134                       CREATED_SUCCESSFULLY)
135         time.sleep(2)
136
137     def test_10_connect_roadma_pp2_to_xpdra_n2(self):
138         url = "{}/operations/transportpce-networkutils:init-rdm-xpdr-links".format(test_utils.RESTCONF_BASE_URL)
139         data = test_utils.generate_link_data("XPDR-A1", "1", "2", "ROADM-A1", "1", "SRG1-PP2-TXRX")
140         response = test_utils.post_request(url, data, test_utils.ODL_LOGIN, test_utils.ODL_PWD)
141         self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200)
142         res = response.json()
143         self.assertIn('Roadm Xponder links created successfully', res["output"]["result"],
144                       CREATED_SUCCESSFULLY)
145         time.sleep(2)
146
147     def test_11_connect_xprdc_n2_to_roadmc_pp2(self):
148         url = "{}/operations/transportpce-networkutils:init-xpdr-rdm-links".format(test_utils.RESTCONF_BASE_URL)
149         data = test_utils.generate_link_data("XPDR-C1", "1", "2", "ROADM-C1", "1", "SRG1-PP2-TXRX")
150         response = test_utils.post_request(url, data, test_utils.ODL_LOGIN, test_utils.ODL_PWD)
151         self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200)
152         res = response.json()
153         self.assertIn('Xponder Roadm Link created successfully', res["output"]["result"],
154                       CREATED_SUCCESSFULLY)
155         time.sleep(2)
156
157     def test_12_connect_roadmc_pp2_to_xpdrc_n2(self):
158         url = "{}/operations/transportpce-networkutils:init-rdm-xpdr-links".format(test_utils.RESTCONF_BASE_URL)
159         data = test_utils.generate_link_data("XPDR-C1", "1", "2", "ROADM-C1", "1", "SRG1-PP2-TXRX")
160         response = test_utils.post_request(url, data, test_utils.ODL_LOGIN, test_utils.ODL_PWD)
161         self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200)
162         res = response.json()
163         self.assertIn('Roadm Xponder links created successfully', res["output"]["result"],
164                       CREATED_SUCCESSFULLY)
165         time.sleep(2)
166
167     def test_13_get_tapi_openroadm_topology(self):
168         url = "{}/operations/tapi-topology:get-topology-details".format(test_utils.RESTCONF_BASE_URL)
169         data = {
170             "tapi-topology:input": {
171                 "tapi-topology:topology-id-or-name": "openroadm-topology"
172             }
173         }
174
175         response = test_utils.post_request(url, data, test_utils.ODL_LOGIN, test_utils.ODL_PWD)
176         self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200)
177         res = response.json()
178         self.assertEqual(len(res["output"]["topology"]["node"]), 1, 'There should be 1 node')
179         self.assertEqual(len(res["output"]["topology"]["node"][0]["owned-node-edge-point"]), 4,
180                          'There should be 4 owned-node-edge-points')
181
182     def test_14_get_tapi_otn_topology(self):
183         url = "{}/operations/tapi-topology:get-topology-details".format(test_utils.RESTCONF_BASE_URL)
184         data = {
185             "tapi-topology:input": {
186                 "tapi-topology:topology-id-or-name": "otn-topology"
187             }
188         }
189
190         response = test_utils.post_request(url, data, test_utils.ODL_LOGIN, test_utils.ODL_PWD)
191         self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200)
192         res = response.json()
193         self.assertEqual(len(res["output"]["topology"]["node"]), 4, 'There should be 4 nodes')
194         self.assertEqual(len(res["output"]["topology"]["link"]), 5, 'There should be 5 links')
195         link_to_check = res["output"]["topology"]["link"][0]
196         # get info from first link to do deeper check
197         node1_uid = link_to_check["node-edge-point"][0]["node-uuid"]
198         node2_uid = link_to_check["node-edge-point"][1]["node-uuid"]
199         node_edge_point1_uid = link_to_check["node-edge-point"][0]["node-edge-point-uuid"]
200         node_edge_point2_uid = link_to_check["node-edge-point"][1]["node-edge-point-uuid"]
201         # get node associated to link info
202         nodes = res["output"]["topology"]["node"]
203         node1 = find_object_with_key(nodes, "uuid", node1_uid)
204         self.assertIsNotNone(node1, 'Node with uuid ' + node1_uid + ' should not be null')
205         node2 = find_object_with_key(nodes, "uuid", node2_uid)
206         self.assertIsNotNone(node2, 'Node with uuid ' + node2_uid + ' should not be null')
207         # get edge-point associated to nodes
208         node1_edge_point = node1["owned-node-edge-point"]
209         node2_edge_point = node2["owned-node-edge-point"]
210         node_edge_point1 = find_object_with_key(node1_edge_point, "uuid", node_edge_point1_uid)
211         self.assertIsNotNone(node_edge_point1, 'Node edge point  with uuid ' + node_edge_point1_uid + 'should not be '
212                                                                                                       'null')
213         node_edge_point2 = find_object_with_key(node2_edge_point, "uuid", node_edge_point2_uid)
214         self.assertIsNotNone(node_edge_point2, 'Node edge point with uuid ' + node_edge_point2_uid + 'should not be '
215                                                                                                      'null')
216         self.assertEqual(len(node_edge_point1["name"]), 1, 'There should be 1 name')
217         self.assertEqual(len(node_edge_point2["name"]), 1, 'There should be 1 name')
218         if node_edge_point1["layer-protocol-name"] == 'ODU':
219             self.assertIn('NodeEdgePoint_N', node_edge_point1["name"][0]["value-name"], 'Value name should be '
220                           'NodeEdgePoint_NX')
221         elif node_edge_point1["layer-protocol-name"] == 'PHOTONIC_MEDIA':
222             self.assertIn('iNodeEdgePoint_', node_edge_point1["name"][0]["value-name"], 'Value name should be '
223                           'iNodeEdgePoint_X')
224         else:
225             self.fail('Wrong layer protocol name')
226
227         if node_edge_point2["layer-protocol-name"] == 'ODU':
228             self.assertIn('NodeEdgePoint_N', node_edge_point2["name"][0]["value-name"], 'Value name should be '
229                           'NodeEdgePoint_NX')
230         elif node_edge_point2["layer-protocol-name"] == 'PHOTONIC_MEDIA':
231             self.assertIn('iNodeEdgePoint_', node_edge_point2["name"][0]["value-name"], 'Value name should be '
232                           'iNodeEdgePoint_X')
233         else:
234             self.fail('Wrong layer protocol name')
235
236     def test_15_disconnect_xpdra(self):
237         response = test_utils.unmount_device("XPDR-A1")
238         self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200)
239         time.sleep(10)
240
241     def test_16_disconnect_xpdrc(self):
242         response = test_utils.unmount_device("XPDR-C1")
243         self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200)
244         time.sleep(10)
245
246     def test_17_disconnect_roadma(self):
247         response = test_utils.unmount_device("ROADM-A1")
248         self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200)
249         time.sleep(10)
250
251     def test_18_disconnect_roadmc(self):
252         response = test_utils.unmount_device("ROADM-C1")
253         self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200)
254         time.sleep(10)
255
256     def test_19_disconnect_spdr_sa1(self):
257         response = test_utils.unmount_device("SPDR-SA1")
258         self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200)
259
260
261 def find_object_with_key(list_dicts, key, value):
262     for dict_ in list_dicts:
263         if dict_[key] == value:
264             return dict_
265     return None
266
267
268 if __name__ == "__main__":
269     unittest.main(verbosity=2)