add some Junit tests to pceOtnNode 99/91099/1
authorShaabanEltanany <shaaban.eltanany.ext@orange.com>
Wed, 13 May 2020 08:59:28 +0000 (10:59 +0200)
committerGilles Thouenon <gilles.thouenon@orange.com>
Fri, 10 Jul 2020 12:41:39 +0000 (14:41 +0200)
JIRA: TRNSPRTPCE-209
Signed-off-by: ShaabanEltanany <shaaban.eltanany.ext@orange.com>
Change-Id: I83cf44ec16eebd8d142e5c78b3fde400f4647482

pce/src/test/java/org/opendaylight/transportpce/pce/networkanalyzer/PceOtnNodeTest.java

index 052d44bdb478477ecbfeb9bccf164c95e9a11f72..65ec2b9eb9d2eec4ef3504b0b7b431a308bc3bc1 100644 (file)
@@ -12,6 +12,7 @@ import com.google.common.collect.ImmutableList;
 import java.util.ArrayList;
 import java.util.Collections;
 import java.util.List;
+import org.junit.Assert;
 import org.junit.Before;
 import org.junit.Test;
 import org.opendaylight.transportpce.common.NetworkUtils;
@@ -33,6 +34,15 @@ import org.opendaylight.yang.gen.v1.http.org.openroadm.network.topology.rev18113
 import org.opendaylight.yang.gen.v1.http.org.openroadm.network.topology.rev181130.networks.network.node.termination.point.XpdrPortAttributesBuilder;
 import org.opendaylight.yang.gen.v1.http.org.openroadm.network.types.rev181130.OpenroadmNodeType;
 import org.opendaylight.yang.gen.v1.http.org.openroadm.network.types.rev181130.OpenroadmTpType;
+import org.opendaylight.yang.gen.v1.http.org.openroadm.network.types.rev181130.xpdr.tp.supported.interfaces.SupportedInterfaceCapability;
+import org.opendaylight.yang.gen.v1.http.org.openroadm.network.types.rev181130.xpdr.tp.supported.interfaces.SupportedInterfaceCapabilityBuilder;
+import org.opendaylight.yang.gen.v1.http.org.openroadm.otn.network.topology.rev181130.networks.network.node.termination.point.TpSupportedInterfaces;
+import org.opendaylight.yang.gen.v1.http.org.openroadm.otn.network.topology.rev181130.networks.network.node.termination.point.TpSupportedInterfacesBuilder;
+import org.opendaylight.yang.gen.v1.http.org.openroadm.otn.network.topology.rev181130.networks.network.node.termination.point.XpdrTpPortConnectionAttributesBuilder;
+import org.opendaylight.yang.gen.v1.http.org.openroadm.port.types.rev181130.If100GEODU4;
+import org.opendaylight.yang.gen.v1.http.org.openroadm.port.types.rev181130.If10GEODU2e;
+import org.opendaylight.yang.gen.v1.http.org.openroadm.port.types.rev181130.If1GEODU0;
+import org.opendaylight.yang.gen.v1.http.org.openroadm.port.types.rev181130.IfOCHOTU4ODU4;
 import org.opendaylight.yang.gen.v1.http.org.openroadm.service.format.rev190531.ServiceFormat;
 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.network.rev180226.NetworkId;
 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.network.rev180226.NodeId;
@@ -48,6 +58,7 @@ import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.network.top
 import org.opendaylight.yangtools.yang.common.Uint32;
 
 
