06f7565d4d4bd937d1d20d160e1bd61896b4b7a9
[transportpce.git] / pce / src / test / java / org / opendaylight / transportpce / pce / networkanalyzer / PceOpticalNodeTest.java
1 /*
2  * Copyright © 2020 Orange, Inc. and others.  All rights reserved.
3  *
4  * This program and the accompanying materials are made available under the
5  * terms of the Eclipse Public License v1.0 which accompanies this distribution,
6  * and is available at http://www.eclipse.org/legal/epl-v10.html
7  */
8
9 package org.opendaylight.transportpce.pce.networkanalyzer;
10
11 import java.math.BigDecimal;
12 import java.util.Arrays;
13 import java.util.BitSet;
14 import java.util.HashMap;
15 import java.util.Map;
16 import org.junit.Assert;
17 import org.junit.Before;
18 import org.junit.Test;
19 import org.opendaylight.transportpce.common.NetworkUtils;
20 import org.opendaylight.transportpce.common.StringConstants;
21 import org.opendaylight.transportpce.common.fixedflex.GridConstant;
22 import org.opendaylight.transportpce.common.fixedflex.GridUtils;
23 import org.opendaylight.transportpce.test.AbstractTest;
24 import org.opendaylight.yang.gen.v1.http.org.openroadm.common.network.rev200529.TerminationPoint1Builder;
25 import org.opendaylight.yang.gen.v1.http.org.openroadm.common.optical.channel.types.rev200529.FrequencyGHz;
26 import org.opendaylight.yang.gen.v1.http.org.openroadm.common.optical.channel.types.rev200529.FrequencyTHz;
27 import org.opendaylight.yang.gen.v1.http.org.openroadm.network.topology.rev200529.networks.network.node.DegreeAttributes;
28 import org.opendaylight.yang.gen.v1.http.org.openroadm.network.topology.rev200529.networks.network.node.DegreeAttributesBuilder;
29 import org.opendaylight.yang.gen.v1.http.org.openroadm.network.topology.rev200529.networks.network.node.SrgAttributes;
30 import org.opendaylight.yang.gen.v1.http.org.openroadm.network.topology.rev200529.networks.network.node.SrgAttributesBuilder;
31 import org.opendaylight.yang.gen.v1.http.org.openroadm.network.topology.rev200529.networks.network.node.termination.point.CpAttributesBuilder;
32 import org.opendaylight.yang.gen.v1.http.org.openroadm.network.topology.rev200529.networks.network.node.termination.point.CtpAttributesBuilder;
33 import org.opendaylight.yang.gen.v1.http.org.openroadm.network.topology.rev200529.networks.network.node.termination.point.PpAttributesBuilder;
34 import org.opendaylight.yang.gen.v1.http.org.openroadm.network.topology.rev200529.networks.network.node.termination.point.RxTtpAttributesBuilder;
35 import org.opendaylight.yang.gen.v1.http.org.openroadm.network.topology.rev200529.networks.network.node.termination.point.TxTtpAttributesBuilder;
36 import org.opendaylight.yang.gen.v1.http.org.openroadm.network.topology.rev200529.networks.network.node.termination.point.XpdrClientAttributesBuilder;
37 import org.opendaylight.yang.gen.v1.http.org.openroadm.network.topology.rev200529.networks.network.node.termination.point.XpdrNetworkAttributesBuilder;
38 import org.opendaylight.yang.gen.v1.http.org.openroadm.network.topology.rev200529.networks.network.node.termination.point.XpdrPortAttributesBuilder;
39 import org.opendaylight.yang.gen.v1.http.org.openroadm.network.types.rev200529.OpenroadmNodeType;
40 import org.opendaylight.yang.gen.v1.http.org.openroadm.network.types.rev200529.OpenroadmTpType;
41 import org.opendaylight.yang.gen.v1.http.org.openroadm.network.types.rev200529.available.freq.map.AvailFreqMaps;
42 import org.opendaylight.yang.gen.v1.http.org.openroadm.network.types.rev200529.available.freq.map.AvailFreqMapsBuilder;
43 import org.opendaylight.yang.gen.v1.http.org.openroadm.network.types.rev200529.available.freq.map.AvailFreqMapsKey;
44 import org.opendaylight.yang.gen.v1.http.org.openroadm.service.format.rev190531.ServiceFormat;
45 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.network.rev180226.NetworkId;
46 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.network.rev180226.NodeId;
47 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.network.rev180226.networks.network.Node;
48 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.network.rev180226.networks.network.NodeBuilder;
49 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.network.rev180226.networks.network.NodeKey;
50 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.network.rev180226.networks.network.node.SupportingNode;
51 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.network.rev180226.networks.network.node.SupportingNodeBuilder;
52 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.network.rev180226.networks.network.node.SupportingNodeKey;
53 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.network.topology.rev180226.Node1Builder;
54 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.network.topology.rev180226.TpId;
55 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.network.topology.rev180226.networks.network.node.TerminationPoint;
56 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.network.topology.rev180226.networks.network.node.TerminationPointBuilder;
57 import org.opendaylight.yangtools.yang.common.Uint16;
58
59 public class PceOpticalNodeTest extends AbstractTest {
60
61     private PceOpticalNode pceOpticalNode;
62     private Node node;
63     private BitSet usedBitSet = new BitSet(8);
64     private BitSet availableBitSet = new BitSet(8);
65
66     @Before
67     public void setUp() {
68         NodeBuilder node1Builder = getNodeBuilder(geSupportingNodes(), OpenroadmTpType.SRGTXRXPP);
69         node = node1Builder.setNodeId(new NodeId("test")).build();
70         availableBitSet.set(0,8);
71     }
72
73     @Test
74     public void isValidTest() {
75         OpenroadmNodeType nodeType = OpenroadmNodeType.ROADM;
76         pceOpticalNode = new PceOpticalNode(node, nodeType, StringConstants.OPENROADM_DEVICE_VERSION_2_2_1,
77                 GridConstant.SLOT_WIDTH_50);
78         Assert.assertTrue(pceOpticalNode.isValid());
79     }
80
81     @Test
82     public void testInitSrgTps() {
83
84         pceOpticalNode = new PceOpticalNode(node,
85                 OpenroadmNodeType.ROADM, StringConstants.OPENROADM_DEVICE_VERSION_2_2_1, GridConstant.SLOT_WIDTH_50);
86         pceOpticalNode.initSrgTps();
87         pceOpticalNode.initXndrTps(ServiceFormat.OMS);
88         pceOpticalNode.initFrequenciesBitSet();
89         Assert.assertFalse(pceOpticalNode.isValid());
90         Assert.assertNull(pceOpticalNode.getBitSetData());
91         Assert.assertTrue(pceOpticalNode.checkTP("testTP"));
92         Assert.assertNull(pceOpticalNode.getAvailableTribPorts());
93         Assert.assertNull(pceOpticalNode.getAvailableTribPorts());
94         Assert.assertNull(pceOpticalNode.getXpdrClient("test"));
95     }
96
97     @Test
98     public void testInitXndrTpSrgTypes() {
99         NodeBuilder node1Builder = getNodeBuilder(geSupportingNodes(), OpenroadmTpType.XPONDERNETWORK);
100         Node specificNode = node1Builder.build();
101         pceOpticalNode = new PceOpticalNode(specificNode,
102                 OpenroadmNodeType.SRG, StringConstants.OPENROADM_DEVICE_VERSION_2_2_1, GridConstant.SLOT_WIDTH_50);
103         pceOpticalNode.initFrequenciesBitSet();
104         Assert.assertTrue(pceOpticalNode.isValid());
105         Assert.assertEquals(availableBitSet, pceOpticalNode.getBitSetData().get(88,96));
106         Assert.assertTrue(pceOpticalNode.checkTP("testTP"));
107     }
108
109     @Test
110     public void testInitXndrTpDegTypes() {
111         pceOpticalNode = new PceOpticalNode(node,
112                 OpenroadmNodeType.DEGREE, StringConstants.OPENROADM_DEVICE_VERSION_2_2_1, GridConstant.SLOT_WIDTH_50);
113         pceOpticalNode.initFrequenciesBitSet();
114         Assert.assertTrue(pceOpticalNode.isValid());
115         Assert.assertEquals(usedBitSet,pceOpticalNode.getBitSetData().get(88,96));
116         Assert.assertTrue(pceOpticalNode.checkTP("testTP"));
117     }
118
119     @Test
120     public void testInitXndrTpXpondrTypes() {
121         pceOpticalNode = new PceOpticalNode(node,
122                 OpenroadmNodeType.XPONDER, StringConstants.OPENROADM_DEVICE_VERSION_2_2_1, GridConstant.SLOT_WIDTH_50);
123         pceOpticalNode.initFrequenciesBitSet();
124         Assert.assertTrue(pceOpticalNode.isValid());
125         Assert.assertEquals(availableBitSet, pceOpticalNode.getBitSetData().get(88,96));
126         Assert.assertTrue(pceOpticalNode.checkTP("testTP"));
127     }
128
129     @Test
130     public void testinitFrequenciesBitSet() {
131         pceOpticalNode = new PceOpticalNode(node,
132                 OpenroadmNodeType.ROADM, StringConstants.OPENROADM_DEVICE_VERSION_2_2_1, GridConstant.SLOT_WIDTH_50);
133         pceOpticalNode.initXndrTps(ServiceFormat.OMS);
134         pceOpticalNode.initFrequenciesBitSet();
135         Assert.assertFalse(pceOpticalNode.isValid());
136         Assert.assertNull(pceOpticalNode.getBitSetData());
137         Assert.assertTrue(pceOpticalNode.checkTP("testTP"));
138     }
139
140     @Test
141     public void testGetRdmSrgClient() {
142         pceOpticalNode = new PceOpticalNode(node,
143                 OpenroadmNodeType.ROADM, StringConstants.OPENROADM_DEVICE_VERSION_2_2_1, GridConstant.SLOT_WIDTH_50);
144         pceOpticalNode.initSrgTps();
145         Assert.assertNull(pceOpticalNode.getRdmSrgClient("7"));
146         Assert.assertFalse(pceOpticalNode.isValid());
147         Assert.assertNull(pceOpticalNode.getBitSetData());
148         Assert.assertTrue(pceOpticalNode.checkTP("testTP"));
149     }
150
151     @Test
152     public void testGetRdmSrgClientEmpty() {
153         NodeBuilder node1Builder = getNodeBuilderEmpty(geSupportingNodes(), OpenroadmTpType.SRGTXRXPP);
154         Node specificNode = node1Builder.setNodeId(new NodeId("test")).build();
155         pceOpticalNode = new PceOpticalNode(specificNode,
156                 OpenroadmNodeType.ROADM, StringConstants.OPENROADM_DEVICE_VERSION_2_2_1, GridConstant.SLOT_WIDTH_50);
157         pceOpticalNode.initSrgTps();
158         pceOpticalNode.initFrequenciesBitSet();
159         pceOpticalNode.initXndrTps(ServiceFormat.OMS);
160         Assert.assertNull(pceOpticalNode.getRdmSrgClient("7"));
161         Assert.assertFalse(pceOpticalNode.isValid());
162         Assert.assertNull(pceOpticalNode.getBitSetData());
163         Assert.assertTrue(pceOpticalNode.checkTP("testTP"));
164     }
165
166     @Test
167     public void testGetRdmSrgClientDeg() {
168         pceOpticalNode = new PceOpticalNode(node,
169                 OpenroadmNodeType.DEGREE, StringConstants.OPENROADM_DEVICE_VERSION_2_2_1, GridConstant.SLOT_WIDTH_50);
170         pceOpticalNode.initSrgTps();
171         Assert.assertNull(pceOpticalNode.getRdmSrgClient("7"));
172         Assert.assertFalse(pceOpticalNode.isValid());
173         Assert.assertNull(pceOpticalNode.getBitSetData());
174         Assert.assertTrue(pceOpticalNode.checkTP("testTP"));
175     }
176
177     @Test
178     public void testGetRdmSrgClientsrgtxcp() {
179         NodeBuilder node1Builder = getNodeBuilder(geSupportingNodes(), OpenroadmTpType.SRGTXCP);
180         Node specificNode = node1Builder.build();
181         pceOpticalNode = new PceOpticalNode(specificNode,
182                 OpenroadmNodeType.ROADM, StringConstants.OPENROADM_DEVICE_VERSION_2_2_1, GridConstant.SLOT_WIDTH_50);
183         pceOpticalNode.initSrgTps();
184         Assert.assertFalse(pceOpticalNode.isValid());
185         Assert.assertNull(pceOpticalNode.getBitSetData());
186         Assert.assertTrue(pceOpticalNode.checkTP("testTP"));
187         Assert.assertNull(pceOpticalNode.getRdmSrgClient("5"));
188     }
189
190     @Test
191     public void testGetRdmSrgClientDegreerxtpp() {
192         NodeBuilder node1Builder = getNodeBuilder(geSupportingNodes(), OpenroadmTpType.DEGREERXTTP);
193         node = node1Builder.build();
194         pceOpticalNode = new PceOpticalNode(node,
195                 OpenroadmNodeType.ROADM, StringConstants.OPENROADM_DEVICE_VERSION_2_2_1, GridConstant.SLOT_WIDTH_50);
196         pceOpticalNode.initSrgTps();
197         Assert.assertNull(pceOpticalNode.getRdmSrgClient("2"));
198         Assert.assertFalse(pceOpticalNode.isValid());
199         Assert.assertNull(pceOpticalNode.getBitSetData());
200         Assert.assertTrue(pceOpticalNode.checkTP("testTP"));
201     }
202
203     private Map<SupportingNodeKey,SupportingNode> geSupportingNodes() {
204         Map<SupportingNodeKey,SupportingNode> supportingNodes1 = new HashMap<>();
205         SupportingNode supportingNode1 = new SupportingNodeBuilder()
206                 .setNodeRef(new NodeId("node 1"))
207                 .setNetworkRef(new NetworkId(NetworkUtils.CLLI_NETWORK_ID))
208                 .build();
209         supportingNodes1
210                 .put(supportingNode1.key(),supportingNode1);
211
212         SupportingNode supportingNode2 = new SupportingNodeBuilder()
213                 .setNodeRef(new NodeId("node 2"))
214                 .setNetworkRef(new NetworkId(NetworkUtils.UNDERLAY_NETWORK_ID))
215                 .build();
216         supportingNodes1
217                 .put(supportingNode2.key(),supportingNode2);
218         return supportingNodes1;
219     }
220
221     private NodeBuilder getNodeBuilder(Map<SupportingNodeKey,SupportingNode> supportingNodes1,
222             OpenroadmTpType openroadmTpType) {
223
224         TerminationPoint1Builder tp1Bldr = getTerminationPoint1Builder(openroadmTpType);
225         TerminationPointBuilder xpdrTpBldr = getTerminationPointBuilder();
226         xpdrTpBldr.addAugmentation(tp1Bldr.build());
227         xpdrTpBldr.addAugmentation(createAnotherTerminationPoint().build());
228         org.opendaylight.yang.gen.v1.http.org.openroadm.network.topology.rev200529.Node1 node1 = getNode1();
229         TerminationPoint xpdr = xpdrTpBldr.build();
230         org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.network.topology.rev180226.Node1 node1Rev180226 =
231                 new Node1Builder()
232                         .setTerminationPoint(Map.of(xpdr.key(),xpdr))
233                         .build();
234
235
236         return new NodeBuilder()
237                 .setNodeId(new NodeId("node_test"))
238                 .withKey(new NodeKey(new NodeId("node 1")))
239                 .addAugmentation(node1Rev180226)
240                 .addAugmentation(node1)
241                 .setSupportingNode(supportingNodes1);
242     }
243
244     private NodeBuilder getNodeBuilderEmpty(Map<SupportingNodeKey,SupportingNode>  supportingNodes1,
245             OpenroadmTpType openroadmTpType) {
246
247         TerminationPoint1Builder tp1Bldr = getTerminationPoint1Builder(openroadmTpType);
248         TerminationPointBuilder xpdrTpBldr = getTerminationPointBuilder();
249         xpdrTpBldr.addAugmentation(tp1Bldr.build());
250         xpdrTpBldr.addAugmentation(createAnotherTerminationPoint().build());
251
252         org.opendaylight.yang.gen.v1.http.org.openroadm.network.topology.rev200529.Node1 node1 = getNode1Empty();
253         TerminationPoint xpdr = xpdrTpBldr.build();
254         org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.network.topology.rev180226.Node1 node1Rev180226 =
255                 new Node1Builder()
256                         .setTerminationPoint(Map.of(xpdr.key(),xpdr))
257                         .build();
258
259
260         return new NodeBuilder()
261                 .setNodeId(new NodeId("node_test"))
262                 .withKey(new NodeKey(new NodeId("node 1")))
263                 .addAugmentation(node1Rev180226)
264                 .addAugmentation(node1)
265                 .setSupportingNode(supportingNodes1);
266     }
267
268     private org.opendaylight
269             .yang.gen.v1.http.org.openroadm.network.topology.rev200529.Node1 getNode1() {
270         return new org.opendaylight.yang.gen.v1.http.org.openroadm.network.topology.rev200529.Node1Builder()
271                 .setSrgAttributes(getSrgAttributes())
272                 .setDegreeAttributes(getDegAttributes())
273                 .build();
274     }
275
276     private org.opendaylight
277             .yang.gen.v1.http.org.openroadm.network.topology.rev200529.Node1 getNode1Empty() {
278         return new org.opendaylight.yang.gen.v1.http.org.openroadm.network.topology.rev200529.Node1Builder()
279                 .setSrgAttributes(getEmptySrgAttributes())
280                 .setDegreeAttributes(getEmptyDegAttributes())
281                 .build();
282     }
283
284     private DegreeAttributes getDegAttributes() {
285         byte[] byteArray = new byte[GridConstant.NB_OCTECTS];
286         Arrays.fill(byteArray, (byte) GridConstant.USED_SLOT_VALUE);
287         byteArray[7] = (byte) GridConstant.AVAILABLE_SLOT_VALUE;
288         Map<AvailFreqMapsKey, AvailFreqMaps> waveMap = new HashMap<>();
289         AvailFreqMaps availFreqMaps = new AvailFreqMapsBuilder().setMapName(GridConstant.C_BAND)
290                 .setFreqMapGranularity(new FrequencyGHz(BigDecimal.valueOf(GridConstant.GRANULARITY)))
291                 .setStartEdgeFreq(new FrequencyTHz(BigDecimal.valueOf(GridConstant.START_EDGE_FREQUENCY)))
292                 .setEffectiveBits(Uint16.valueOf(GridConstant.EFFECTIVE_BITS))
293                 .setFreqMap(byteArray)
294                 .build();
295         waveMap.put(availFreqMaps.key(), availFreqMaps);
296         return new DegreeAttributesBuilder()
297                 .setAvailFreqMaps(waveMap)
298                 .build();
299     }
300
301     private SrgAttributes getSrgAttributes() {
302         return new SrgAttributesBuilder().setAvailFreqMaps(GridUtils.initFreqMaps4FixedGrid2Available()).build();
303     }
304
305     private DegreeAttributes getEmptyDegAttributes() {
306         return (new DegreeAttributesBuilder())
307                 .setAvailFreqMaps(Map.of())
308                 .build();
309     }
310
311     private SrgAttributes getEmptySrgAttributes() {
312         return new SrgAttributesBuilder().setAvailFreqMaps(Map.of()).build();
313     }
314
315     private TerminationPointBuilder getTerminationPointBuilder() {
316         return new TerminationPointBuilder().setTpId(new TpId("2"));
317     }
318
319     private TerminationPoint1Builder getTerminationPoint1Builder(OpenroadmTpType openroadmTpType) {
320
321         return new TerminationPoint1Builder().setTpType(openroadmTpType);
322
323     }
324
325     private org.opendaylight.yang.gen
326             .v1.http.org.openroadm.network.topology.rev200529.TerminationPoint1Builder createAnotherTerminationPoint() {
327         return new org.opendaylight
328                 .yang.gen.v1.http.org.openroadm.network.topology.rev200529.TerminationPoint1Builder()
329                 .setCtpAttributes((new CtpAttributesBuilder()).build())
330                 .setCpAttributes((new CpAttributesBuilder()).build())
331                 .setTxTtpAttributes((new TxTtpAttributesBuilder()).setUsedWavelengths(Map.of()).build())
332                 .setRxTtpAttributes((new RxTtpAttributesBuilder()).setUsedWavelengths(Map.of()).build())
333                 .setPpAttributes((new PpAttributesBuilder()).setUsedWavelength(Map.of()).build())
334                 .setXpdrClientAttributes((new XpdrClientAttributesBuilder()).build())
335                 .setXpdrPortAttributes((new XpdrPortAttributesBuilder()).build())
336                 .setXpdrNetworkAttributes(new XpdrNetworkAttributesBuilder()
337                         .setTailEquipmentId("destNode" + "--" + "destTp").build());
338     }
339
340 }