2 * Copyright © 2020 Orange, Inc. and others. All rights reserved.
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
9 package org.opendaylight.transportpce.pce.networkanalyzer;
11 import java.math.BigDecimal;
12 import java.util.Arrays;
13 import java.util.BitSet;
14 import java.util.HashMap;
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;
62 public class PceOpticalNodeTest extends AbstractTest {
64 private PceOpticalNode pceOpticalNode;
66 private BitSet usedBitSet = new BitSet(8);
67 private BitSet availableBitSet = new BitSet(8);
71 NodeBuilder node1Builder = getNodeBuilder(geSupportingNodes(), OpenroadmTpType.SRGTXRXPP);
72 node = node1Builder.setNodeId(new NodeId("test")).build();
73 availableBitSet.set(0,8);
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());
85 public void testInitSrgTps() {
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"));
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"));
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"));
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"));
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"));
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"));
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"));
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"));
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"));
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"));
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))
213 .put(supportingNode1.key(),supportingNode1);
215 SupportingNode supportingNode2 = new SupportingNodeBuilder()
216 .setNodeRef(new NodeId("node 2"))
217 .setNetworkRef(new NetworkId(NetworkUtils.UNDERLAY_NETWORK_ID))
220 .put(supportingNode2.key(),supportingNode2);
221 return supportingNodes1;
224 private NodeBuilder getNodeBuilder(Map<SupportingNodeKey,SupportingNode> supportingNodes1,
225 OpenroadmTpType openroadmTpType) {
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 =
235 .setTerminationPoint(Map.of(xpdr.key(),xpdr))
237 Node1 node11 = new org.opendaylight.yang.gen.v1.http.org.openroadm.common.network.rev200529.Node1Builder()
238 .setAdministrativeState(AdminStates.InService).setOperationalState(State.InService).build();
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);
250 private NodeBuilder getNodeBuilderEmpty(Map<SupportingNodeKey,SupportingNode> supportingNodes1,
251 OpenroadmTpType openroadmTpType) {
253 TerminationPoint1Builder tp1Bldr = getTerminationPoint1Builder(openroadmTpType);
254 TerminationPointBuilder xpdrTpBldr = getTerminationPointBuilder();
255 xpdrTpBldr.addAugmentation(tp1Bldr.build());
256 xpdrTpBldr.addAugmentation(createAnotherTerminationPoint().build());
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 =
262 .setTerminationPoint(Map.of(xpdr.key(),xpdr))
264 Node1 node11 = new org.opendaylight.yang.gen.v1.http.org.openroadm.common.network.rev200529.Node1Builder()
265 .setAdministrativeState(AdminStates.InService).setOperationalState(State.InService).build();
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);
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())
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())
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)
304 waveMap.put(availFreqMaps.key(), availFreqMaps);
305 return new DegreeAttributesBuilder()
306 .setAvailFreqMaps(waveMap)
310 private SrgAttributes getSrgAttributes() {
311 return new SrgAttributesBuilder().setAvailFreqMaps(GridUtils.initFreqMaps4FixedGrid2Available()).build();
314 private DegreeAttributes getEmptyDegAttributes() {
315 return (new DegreeAttributesBuilder())
316 .setAvailFreqMaps(Map.of())
320 private SrgAttributes getEmptySrgAttributes() {
321 return new SrgAttributesBuilder().setAvailFreqMaps(Map.of()).build();
324 private TerminationPointBuilder getTerminationPointBuilder() {
325 return new TerminationPointBuilder().setTpId(new TpId("2"));
328 private TerminationPoint1Builder getTerminationPoint1Builder(OpenroadmTpType openroadmTpType) {
330 return new TerminationPoint1Builder().setTpType(openroadmTpType).setOperationalState(State.InService)
331 .setAdministrativeState(AdminStates.InService);
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());