+
 public class PceOtnNodeTest extends AbstractTest {
 
     private PceOtnNode pceOtnNode;
@@ -55,17 +66,65 @@ public class PceOtnNodeTest extends AbstractTest {
 
     @Before
     public void setUp() {
-        NodeBuilder node1Builder = getNodeBuilder(geSupportingNodes(), OpenroadmTpType.SRGTXRXPP);
-        node = node1Builder.build();
-        pceOtnNode =
-                new PceOtnNode(node, OpenroadmNodeType.ROADM,
-                        new NodeId("optical"), ServiceFormat.OMS.getName(), "test");
+        node = getNodeBuilder(geSupportingNodes(), OpenroadmTpType.XPONDERNETWORK).build();
+    }
+
+    @Test
+    public void testInitXndrTpsODU4() {
+        pceOtnNode = new PceOtnNode(node, OpenroadmNodeType.MUXPDR,
+                new NodeId("optical"), ServiceFormat.OMS.getName(), "ODU4");
+        pceOtnNode.initXndrTps("AZ");
+        pceOtnNode.checkAvailableTribPort();
+        pceOtnNode.checkAvailableTribSlot();
+        Assert.assertTrue(pceOtnNode.isValid());
+        Assert.assertFalse(pceOtnNode.checkWL(5L));
+        Assert.assertNotNull(pceOtnNode.getAvailableTribPorts());
+    }
 
+    @Test
+    public void testInitXndrTps10GE() {
+        pceOtnNode = new PceOtnNode(node, OpenroadmNodeType.MUXPDR,
+                new NodeId("optical"), ServiceFormat.OMS.getName(), "10GE");
+        pceOtnNode.initXndrTps("mode");
+        pceOtnNode.checkAvailableTribPort();
+        pceOtnNode.checkAvailableTribSlot();
+        Assert.assertFalse(pceOtnNode.isValid());
+    }
+
+    @Test
+    public void testInitXndrTps10GXponderClient1() {
+        node = getNodeBuilder(geSupportingNodes(), OpenroadmTpType.XPONDERCLIENT).build();
+        pceOtnNode = new PceOtnNode(node, OpenroadmNodeType.ROADM,
+                new NodeId("optical"), ServiceFormat.OMS.getName(), "10GE");
+        pceOtnNode.initXndrTps("mode");
+        pceOtnNode.checkAvailableTribPort();
+        pceOtnNode.checkAvailableTribSlot();
+        Assert.assertFalse(pceOtnNode.isValid());
     }
 
     @Test
-    public void test() {
+    public void testInitXndrTps1GXponderClient() {
+        node = getNodeBuilder(geSupportingNodes(), OpenroadmTpType.XPONDERCLIENT).build();
+        pceOtnNode = new PceOtnNode(node, OpenroadmNodeType.MUXPDR,
+                new NodeId("optical"), ServiceFormat.OMS.getName(), "1GE");
         pceOtnNode.initXndrTps("mode");
+        pceOtnNode.checkAvailableTribPort();
+        pceOtnNode.checkAvailableTribSlot();
+        Assert.assertFalse(pceOtnNode.isValid());
+    }
+
+    @Test
+    public void testInitXndrTps10GXponderClient() {
+        pceOtnNode = new PceOtnNode(node, OpenroadmNodeType.MUXPDR,
+                new NodeId("optical"), ServiceFormat.OMS.getName(), "10GE");
+        pceOtnNode.validateXponder("optical", "sl");
+        pceOtnNode.validateXponder("not optical", "sl");
+        pceOtnNode.initXndrTps("AZ");
+        pceOtnNode.checkAvailableTribPort();
+        pceOtnNode.checkAvailableTribSlot();
+        Assert.assertFalse(pceOtnNode.isValid());
+        Assert.assertFalse(pceOtnNode.checkTP("tp"));
+
     }
 
     private List<SupportingNode> geSupportingNodes() {
@@ -87,11 +146,17 @@ public class PceOtnNodeTest extends AbstractTest {
     private NodeBuilder getNodeBuilder(List<SupportingNode> supportingNodes1, OpenroadmTpType openroadmTpType) {
 
         TerminationPoint1Builder tp1Bldr = getTerminationPoint1Builder(openroadmTpType);
-        TerminationPointBuilder xpdrTpBldr = getTerminationPointBuilder();
+        TerminationPointBuilder xpdrTpBldr = getTerminationPointBuilder(openroadmTpType);
         xpdrTpBldr.addAugmentation(TerminationPoint1.class, tp1Bldr.build());
+
+        xpdrTpBldr.addAugmentation(
+                org.opendaylight.yang.gen.v1.http.org.openroadm.common.network.rev181130
+                        .TerminationPoint1.class,
+                createAnother2TerminationPoint(openroadmTpType).build());
         xpdrTpBldr.addAugmentation(
                 org.opendaylight.yang.gen.v1.http.org.openroadm.network.topology.rev181130.TerminationPoint1.class,
-                createAnotherTerminationPoint().build());
+                createAnotherTerminationPoint(openroadmTpType).build());
+
         org.opendaylight.yang.gen.v1.http.org.openroadm.network.topology.rev181130.Node1 node1 = getNode1();
         org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.network.topology.rev180226.Node1 node1Rev180226 =
                 new Node1Builder()
@@ -99,25 +164,38 @@ public class PceOtnNodeTest extends AbstractTest {
                         .build();
 
 
+        org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.network.topology.rev180226.Node1 nodeIetf =
+                new org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.network.topology.rev180226
+                        .Node1Builder()
+                        .setTerminationPoint(ImmutableList.of(xpdrTpBldr.build()))
+                        .build();
+
         return new NodeBuilder()
                 .setNodeId(new NodeId("node_test"))
                 .withKey(new NodeKey(new NodeId("node 1")))
                 .addAugmentation(
                         Node1.class, node1Rev180226)
                 .addAugmentation(
-                        org.opendaylight.yang.gen.v1.http.org.openroadm.network.topology.rev181130.Node1.class,
+                        org.opendaylight
+                                .yang.gen.v1.http.org.openroadm.network.topology.rev181130.Node1.class,
                         node1)
+                .addAugmentation(
+                        org.opendaylight
+                                .yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.network.topology.rev180226.Node1.class,
+                        nodeIetf
+                )
                 .setSupportingNode(supportingNodes1);
     }
 
     private NodeBuilder getNodeBuilderEmpty(List<SupportingNode> supportingNodes1, OpenroadmTpType openroadmTpType) {
 
         TerminationPoint1Builder tp1Bldr = getTerminationPoint1Builder(openroadmTpType);
-        TerminationPointBuilder xpdrTpBldr = getTerminationPointBuilder();
+        TerminationPointBuilder xpdrTpBldr = getTerminationPointBuilder(openroadmTpType);
         xpdrTpBldr.addAugmentation(TerminationPoint1.class, tp1Bldr.build());
         xpdrTpBldr.addAugmentation(
-                org.opendaylight.yang.gen.v1.http.org.openroadm.network.topology.rev181130.TerminationPoint1.class,
-                createAnotherTerminationPoint().build());
+                org.opendaylight.yang.gen.v1.http.org.openroadm.common.network.rev181130
+                        .TerminationPoint1.class,
+                createAnotherTerminationPoint(openroadmTpType).build());
 
         org.opendaylight.yang.gen.v1.http.org.openroadm.network.topology.rev181130.Node1 node1 = getNode1Empty();
         org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.network.topology.rev180226.Node1 node1Rev180226 =
@@ -180,9 +258,13 @@ public class PceOtnNodeTest extends AbstractTest {
         return new SrgAttributesBuilder().setAvailableWavelengths(waveList).build();
     }
 
-    private TerminationPointBuilder getTerminationPointBuilder() {
+    private TerminationPointBuilder getTerminationPointBuilder(OpenroadmTpType openroadmTpType) {
         return new TerminationPointBuilder()
-                .setTpId(new TpId("2"));
+                .setTpId(new TpId("2"))
+                .addAugmentation(
+                        org.opendaylight.yang.gen.v1.http.org.openroadm.otn.network.topology.rev181130
+                                .TerminationPoint1.class,
+                        createOTNTerminationPoint(openroadmTpType).build());
     }
 
     private TerminationPoint1Builder getTerminationPoint1Builder(OpenroadmTpType openroadmTpType) {
@@ -193,10 +275,12 @@ public class PceOtnNodeTest extends AbstractTest {
     }
 
     private org.opendaylight.yang.gen
-            .v1.http.org.openroadm.network.topology.rev181130.TerminationPoint1Builder createAnotherTerminationPoint() {
+            .v1.http.org.openroadm.network.topology.rev181130.TerminationPoint1Builder createAnotherTerminationPoint(
+            OpenroadmTpType openroadmTpType
+    ) {
         return new org.opendaylight
                 .yang.gen.v1.http.org.openroadm.network.topology.rev181130.TerminationPoint1Builder()
-                .setTpType(OpenroadmTpType.XPONDERNETWORK)
+                .setTpType(openroadmTpType)
                 .setCtpAttributes((new CtpAttributesBuilder()).setUsedWavelengths(new ArrayList<>()).build())
                 .setCpAttributes((new CpAttributesBuilder()).setUsedWavelengths(new ArrayList<>()).build())
                 .setTxTtpAttributes((new TxTtpAttributesBuilder()).setUsedWavelengths(new ArrayList<>()).build())
@@ -208,6 +292,49 @@ public class PceOtnNodeTest extends AbstractTest {
                         .setTailEquipmentId("destNode" + "--" + "destTp").build());
     }
 
+    private org.opendaylight.yang.gen.v1.http.org.openroadm.otn.network.topology.rev181130
+            .TerminationPoint1Builder createOTNTerminationPoint(OpenroadmTpType openroadmTpType) {
+
+        SupportedInterfaceCapability supIfCapa = new SupportedInterfaceCapabilityBuilder()
+                .setIfCapType(IfOCHOTU4ODU4.class)
+                .build();
+
+        SupportedInterfaceCapability supIfCapa1 = new SupportedInterfaceCapabilityBuilder()
+                .setIfCapType(If100GEODU4.class)
+                .build();
+        SupportedInterfaceCapability supIfCapa2 = new SupportedInterfaceCapabilityBuilder()
+                .setIfCapType(If10GEODU2e.class)
+                .build();
+        SupportedInterfaceCapability supIfCapa3 = new SupportedInterfaceCapabilityBuilder()
+                .setIfCapType(If1GEODU0.class)
+                .build();
+
+        List<SupportedInterfaceCapability> supIfCapaList = new ArrayList<>();
+        supIfCapaList.add(supIfCapa);
+        supIfCapaList.add(supIfCapa1);
+        supIfCapaList.add(supIfCapa2);
+        supIfCapaList.add(supIfCapa3);
+
+        TpSupportedInterfaces tpSupIf = new TpSupportedInterfacesBuilder()
+                .setSupportedInterfaceCapability(supIfCapaList)
+                .build();
+
+        XpdrTpPortConnectionAttributesBuilder xtpcaBldr = new XpdrTpPortConnectionAttributesBuilder();
+
+        return new org.opendaylight.yang.gen.v1.http.org.openroadm.otn.network.topology.rev181130
+                .TerminationPoint1Builder()
+                .setTpType(openroadmTpType)
+                .setTpSupportedInterfaces(tpSupIf)
+                .setXpdrTpPortConnectionAttributes(xtpcaBldr.build());
+    }
+
+    private org.opendaylight.yang.gen.v1.http.org.openroadm.common.network.rev181130
+            .TerminationPoint1Builder createAnother2TerminationPoint(OpenroadmTpType openroadmTpType) {
+        return new org.opendaylight.yang.gen.v1.http.org.openroadm.common.network.rev181130
+                .TerminationPoint1Builder()
+                .setTpType(openroadmTpType);
+    }
+
     private static List<org.opendaylight.yang.gen
             .v1.http.org.openroadm.srg.rev181130.srg.node.attributes.AvailableWavelengths> create96AvalWaveSrg() {