From 5f647d7cdc6d8057e420fb2ae5f53cc478bb8e81 Mon Sep 17 00:00:00 2001 From: Gilles Thouenon Date: Tue, 27 Oct 2020 16:01:48 +0100 Subject: [PATCH] Rewrite TAPI topology functional tests - reactivate tapi functional tests in tox - rewrite all the functional test suite in order to complement UTs JIRA: TRNSPRTPCE-344 Signed-off-by: Gilles Thouenon Co-authored-by: Christophe Betoule Change-Id: I70008b844f8b15f98ff60968c7ba836ced5b1c00 --- tests/transportpce_tests/2.2.1/test_tapi.py | 671 +++++++++++++++++--- tox.ini | 2 +- 2 files changed, 584 insertions(+), 89 deletions(-) diff --git a/tests/transportpce_tests/2.2.1/test_tapi.py b/tests/transportpce_tests/2.2.1/test_tapi.py index 496a33e65..d945c335b 100644 --- a/tests/transportpce_tests/2.2.1/test_tapi.py +++ b/tests/transportpce_tests/2.2.1/test_tapi.py @@ -26,16 +26,117 @@ from common import test_utils CREATED_SUCCESSFULLY = 'Result message should contain Xponder Roadm Link created successfully' - class TransportTapitesting(unittest.TestCase): processes = None + WAITING = 20 + cr_serv_sample_data = {"input": { + "sdnc-request-header": { + "request-id": "request-1", + "rpc-action": "service-create", + "request-system-id": "appname" + }, + "service-name": "service1-OCH-OTU4", + "common-id": "commonId", + "connection-type": "infrastructure", + "service-a-end": { + "service-rate": "100", + "node-id": "SPDR-SA1", + "service-format": "OTU", + "otu-service-rate": "org-openroadm-otn-common-types:OTU4", + "clli": "NodeSA", + "subrate-eth-sla": { + "subrate-eth-sla": { + "committed-info-rate": "100000", + "committed-burst-size": "64" + } + }, + "tx-direction": { + "port": { + "port-device-name": "SPDR-SA1-XPDR1", + "port-type": "fixed", + "port-name": "XPDR1-NETWORK1", + "port-rack": "000000.00", + "port-shelf": "Chassis#1" + }, + "lgx": { + "lgx-device-name": "Some lgx-device-name", + "lgx-port-name": "Some lgx-port-name", + "lgx-port-rack": "000000.00", + "lgx-port-shelf": "00" + } + }, + "rx-direction": { + "port": { + "port-device-name": "SPDR-SA1-XPDR1", + "port-type": "fixed", + "port-name": "XPDR1-NETWORK1", + "port-rack": "000000.00", + "port-shelf": "Chassis#1" + }, + "lgx": { + "lgx-device-name": "Some lgx-device-name", + "lgx-port-name": "Some lgx-port-name", + "lgx-port-rack": "000000.00", + "lgx-port-shelf": "00" + } + }, + "optic-type": "gray" + }, + "service-z-end": { + "service-rate": "100", + "node-id": "SPDR-SC1", + "service-format": "OTU", + "otu-service-rate": "org-openroadm-otn-common-types:OTU4", + "clli": "NodeSC", + "subrate-eth-sla": { + "subrate-eth-sla": { + "committed-info-rate": "100000", + "committed-burst-size": "64" + } + }, + "tx-direction": { + "port": { + "port-device-name": "SPDR-SC1-XPDR1", + "port-type": "fixed", + "port-name": "XPDR1-NETWORK1", + "port-rack": "000000.00", + "port-shelf": "Chassis#1" + }, + "lgx": { + "lgx-device-name": "Some lgx-device-name", + "lgx-port-name": "Some lgx-port-name", + "lgx-port-rack": "000000.00", + "lgx-port-shelf": "00" + } + }, + "rx-direction": { + "port": { + "port-device-name": "SPDR-SC1-XPDR1", + "port-type": "fixed", + "port-name": "XPDR1-NETWORK1", + "port-rack": "000000.00", + "port-shelf": "Chassis#1" + }, + "lgx": { + "lgx-device-name": "Some lgx-device-name", + "lgx-port-name": "Some lgx-port-name", + "lgx-port-rack": "000000.00", + "lgx-port-shelf": "00" + } + }, + "optic-type": "gray" + }, + "due-date": "2018-06-15T00:00:01Z", + "operator-contact": "pw1234" + } + } @classmethod def setUpClass(cls): cls.init_failed = False os.environ['JAVA_MIN_MEM'] = '1024M' - os.environ['JAVA_MAX_MEM'] = '4069M' + os.environ['JAVA_MAX_MEM'] = '4096M' cls.processes = test_utils.start_tpce() # TAPI feature is not installed by default in Karaf if "USE_LIGHTY" not in os.environ or os.environ['USE_LIGHTY'] != 'True': @@ -53,7 +154,7 @@ class TransportTapitesting(unittest.TestCase): print("tapi installation feature failed...") test_utils.shutdown_process(cls.processes[0]) sys.exit(2) - cls.processes = test_utils.start_sims(['xpdra', 'roadma', 'roadmc', 'xpdrc', 'spdra']) + cls.processes = test_utils.start_sims(['xpdra', 'roadma', 'roadmb', 'roadmc', 'xpdrc', 'spdra', 'spdrc']) @classmethod def tearDownClass(cls): @@ -67,33 +168,115 @@ class TransportTapitesting(unittest.TestCase): self.fail('Feature installation failed') print("execution of {}".format(self.id().split(".")[-1])) - def test_00_connect_spdr_sa1(self): - response = test_utils.mount_device("SPDR-SA1", 'spdra') + def test_01_get_tapi_topology_T100G(self): + url = "{}/operations/tapi-topology:get-topology-details" + data = { + "tapi-topology:input": { + "tapi-topology:topology-id-or-name": "Transponder 100GE" + } + } + response = test_utils.post_request(url, data) + self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200) + res = response.json() + self.assertEqual(len(res["output"]["topology"]["node"]), 1, 'Topology should contain 1 node') + self.assertNotIn("link", res["output"]["topology"], 'Topology should contain no link') + self.assertNotIn("owned-node-edge-point", res["output"]["topology"]["node"][0], + 'Node should contain no owned-node-edge-points') + self.assertEqual("Tpdr100g over WDM node", res["output"]["topology"]["node"][0]["name"][0]["value"], + 'node name should be: Tpdr100g over WDM node') + self.assertIn("ETH", res["output"]["topology"]["node"][0]["layer-protocol-name"], + 'Node layer protocol should contain ETH') + self.assertEqual(1, len(res["output"]["topology"]["node"][0]["node-rule-group"]), + 'node should contain 1 node rule group') + + def test_02_get_tapi_topology_T0(self): + url = "{}/operations/tapi-topology:get-topology-details" + data = { + "tapi-topology:input": { + "tapi-topology:topology-id-or-name": "T0 - Multi-layer topology" + } + } + response = test_utils.post_request(url, data) + self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200) + res = response.json() + self.assertNotIn("node", res["output"]["topology"], 'Topology should contain no node') + self.assertNotIn("link", res["output"]["topology"], 'Topology should contain no link') + + def test_03_connect_rdmb(self): + response = test_utils.mount_device("ROADM-B1", 'roadmb') self.assertEqual(response.status_code, requests.codes.created, test_utils.CODE_SHOULD_BE_201) time.sleep(10) - # TODO replace connect and disconnect timers with test_utils.wait_until_log_contains - def test_01_connect_xpdra(self): + def test_04_check_tapi_topos(self): + url = "{}/operations/tapi-topology:get-topology-details" + data = { + "tapi-topology:input": { + "tapi-topology:topology-id-or-name": "Transponder 100GE" + } + } + response = test_utils.post_request(url, data) + self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200) + res = response.json() + self.assertEqual(len(res["output"]["topology"]["node"]), 1, 'Topology should contain 1 node') + self.assertNotIn("link", res["output"]["topology"], 'Topology should contain no link') + + url = "{}/operations/tapi-topology:get-topology-details" + data = { + "tapi-topology:input": { + "tapi-topology:topology-id-or-name": "T0 - Multi-layer topology" + } + } + response = test_utils.post_request(url, data) + self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200) + res = response.json() + self.assertNotIn("node", res["output"]["topology"], 'Topology should contain no node') + self.assertNotIn("link", res["output"]["topology"], 'Topology should contain no link') + + def test_05_disconnect_roadmb(self): + response = test_utils.unmount_device("ROADM-B1") + self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200) + time.sleep(5) + + def test_06_connect_xpdra(self): response = test_utils.mount_device("XPDR-A1", 'xpdra') self.assertEqual(response.status_code, requests.codes.created, test_utils.CODE_SHOULD_BE_201) time.sleep(10) - def test_02_connect_xpdrc(self): - response = test_utils.mount_device("XPDR-C1", 'xpdrc') - self.assertEqual(response.status_code, requests.codes.created, test_utils.CODE_SHOULD_BE_201) - time.sleep(10) + def test_07_check_tapi_topos(self): + self.test_04_check_tapi_topos() - def test_03_connect_rdma(self): + def test_08_connect_rdma(self): response = test_utils.mount_device("ROADM-A1", 'roadma') self.assertEqual(response.status_code, requests.codes.created, test_utils.CODE_SHOULD_BE_201) - time.sleep(20) + time.sleep(10) - def test_04_connect_rdmc(self): + def test_09_connect_rdmc(self): response = test_utils.mount_device("ROADM-C1", 'roadmc') self.assertEqual(response.status_code, requests.codes.created, test_utils.CODE_SHOULD_BE_201) - time.sleep(20) + time.sleep(10) - def test_05_connect_xprda_n1_to_roadma_pp1(self): + def test_10_check_tapi_topos(self): + self.test_01_get_tapi_topology_T100G() + + url = "{}/operations/tapi-topology:get-topology-details" + data = { + "tapi-topology:input": { + "tapi-topology:topology-id-or-name": "T0 - Multi-layer topology" + } + } + response = test_utils.post_request(url, data) + self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200) + res = response.json() + self.assertEqual(1, len(res["output"]["topology"]["node"]), 'Topology should contain 1 node') + self.assertNotIn("link", res["output"]["topology"], 'Topology should contain no link') + self.assertEqual("ROADM-infra", res["output"]["topology"]["node"][0]["name"][0]["value"], + 'node name should be: ROADM-infra') + self.assertIn("PHOTONIC_MEDIA", res["output"]["topology"]["node"][0]["layer-protocol-name"], + 'Node layer protocol should contain PHOTONIC_MEDIA') + self.assertEqual(1, len(res["output"]["topology"]["node"][0]["node-rule-group"]), + 'node should contain 1 node rule group') + + def test_11_connect_xprda_n1_to_roadma_pp1(self): response = test_utils.connect_xpdr_to_rdm_request("XPDR-A1", "1", "1", "ROADM-A1", "1", "SRG1-PP1-TXRX") self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200) @@ -102,7 +285,7 @@ class TransportTapitesting(unittest.TestCase): CREATED_SUCCESSFULLY) time.sleep(2) - def test_06_connect_roadma_pp1_to_xpdra_n1(self): + def test_12_connect_roadma_pp1_to_xpdra_n1(self): response = test_utils.connect_rdm_to_xpdr_request("XPDR-A1", "1", "1", "ROADM-A1", "1", "SRG1-PP1-TXRX") self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200) @@ -111,7 +294,51 @@ class TransportTapitesting(unittest.TestCase): CREATED_SUCCESSFULLY) time.sleep(2) - def test_07_connect_xprdc_n1_to_roadmc_pp1(self): + def test_13_check_tapi_topology_T100G(self): + url = "{}/operations/tapi-topology:get-topology-details" + data = { + "tapi-topology:input": { + "tapi-topology:topology-id-or-name": "Transponder 100GE" + } + } + response = test_utils.post_request(url, data) + self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200) + res = response.json() + self.assertEqual(1, len(res["output"]["topology"]["node"][0]["owned-node-edge-point"]), + 'Node should contain 1 owned-node-edge-points') + self.assertEqual("XPDR1-CLIENT1", + res["output"]["topology"]["node"][0]["owned-node-edge-point"][0]["name"][0]["value"], + 'name of owned-node-edge-points should be XPDR1-CLIENT1') + + def test_14_check_tapi_topology_T0(self): + url = "{}/operations/tapi-topology:get-topology-details" + data = { + "tapi-topology:input": { + "tapi-topology:topology-id-or-name": "T0 - Multi-layer topology" + } + } + response = test_utils.post_request(url, data) + self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200) + res = response.json() + nodes = res["output"]["topology"]["node"] + links = res["output"]["topology"]["link"] + self.assertEqual(3, len(nodes), 'Topology should contain 3 nodes') + self.assertEqual(2, len(links), 'Topology should contain 2 links') + self.assertEqual(2, count_object_with_double_key(nodes, "name", "value-name", "otsi node name"), + 'Topology should contain 2 otsi nodes') + self.assertEqual(1, count_object_with_double_key(nodes, "name", "value-name", "dsr/odu node name"), + 'Topology should contain 1 dsr node') + self.assertEqual(1, count_object_with_double_key(links, "name", "value-name", "transitional link name"), + 'Topology should contain 1 transitional link') + self.assertEqual(1, count_object_with_double_key(links, "name", "value-name", "OMS link name"), + 'Topology should contain 1 oms link') + + def test_15_connect_xpdrc(self): + response = test_utils.mount_device("XPDR-C1", 'xpdrc') + self.assertEqual(response.status_code, requests.codes.created, test_utils.CODE_SHOULD_BE_201) + time.sleep(10) + + def test_16_connect_xprdc_n1_to_roadmc_pp1(self): response = test_utils.connect_xpdr_to_rdm_request("XPDR-C1", "1", "1", "ROADM-C1", "1", "SRG1-PP1-TXRX") self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200) @@ -120,7 +347,7 @@ class TransportTapitesting(unittest.TestCase): CREATED_SUCCESSFULLY) time.sleep(2) - def test_08_connect_roadmc_pp1_to_xpdrc_n1(self): + def test_17_connect_roadmc_pp1_to_xpdrc_n1(self): response = test_utils.connect_rdm_to_xpdr_request("XPDR-C1", "1", "1", "ROADM-C1", "1", "SRG1-PP1-TXRX") self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200) @@ -129,8 +356,68 @@ class TransportTapitesting(unittest.TestCase): CREATED_SUCCESSFULLY) time.sleep(2) - def test_09_connect_xprda_n2_to_roadma_pp2(self): - response = test_utils.connect_xpdr_to_rdm_request("XPDR-A1", "1", "2", + def test_18_check_tapi_topology_T100G(self): + url = "{}/operations/tapi-topology:get-topology-details" + data = { + "tapi-topology:input": { + "tapi-topology:topology-id-or-name": "Transponder 100GE" + } + } + response = test_utils.post_request(url, data) + self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200) + res = response.json() + self.assertEqual(2, len(res["output"]["topology"]["node"][0]["owned-node-edge-point"]), + 'Node should contain 2 owned-node-edge-points') + self.assertEqual("XPDR1-CLIENT1", + res["output"]["topology"]["node"][0]["owned-node-edge-point"][0]["name"][0]["value"], + 'name of owned-node-edge-points should be XPDR1-CLIENT1') + self.assertEqual("XPDR1-CLIENT1", + res["output"]["topology"]["node"][0]["owned-node-edge-point"][1]["name"][0]["value"], + 'name of owned-node-edge-points should be XPDR1-CLIENT1') + + def test_19_check_tapi_topology_T0(self): + url = "{}/operations/tapi-topology:get-topology-details" + data = { + "tapi-topology:input": { + "tapi-topology:topology-id-or-name": "T0 - Multi-layer topology" + } + } + response = test_utils.post_request(url, data) + self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200) + res = response.json() + nodes = res["output"]["topology"]["node"] + links = res["output"]["topology"]["link"] + self.assertEqual(5, len(nodes), 'Topology should contain 5 nodes') + self.assertEqual(4, len(links), 'Topology should contain 4 links') + self.assertEqual(3, count_object_with_double_key(nodes, "name", "value-name", "otsi node name"), + 'Topology should contain 3 otsi nodes') + self.assertEqual(2, count_object_with_double_key(nodes, "name", "value-name", "dsr/odu node name"), + 'Topology should contain 2 dsr nodes') + self.assertEqual(2, count_object_with_double_key(links, "name", "value-name", "transitional link name"), + 'Topology should contain 2 transitional links') + self.assertEqual(2, count_object_with_double_key(links, "name", "value-name", "OMS link name"), + 'Topology should contain 2 oms links') + + def test_20_connect_spdr_sa1(self): + response = test_utils.mount_device("SPDR-SA1", 'spdra') + self.assertEqual(response.status_code, requests.codes.created, test_utils.CODE_SHOULD_BE_201) + time.sleep(10) + # TODO replace connect and disconnect timers with test_utils.wait_until_log_contains + + def test_21_connect_spdr_sc1(self): + response = test_utils.mount_device("SPDR-SC1", 'spdrc') + self.assertEqual(response.status_code, requests.codes.created, test_utils.CODE_SHOULD_BE_201) + time.sleep(10) + # TODO replace connect and disconnect timers with test_utils.wait_until_log_contains + + def test_22_check_tapi_topology_T100G(self): + self.test_18_check_tapi_topology_T100G() + + def test_23_check_tapi_topology_T0(self): + self.test_19_check_tapi_topology_T0() + + def test_24_connect_sprda_n1_to_roadma_pp2(self): + response = test_utils.connect_xpdr_to_rdm_request("SPDR-SA1", "1", "1", "ROADM-A1", "1", "SRG1-PP2-TXRX") self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200) res = response.json() @@ -138,8 +425,8 @@ class TransportTapitesting(unittest.TestCase): CREATED_SUCCESSFULLY) time.sleep(2) - def test_10_connect_roadma_pp2_to_xpdra_n2(self): - response = test_utils.connect_rdm_to_xpdr_request("XPDR-A1", "1", "2", + def test_25_connect_roadma_pp2_to_spdra_n1(self): + response = test_utils.connect_rdm_to_xpdr_request("SPDR-SA1", "1", "1", "ROADM-A1", "1", "SRG1-PP2-TXRX") self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200) res = response.json() @@ -147,8 +434,8 @@ class TransportTapitesting(unittest.TestCase): CREATED_SUCCESSFULLY) time.sleep(2) - def test_11_connect_xprdc_n2_to_roadmc_pp2(self): - response = test_utils.connect_xpdr_to_rdm_request("XPDR-C1", "1", "2", + def test_26_connect_sprdc_n1_to_roadmc_pp2(self): + response = test_utils.connect_xpdr_to_rdm_request("SPDR-SC1", "1", "1", "ROADM-C1", "1", "SRG1-PP2-TXRX") self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200) res = response.json() @@ -156,8 +443,8 @@ class TransportTapitesting(unittest.TestCase): CREATED_SUCCESSFULLY) time.sleep(2) - def test_12_connect_roadmc_pp2_to_xpdrc_n2(self): - response = test_utils.connect_rdm_to_xpdr_request("XPDR-C1", "1", "2", + def test_27_connect_roadmc_pp2_to_spdrc_n1(self): + response = test_utils.connect_rdm_to_xpdr_request("SPDR-SC1", "1", "1", "ROADM-C1", "1", "SRG1-PP2-TXRX") self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200) res = response.json() @@ -165,98 +452,299 @@ class TransportTapitesting(unittest.TestCase): CREATED_SUCCESSFULLY) time.sleep(2) - def test_13_get_tapi_openroadm_topology(self): + def test_28_check_tapi_topology_T100G(self): + self.test_18_check_tapi_topology_T100G() + + def test_29_check_tapi_topology_T0(self): url = "{}/operations/tapi-topology:get-topology-details" data = { "tapi-topology:input": { - "tapi-topology:topology-id-or-name": "openroadm-topology" + "tapi-topology:topology-id-or-name": "T0 - Multi-layer topology" } } + response = test_utils.post_request(url, data) + self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200) + res = response.json() + nodes = res["output"]["topology"]["node"] + links = res["output"]["topology"]["link"] + self.assertEqual(9, len(nodes), 'Topology should contain 9 nodes') + self.assertEqual(8, len(links), 'Topology should contain 8 links') + self.assertEqual(5, count_object_with_double_key(nodes, "name", "value-name", "otsi node name"), + 'Topology should contain 5 otsi nodes') + self.assertEqual(4, count_object_with_double_key(nodes, "name", "value-name", "dsr/odu node name"), + 'Topology should contain 4 dsr nodes') + self.assertEqual(4, count_object_with_double_key(links, "name", "value-name", "transitional link name"), + 'Topology should contain 4 transitional links') + self.assertEqual(4, count_object_with_double_key(links, "name", "value-name", "OMS link name"), + 'Topology should contain 4 oms links') + + def test_30_add_oms_attributes(self): + # Config ROADMA-ROADMC oms-attributes + data = {"span": { + "clfi": "fiber1", + "auto-spanloss": "true", + "spanloss-base": 11.4, + "spanloss-current": 12, + "engineered-spanloss": 12.2, + "link-concatenation": [{ + "SRLG-Id": 0, + "fiber-type": "smf", + "SRLG-length": 100000, + "pmd": 0.5}]}} + response = test_utils.add_oms_attr_request("ROADM-A1-DEG2-DEG2-TTP-TXRXtoROADM-C1-DEG1-DEG1-TTP-TXRX", data) + self.assertEqual(response.status_code, requests.codes.created) + # Config ROADMC-ROADMA oms-attributes + data = {"span": { + "clfi": "fiber1", + "auto-spanloss": "true", + "spanloss-base": 11.4, + "spanloss-current": 12, + "engineered-spanloss": 12.2, + "link-concatenation": [{ + "SRLG-Id": 0, + "fiber-type": "smf", + "SRLG-length": 100000, + "pmd": 0.5}]}} + response = test_utils.add_oms_attr_request("ROADM-C1-DEG1-DEG1-TTP-TXRXtoROADM-A1-DEG2-DEG2-TTP-TXRX", data) + self.assertEqual(response.status_code, requests.codes.created) + + def test_31_create_OCH_OTU4_service(self): + response = test_utils.service_create_request(self.cr_serv_sample_data) + self.assertEqual(response.status_code, requests.codes.ok) + res = response.json() + self.assertIn('PCE calculation in progress', + res['output']['configuration-response-common']['response-message']) + time.sleep(self.WAITING) + def test_32_check_tapi_topology_T0(self): + url = "{}/operations/tapi-topology:get-topology-details" + data = { + "tapi-topology:input": { + "tapi-topology:topology-id-or-name": "T0 - Multi-layer topology" + } + } response = test_utils.post_request(url, data) self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200) res = response.json() - self.assertEqual(len(res["output"]["topology"]["node"]), 1, 'There should be 1 node') - self.assertEqual(len(res["output"]["topology"]["node"][0]["owned-node-edge-point"]), 4, - 'There should be 4 owned-node-edge-points') + nodes = res["output"]["topology"]["node"] + links = res["output"]["topology"]["link"] + self.assertEqual(9, len(nodes), 'Topology should contain 9 nodes') + self.assertEqual(9, len(links), 'Topology should contain 9 links') + self.assertEqual(4, count_object_with_double_key(links, "name", "value-name", "transitional link name"), + 'Topology should contain 4 transitional links') + self.assertEqual(4, count_object_with_double_key(links, "name", "value-name", "OMS link name"), + 'Topology should contain 4 oms links') + self.assertEqual(1, count_object_with_double_key(links, "name", "value-name", "otn link name"), + 'Topology should contain 1 otn link') + for link in links: + if link["name"][0]["value"] == "OTU4-SPDR-SA1-XPDR1-XPDR1-NETWORK1toSPDR-SC1-XPDR1-XPDR1-NETWORK1": + self.assertEqual(100000, link["available-capacity"]["total-size"]["value"], + 'OTU4 link should have an available capacity of 100 000 Mbps') + elif link["name"][0]["value-name"] == "transitional link name": + self.assertEqual(100, link["available-capacity"]["total-size"]["value"], + 'link should have an available capacity of 100 Gbps') + self.assertEqual(2, len(link["node-edge-point"]), 'link should have 2 neps') + + def test_33_create_ODU4_service(self): + self.cr_serv_sample_data["input"]["service-name"] = "service1-ODU4" + self.cr_serv_sample_data["input"]["service-a-end"]["service-format"] = "ODU" + del self.cr_serv_sample_data["input"]["service-a-end"]["otu-service-rate"] + self.cr_serv_sample_data["input"]["service-a-end"]["odu-service-rate"] = "org-openroadm-otn-common-types:ODU4" + self.cr_serv_sample_data["input"]["service-z-end"]["service-format"] = "ODU" + del self.cr_serv_sample_data["input"]["service-z-end"]["otu-service-rate"] + self.cr_serv_sample_data["input"]["service-z-end"]["odu-service-rate"] = "org-openroadm-otn-common-types:ODU4" + + response = test_utils.service_create_request(self.cr_serv_sample_data) + self.assertEqual(response.status_code, requests.codes.ok) + res = response.json() + self.assertIn('PCE calculation in progress', + res['output']['configuration-response-common']['response-message']) + time.sleep(self.WAITING) - def test_14_get_tapi_otn_topology(self): + def test_34_check_tapi_topology_T0(self): url = "{}/operations/tapi-topology:get-topology-details" data = { "tapi-topology:input": { - "tapi-topology:topology-id-or-name": "otn-topology" + "tapi-topology:topology-id-or-name": "T0 - Multi-layer topology" } } + response = test_utils.post_request(url, data) + self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200) + res = response.json() + nodes = res["output"]["topology"]["node"] + links = res["output"]["topology"]["link"] + self.assertEqual(9, len(nodes), 'Topology should contain 9 nodes') + self.assertEqual(10, len(links), 'Topology should contain 10 links') + self.assertEqual(4, count_object_with_double_key(links, "name", "value-name", "transitional link name"), + 'Topology should contain 4 transitional links') + self.assertEqual(4, count_object_with_double_key(links, "name", "value-name", "OMS link name"), + 'Topology should contain 4 oms links') + self.assertEqual(2, count_object_with_double_key(links, "name", "value-name", "otn link name"), + 'Topology should contain 2 otn links') + for link in links: + if link["name"][0]["value"] == "OTU4-SPDR-SA1-XPDR1-XPDR1-NETWORK1toSPDR-SC1-XPDR1-XPDR1-NETWORK1": + self.assertEqual(0, link["available-capacity"]["total-size"]["value"], + 'OTU4 link should have an available capacity of 0 Mbps') + elif link["name"][0]["value"] == "ODU4-SPDR-SA1-XPDR1-XPDR1-NETWORK1toSPDR-SC1-XPDR1-XPDR1-NETWORK1": + self.assertEqual(100000, link["available-capacity"]["total-size"]["value"], + 'ODU4 link should have an available capacity of 100 000 Mbps') + elif link["name"][0]["value-name"] == "transitional link name": + self.assertEqual(100, link["available-capacity"]["total-size"]["value"], + 'link should have an available capacity of 100 Gbps') + self.assertEqual(2, len(link["node-edge-point"]), 'link should have 2 neps') + + def test_35_connect_sprda_2_n2_to_roadma_pp3(self): + response = test_utils.connect_xpdr_to_rdm_request("SPDR-SA1", "2", "2", + "ROADM-A1", "1", "SRG1-PP3-TXRX") + self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200) + res = response.json() + self.assertIn('Xponder Roadm Link created successfully', res["output"]["result"], + CREATED_SUCCESSFULLY) + time.sleep(2) + def test_36_connect_roadma_pp3_to_spdra_2_n2(self): + response = test_utils.connect_rdm_to_xpdr_request("SPDR-SA1", "2", "2", + "ROADM-A1", "1", "SRG1-PP3-TXRX") + self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200) + res = response.json() + self.assertIn('Roadm Xponder links created successfully', res["output"]["result"], + CREATED_SUCCESSFULLY) + time.sleep(2) + + def test_37_check_tapi_topology_T0(self): + url = "{}/operations/tapi-topology:get-topology-details" + data = { + "tapi-topology:input": { + "tapi-topology:topology-id-or-name": "T0 - Multi-layer topology" + } + } response = test_utils.post_request(url, data) self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200) res = response.json() - self.assertEqual(len(res["output"]["topology"]["node"]), 4, 'There should be 4 nodes') - self.assertEqual(len(res["output"]["topology"]["link"]), 5, 'There should be 5 links') - link_to_check = res["output"]["topology"]["link"][0] - # get info from first link to do deeper check - node1_uid = link_to_check["node-edge-point"][0]["node-uuid"] - node2_uid = link_to_check["node-edge-point"][1]["node-uuid"] - node_edge_point1_uid = link_to_check["node-edge-point"][0]["node-edge-point-uuid"] - node_edge_point2_uid = link_to_check["node-edge-point"][1]["node-edge-point-uuid"] - # get node associated to link info nodes = res["output"]["topology"]["node"] - node1 = find_object_with_key(nodes, "uuid", node1_uid) - self.assertIsNotNone(node1, 'Node with uuid ' + node1_uid + ' should not be null') - node2 = find_object_with_key(nodes, "uuid", node2_uid) - self.assertIsNotNone(node2, 'Node with uuid ' + node2_uid + ' should not be null') - # get edge-point associated to nodes - node1_edge_point = node1["owned-node-edge-point"] - node2_edge_point = node2["owned-node-edge-point"] - node_edge_point1 = find_object_with_key(node1_edge_point, "uuid", node_edge_point1_uid) - self.assertIsNotNone(node_edge_point1, 'Node edge point with uuid ' + node_edge_point1_uid + 'should not be ' - 'null') - node_edge_point2 = find_object_with_key(node2_edge_point, "uuid", node_edge_point2_uid) - self.assertIsNotNone(node_edge_point2, 'Node edge point with uuid ' + node_edge_point2_uid + 'should not be ' - 'null') - self.assertEqual(len(node_edge_point1["name"]), 1, 'There should be 1 name') - self.assertEqual(len(node_edge_point2["name"]), 1, 'There should be 1 name') - if node_edge_point1["layer-protocol-name"] == 'ODU': - self.assertIn('NodeEdgePoint_N', node_edge_point1["name"][0]["value-name"], 'Value name should be ' - 'NodeEdgePoint_NX') - elif node_edge_point1["layer-protocol-name"] == 'PHOTONIC_MEDIA': - self.assertIn('iNodeEdgePoint_', node_edge_point1["name"][0]["value-name"], 'Value name should be ' - 'iNodeEdgePoint_X') - else: - self.fail('Wrong layer protocol name') - - if node_edge_point2["layer-protocol-name"] == 'ODU': - self.assertIn('NodeEdgePoint_N', node_edge_point2["name"][0]["value-name"], 'Value name should be ' - 'NodeEdgePoint_NX') - elif node_edge_point2["layer-protocol-name"] == 'PHOTONIC_MEDIA': - self.assertIn('iNodeEdgePoint_', node_edge_point2["name"][0]["value-name"], 'Value name should be ' - 'iNodeEdgePoint_X') - else: - self.fail('Wrong layer protocol name') - - def test_15_disconnect_xpdra(self): - response = test_utils.unmount_device("XPDR-A1") + links = res["output"]["topology"]["link"] + self.assertEqual(11, len(nodes), 'Topology should contain 11 nodes') + self.assertEqual(12, len(links), 'Topology should contain 12 links') + self.assertEqual(6, count_object_with_double_key(nodes, "name", "value-name", "otsi node name"), + 'Topology should contain 6 otsi nodes') + self.assertEqual(5, count_object_with_double_key(nodes, "name", "value-name", "dsr/odu node name"), + 'Topology should contain 5 dsr nodes') + self.assertEqual(5, count_object_with_double_key(links, "name", "value-name", "transitional link name"), + 'Topology should contain 5 transitional links') + self.assertEqual(5, count_object_with_double_key(links, "name", "value-name", "OMS link name"), + 'Topology should contain 5 oms links') + self.assertEqual(2, count_object_with_double_key(links, "name", "value-name", "otn link name"), + 'Topology should contain 2 otn links') + + def test_38_delete_ODU4_service(self): + response = test_utils.service_delete_request("service1-ODU4") + self.assertEqual(response.status_code, requests.codes.ok) + res = response.json() + self.assertIn('Renderer service delete in progress', + res['output']['configuration-response-common']['response-message']) + time.sleep(20) + + def test_39_delete_OCH_OTU4_service(self): + response = test_utils.service_delete_request("service1-OCH-OTU4") + self.assertEqual(response.status_code, requests.codes.ok) + res = response.json() + self.assertIn('Renderer service delete in progress', + res['output']['configuration-response-common']['response-message']) + time.sleep(20) + + def test_40_check_tapi_topology_T0(self): + url = "{}/operations/tapi-topology:get-topology-details" + data = { + "tapi-topology:input": { + "tapi-topology:topology-id-or-name": "T0 - Multi-layer topology" + } + } + response = test_utils.post_request(url, data) self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200) - time.sleep(10) + res = response.json() + nodes = res["output"]["topology"]["node"] + links = res["output"]["topology"]["link"] + self.assertEqual(11, len(nodes), 'Topology should contain 11 nodes') + self.assertEqual(10, len(links), 'Topology should contain 10 links') + self.assertEqual(0, count_object_with_double_key(links, "name", "value-name", "otn link name"), + 'Topology should contain 0 otn link') + + def test_41_disconnect_xponders_from_roadm(self): + url = "{}/config/ietf-network:networks/network/openroadm-topology/ietf-network-topology:link/" + response = test_utils.get_ordm_topo_request("") + self.assertEqual(response.status_code, requests.codes.ok) + res = response.json() + links = res['network'][0]['ietf-network-topology:link'] + for link in links: + if (link["org-openroadm-common-network:link-type"] == "XPONDER-OUTPUT" or + link["org-openroadm-common-network:link-type"] == "XPONDER-INPUT"): + link_name = link["link-id"] + response = test_utils.delete_request(url+link_name) + self.assertEqual(response.status_code, requests.codes.ok) + + def test_42_check_tapi_topology_T0(self): + url = "{}/operations/tapi-topology:get-topology-details" + data = { + "tapi-topology:input": { + "tapi-topology:topology-id-or-name": "T0 - Multi-layer topology" + } + } + response = test_utils.post_request(url, data) + self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200) + res = response.json() + nodes = res["output"]["topology"]["node"] + self.assertEqual(1, len(nodes), 'Topology should contain 1 node') + self.assertNotIn("link", res["output"]["topology"], 'Topology should contain no link') + self.assertEqual("ROADM-infra", res["output"]["topology"]["node"][0]["name"][0]["value"], + 'node name should be: ROADM-infra') - def test_16_disconnect_xpdrc(self): - response = test_utils.unmount_device("XPDR-C1") + def test_43_get_tapi_topology_T100G(self): + url = "{}/operations/tapi-topology:get-topology-details" + data = { + "tapi-topology:input": { + "tapi-topology:topology-id-or-name": "Transponder 100GE" + } + } + response = test_utils.post_request(url, data) self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200) - time.sleep(10) + res = response.json() + self.assertEqual(len(res["output"]["topology"]["node"]), 1, 'Topology should contain 1 node') + self.assertNotIn("link", res["output"]["topology"], 'Topology should contain no link') + self.assertNotIn("owned-node-edge-point", res["output"]["topology"]["node"][0], + 'Node should contain no owned-node-edge-points') - def test_17_disconnect_roadma(self): + def test_44_disconnect_roadma(self): response = test_utils.unmount_device("ROADM-A1") self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200) - time.sleep(10) + time.sleep(5) - def test_18_disconnect_roadmc(self): + def test_45_disconnect_roadmc(self): response = test_utils.unmount_device("ROADM-C1") self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200) - time.sleep(10) + time.sleep(5) + + def test_46_check_tapi_topos(self): + self.test_01_get_tapi_topology_T100G() + self.test_02_get_tapi_topology_T0() + + def test_47_disconnect_xpdra(self): + response = test_utils.unmount_device("XPDR-A1") + self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200) + time.sleep(5) - def test_19_disconnect_spdr_sa1(self): + def test_48_disconnect_xpdrc(self): + response = test_utils.unmount_device("XPDR-C1") + self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200) + time.sleep(5) + + def test_49_disconnect_spdr_sa1(self): response = test_utils.unmount_device("SPDR-SA1") self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200) + time.sleep(5) + + def test_50_disconnect_spdr_sc1(self): + response = test_utils.unmount_device("SPDR-SC1") + self.assertEqual(response.status_code, requests.codes.ok, test_utils.CODE_SHOULD_BE_200) def find_object_with_key(list_dicts, key, value): @@ -265,6 +753,13 @@ def find_object_with_key(list_dicts, key, value): return dict_ return None +def count_object_with_double_key(list_dicts, key1, key2, value): + nb = 0 + for dict in list_dicts: + if dict[key1][0][key2] == value: + nb += 1 + return nb + if __name__ == "__main__": - unittest.main(verbosity=2) + unittest.main(verbosity=2) \ No newline at end of file diff --git a/tox.ini b/tox.ini index d6acf6de9..5b567560c 100644 --- a/tox.ini +++ b/tox.ini @@ -54,7 +54,7 @@ commands = {py3,otnrenderer}: nosetests --with-xunit transportpce_tests/2.2.1/test_otn_renderer.py {py3,otnshrenderer}: nosetests --with-xunit transportpce_tests/2.2.1/test_otn_sh_renderer.py {py3,olm221}: nosetests --with-xunit transportpce_tests/2.2.1/test_olm.py - #{py3,tapi221}: nosetests --with-xunit transportpce_tests/2.2.1/test_tapi.py + {py3,tapi221}: nosetests --with-xunit transportpce_tests/2.2.1/test_tapi.py {py3,otnend2end}: nosetests --with-xunit transportpce_tests/2.2.1/test_otn_end2end.py {py3,end2end}: nosetests --with-xunit transportpce_tests/1.2.1/test_end2end.py {py3,end2end221}: nosetests --with-xunit transportpce_tests/2.2.1/test_end2end.py -- 2.36.6