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