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.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;
59 public class PceOpticalNodeTest extends AbstractTest {
61 private PceOpticalNode pceOpticalNode;
63 private BitSet usedBitSet = new BitSet(8);
64 private BitSet availableBitSet = new BitSet(8);
68 NodeBuilder node1Builder = getNodeBuilder(geSupportingNodes(), OpenroadmTpType.SRGTXRXPP);
69 node = node1Builder.setNodeId(new NodeId("test")).build();
70 availableBitSet.set(0,8);
74 public void isValidTest() {
75 OpenroadmNodeType nodeType = OpenroadmNodeType.ROADM;
76 pceOpticalNode = new PceOpticalNode(node, nodeType, StringConstants.OPENROADM_DEVICE_VERSION_2_2_1);
77 Assert.assertTrue(pceOpticalNode.isValid());
81 public void testInitSrgTps() {
83 pceOpticalNode = new PceOpticalNode(node,
84 OpenroadmNodeType.ROADM, StringConstants.OPENROADM_DEVICE_VERSION_2_2_1);
85 pceOpticalNode.initSrgTps();
86 pceOpticalNode.initXndrTps(ServiceFormat.OMS);
87 pceOpticalNode.initFrequenciesBitSet();
88 Assert.assertFalse(pceOpticalNode.isValid());
89 Assert.assertNull(pceOpticalNode.getBitSetData());
90 Assert.assertTrue(pceOpticalNode.checkTP("testTP"));
91 Assert.assertNull(pceOpticalNode.getAvailableTribPorts());
92 Assert.assertNull(pceOpticalNode.getAvailableTribPorts());
93 Assert.assertNull(pceOpticalNode.getXpdrClient("test"));
97 public void testInitXndrTpSrgTypes() {
98 NodeBuilder node1Builder = getNodeBuilder(geSupportingNodes(), OpenroadmTpType.XPONDERNETWORK);
99 Node specificNode = node1Builder.build();
100 pceOpticalNode = new PceOpticalNode(specificNode,
101 OpenroadmNodeType.SRG, StringConstants.OPENROADM_DEVICE_VERSION_2_2_1);
102 pceOpticalNode.initFrequenciesBitSet();
103 Assert.assertTrue(pceOpticalNode.isValid());
104 Assert.assertEquals(availableBitSet, pceOpticalNode.getBitSetData().get(88,96));
105 Assert.assertTrue(pceOpticalNode.checkTP("testTP"));
109 public void testInitXndrTpDegTypes() {
110 pceOpticalNode = new PceOpticalNode(node,
111 OpenroadmNodeType.DEGREE, StringConstants.OPENROADM_DEVICE_VERSION_2_2_1);
112 pceOpticalNode.initFrequenciesBitSet();
113 Assert.assertTrue(pceOpticalNode.isValid());
114 Assert.assertEquals(usedBitSet,pceOpticalNode.getBitSetData().get(88,96));
115 Assert.assertTrue(pceOpticalNode.checkTP("testTP"));
119 public void testInitXndrTpXpondrTypes() {
120 pceOpticalNode = new PceOpticalNode(node,
121 OpenroadmNodeType.XPONDER, StringConstants.OPENROADM_DEVICE_VERSION_2_2_1);
122 pceOpticalNode.initFrequenciesBitSet();
123 Assert.assertTrue(pceOpticalNode.isValid());
124 Assert.assertEquals(availableBitSet, pceOpticalNode.getBitSetData().get(88,96));
125 Assert.assertTrue(pceOpticalNode.checkTP("testTP"));
129 public void testinitFrequenciesBitSet() {
130 pceOpticalNode = new PceOpticalNode(node,
131 OpenroadmNodeType.ROADM, StringConstants.OPENROADM_DEVICE_VERSION_2_2_1);
132 pceOpticalNode.initXndrTps(ServiceFormat.OMS);
133 pceOpticalNode.initFrequenciesBitSet();
134 Assert.assertFalse(pceOpticalNode.isValid());
135 Assert.assertNull(pceOpticalNode.getBitSetData());
136 Assert.assertTrue(pceOpticalNode.checkTP("testTP"));
140 public void testGetRdmSrgClient() {
141 pceOpticalNode = new PceOpticalNode(node,
142 OpenroadmNodeType.ROADM, StringConstants.OPENROADM_DEVICE_VERSION_2_2_1);
143 pceOpticalNode.initSrgTps();
144 Assert.assertNull(pceOpticalNode.getRdmSrgClient("7"));
145 Assert.assertFalse(pceOpticalNode.isValid());
146 Assert.assertNull(pceOpticalNode.getBitSetData());
147 Assert.assertTrue(pceOpticalNode.checkTP("testTP"));
151 public void testGetRdmSrgClientEmpty() {
152 NodeBuilder node1Builder = getNodeBuilderEmpty(geSupportingNodes(), OpenroadmTpType.SRGTXRXPP);
153 Node specificNode = node1Builder.setNodeId(new NodeId("test")).build();
154 pceOpticalNode = new PceOpticalNode(specificNode,
155 OpenroadmNodeType.ROADM, StringConstants.OPENROADM_DEVICE_VERSION_2_2_1);
156 pceOpticalNode.initSrgTps();
157 pceOpticalNode.initFrequenciesBitSet();
158 pceOpticalNode.initXndrTps(ServiceFormat.OMS);
159 Assert.assertNull(pceOpticalNode.getRdmSrgClient("7"));
160 Assert.assertFalse(pceOpticalNode.isValid());
161 Assert.assertNull(pceOpticalNode.getBitSetData());
162 Assert.assertTrue(pceOpticalNode.checkTP("testTP"));
166 public void testGetRdmSrgClientDeg() {
167 pceOpticalNode = new PceOpticalNode(node,
168 OpenroadmNodeType.DEGREE, StringConstants.OPENROADM_DEVICE_VERSION_2_2_1);
169 pceOpticalNode.initSrgTps();
170 Assert.assertNull(pceOpticalNode.getRdmSrgClient("7"));
171 Assert.assertFalse(pceOpticalNode.isValid());
172 Assert.assertNull(pceOpticalNode.getBitSetData());
173 Assert.assertTrue(pceOpticalNode.checkTP("testTP"));
177 public void testGetRdmSrgClientsrgtxcp() {
178 NodeBuilder node1Builder = getNodeBuilder(geSupportingNodes(), OpenroadmTpType.SRGTXCP);
179 Node specificNode = node1Builder.build();
180 pceOpticalNode = new PceOpticalNode(specificNode,
181 OpenroadmNodeType.ROADM, StringConstants.OPENROADM_DEVICE_VERSION_2_2_1);
182 pceOpticalNode.initSrgTps();
183 Assert.assertFalse(pceOpticalNode.isValid());
184 Assert.assertNull(pceOpticalNode.getBitSetData());
185 Assert.assertTrue(pceOpticalNode.checkTP("testTP"));
186 Assert.assertNull(pceOpticalNode.getRdmSrgClient("5"));
190 public void testGetRdmSrgClientDegreerxtpp() {
191 NodeBuilder node1Builder = getNodeBuilder(geSupportingNodes(), OpenroadmTpType.DEGREERXTTP);
192 node = node1Builder.build();
193 pceOpticalNode = new PceOpticalNode(node,
194 OpenroadmNodeType.ROADM, StringConstants.OPENROADM_DEVICE_VERSION_2_2_1);
195 pceOpticalNode.initSrgTps();
196 Assert.assertNull(pceOpticalNode.getRdmSrgClient("2"));
197 Assert.assertFalse(pceOpticalNode.isValid());
198 Assert.assertNull(pceOpticalNode.getBitSetData());
199 Assert.assertTrue(pceOpticalNode.checkTP("testTP"));
202 private Map<SupportingNodeKey,SupportingNode> geSupportingNodes() {
203 Map<SupportingNodeKey,SupportingNode> supportingNodes1 = new HashMap<>();
204 SupportingNode supportingNode1 = new SupportingNodeBuilder()
205 .setNodeRef(new NodeId("node 1"))
206 .setNetworkRef(new NetworkId(NetworkUtils.CLLI_NETWORK_ID))
209 .put(supportingNode1.key(),supportingNode1);
211 SupportingNode supportingNode2 = new SupportingNodeBuilder()
212 .setNodeRef(new NodeId("node 2"))
213 .setNetworkRef(new NetworkId(NetworkUtils.UNDERLAY_NETWORK_ID))
216 .put(supportingNode2.key(),supportingNode2);
217 return supportingNodes1;
220 private NodeBuilder getNodeBuilder(Map<SupportingNodeKey,SupportingNode> supportingNodes1,
221 OpenroadmTpType openroadmTpType) {
223 TerminationPoint1Builder tp1Bldr = getTerminationPoint1Builder(openroadmTpType);
224 TerminationPointBuilder xpdrTpBldr = getTerminationPointBuilder();
225 xpdrTpBldr.addAugmentation(tp1Bldr.build());
226 xpdrTpBldr.addAugmentation(createAnotherTerminationPoint().build());
227 org.opendaylight.yang.gen.v1.http.org.openroadm.network.topology.rev200529.Node1 node1 = getNode1();
228 TerminationPoint xpdr = xpdrTpBldr.build();
229 org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.network.topology.rev180226.Node1 node1Rev180226 =
231 .setTerminationPoint(Map.of(xpdr.key(),xpdr))
235 return new NodeBuilder()
236 .setNodeId(new NodeId("node_test"))
237 .withKey(new NodeKey(new NodeId("node 1")))
238 .addAugmentation(node1Rev180226)
239 .addAugmentation(node1)
240 .setSupportingNode(supportingNodes1);
243 private NodeBuilder getNodeBuilderEmpty(Map<SupportingNodeKey,SupportingNode> supportingNodes1,
244 OpenroadmTpType openroadmTpType) {
246 TerminationPoint1Builder tp1Bldr = getTerminationPoint1Builder(openroadmTpType);
247 TerminationPointBuilder xpdrTpBldr = getTerminationPointBuilder();
248 xpdrTpBldr.addAugmentation(tp1Bldr.build());
249 xpdrTpBldr.addAugmentation(createAnotherTerminationPoint().build());
251 org.opendaylight.yang.gen.v1.http.org.openroadm.network.topology.rev200529.Node1 node1 = getNode1Empty();
252 TerminationPoint xpdr = xpdrTpBldr.build();
253 org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.network.topology.rev180226.Node1 node1Rev180226 =
255 .setTerminationPoint(Map.of(xpdr.key(),xpdr))
259 return new NodeBuilder()
260 .setNodeId(new NodeId("node_test"))
261 .withKey(new NodeKey(new NodeId("node 1")))
262 .addAugmentation(node1Rev180226)
263 .addAugmentation(node1)
264 .setSupportingNode(supportingNodes1);
267 private org.opendaylight
268 .yang.gen.v1.http.org.openroadm.network.topology.rev200529.Node1 getNode1() {
269 return new org.opendaylight.yang.gen.v1.http.org.openroadm.network.topology.rev200529.Node1Builder()
270 .setSrgAttributes(getSrgAttributes())
271 .setDegreeAttributes(getDegAttributes())
275 private org.opendaylight
276 .yang.gen.v1.http.org.openroadm.network.topology.rev200529.Node1 getNode1Empty() {
277 return new org.opendaylight.yang.gen.v1.http.org.openroadm.network.topology.rev200529.Node1Builder()
278 .setSrgAttributes(getEmptySrgAttributes())
279 .setDegreeAttributes(getEmptyDegAttributes())
283 private DegreeAttributes getDegAttributes() {
284 byte[] byteArray = new byte[GridConstant.NB_OCTECTS];
285 Arrays.fill(byteArray, (byte) GridConstant.USED_SLOT_VALUE);
286 byteArray[7] = (byte) GridConstant.AVAILABLE_SLOT_VALUE;
287 Map<AvailFreqMapsKey, AvailFreqMaps> waveMap = new HashMap<>();
288 AvailFreqMaps availFreqMaps = new AvailFreqMapsBuilder().setMapName(GridConstant.C_BAND)
289 .setFreqMapGranularity(new FrequencyGHz(BigDecimal.valueOf(GridConstant.GRANULARITY)))
290 .setStartEdgeFreq(new FrequencyTHz(BigDecimal.valueOf(GridConstant.START_EDGE_FREQUENCY)))
291 .setEffectiveBits(Uint16.valueOf(GridConstant.EFFECTIVE_BITS))
292 .setFreqMap(byteArray)
294 waveMap.put(availFreqMaps.key(), availFreqMaps);
295 return new DegreeAttributesBuilder()
296 .setAvailFreqMaps(waveMap)
300 private SrgAttributes getSrgAttributes() {
301 return new SrgAttributesBuilder().setAvailFreqMaps(GridUtils.initFreqMaps4FixedGrid2Available()).build();
304 private DegreeAttributes getEmptyDegAttributes() {
305 return (new DegreeAttributesBuilder())
306 .setAvailFreqMaps(Map.of())
310 private SrgAttributes getEmptySrgAttributes() {
311 return new SrgAttributesBuilder().setAvailFreqMaps(Map.of()).build();
314 private TerminationPointBuilder getTerminationPointBuilder() {
315 return new TerminationPointBuilder().setTpId(new TpId("2"));
318 private TerminationPoint1Builder getTerminationPoint1Builder(OpenroadmTpType openroadmTpType) {
320 return new TerminationPoint1Builder().setTpType(openroadmTpType);
324 private org.opendaylight.yang.gen
325 .v1.http.org.openroadm.network.topology.rev200529.TerminationPoint1Builder createAnotherTerminationPoint() {
326 return new org.opendaylight
327 .yang.gen.v1.http.org.openroadm.network.topology.rev200529.TerminationPoint1Builder()
328 .setCtpAttributes((new CtpAttributesBuilder()).build())
329 .setCpAttributes((new CpAttributesBuilder()).build())
330 .setTxTtpAttributes((new TxTtpAttributesBuilder()).setUsedWavelengths(Map.of()).build())
331 .setRxTtpAttributes((new RxTtpAttributesBuilder()).setUsedWavelengths(Map.of()).build())
332 .setPpAttributes((new PpAttributesBuilder()).setUsedWavelength(Map.of()).build())
333 .setXpdrClientAttributes((new XpdrClientAttributesBuilder()).build())
334 .setXpdrPortAttributes((new XpdrPortAttributesBuilder()).build())
335 .setXpdrNetworkAttributes(new XpdrNetworkAttributesBuilder()
336 .setTailEquipmentId("destNode" + "--" + "destTp").build());