update portmapping YANG to store SAPI/DAPI hashmap
[transportpce.git] / tapi / src / test / java / org / opendaylight / transportpce / tapi / utils / TopologyDataUtils.java
1 /*
2  * Copyright © 2019 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 package org.opendaylight.transportpce.tapi.utils;
9
10 import edu.umd.cs.findbugs.annotations.NonNull;
11 import java.io.File;
12 import java.io.FileInputStream;
13 import java.io.FileNotFoundException;
14 import java.io.InputStream;
15 import java.util.Optional;
16 import org.opendaylight.mdsal.binding.api.DataBroker;
17 import org.opendaylight.mdsal.binding.api.WriteTransaction;
18 import org.opendaylight.mdsal.common.api.LogicalDatastoreType;
19 import org.opendaylight.transportpce.common.DataStoreContext;
20 import org.opendaylight.transportpce.common.converter.XMLDataObjectConverter;
21 import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.portmapping.rev200429.Network;
22 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.network.rev180226.Networks;
23 import org.opendaylight.yang.gen.v1.urn.onf.otcc.yang.tapi.topology.rev181210.GetTopologyDetailsInput;
24 import org.opendaylight.yang.gen.v1.urn.onf.otcc.yang.tapi.topology.rev181210.GetTopologyDetailsInputBuilder;
25 import org.opendaylight.yangtools.yang.binding.DataObject;
26 import org.opendaylight.yangtools.yang.binding.InstanceIdentifier;
27 import org.opendaylight.yangtools.yang.data.api.schema.NormalizedNode;
28 import org.slf4j.Logger;
29 import org.slf4j.LoggerFactory;
30
31 public final class TopologyDataUtils {
32
33     private static final Logger LOG = LoggerFactory.getLogger(TopologyDataUtils.class);
34     private static final String TOPOLOGY_FILE =
35         "src/test/resources/openroadm-topology2.xml";
36     private static final String PORTMAPPING_FILE =
37         "src/test/resources/portmapping-example.xml";
38
39     public static GetTopologyDetailsInput buildGetTopologyDetailsInput() {
40         GetTopologyDetailsInputBuilder builtInput = new GetTopologyDetailsInputBuilder();
41         builtInput.setTopologyIdOrName("topo1");
42         return builtInput.build();
43     }
44
45     public static void writeTopologyFromFileToDatastore(DataStoreContext dataStoreContextUtil) {
46         Networks result = null;
47         File topoFile = new File(TOPOLOGY_FILE);
48         if (topoFile.exists()) {
49             String fileName = topoFile.getName();
50             InputStream targetStream;
51             try {
52                 targetStream = new FileInputStream(topoFile);
53                 Optional<NormalizedNode<?, ?>> transformIntoNormalizedNode = null;
54                 transformIntoNormalizedNode = XMLDataObjectConverter.createWithDataStoreUtil(dataStoreContextUtil)
55                     .transformIntoNormalizedNode(targetStream);
56                 if (!transformIntoNormalizedNode.isPresent()) {
57                     throw new IllegalStateException(String.format(
58                         "Could not transform the input %s into normalized nodes", fileName));
59                 }
60                 Optional<DataObject> dataObject = XMLDataObjectConverter.createWithDataStoreUtil(dataStoreContextUtil)
61                     .getDataObject(transformIntoNormalizedNode.get(), Networks.QNAME);
62                 if (!dataObject.isPresent()) {
63                     throw new IllegalStateException("Could not transform normalized nodes into data object");
64                 } else {
65                     result = (Networks) dataObject.get();
66                 }
67             } catch (FileNotFoundException e) {
68                 LOG.error("File not found : {} at {}", e.getMessage(), e.getLocalizedMessage());
69             }
70         } else {
71             LOG.error("xml file {} not found at {}", topoFile.getName(), topoFile.getAbsolutePath());
72         }
73         LOG.info("Storing openroadm-topology in datastore");
74         InstanceIdentifier<Networks> ietfNetworksIID = InstanceIdentifier.builder(Networks.class).build();
75         writeTransaction(dataStoreContextUtil.getDataBroker(), ietfNetworksIID, result);
76         LOG.info("openroadm-topology stored with success in datastore");
77     }
78
79     @SuppressWarnings("unchecked")
80     private static boolean writeTransaction(DataBroker dataBroker, InstanceIdentifier instanceIdentifier,
81         DataObject object) {
82         @NonNull
83         WriteTransaction transaction = dataBroker.newWriteOnlyTransaction();
84         transaction.put(LogicalDatastoreType.CONFIGURATION, instanceIdentifier, object);
85         transaction.commit();
86         return true;
87     }
88
89     public static void writePortmappingFromFileToDatastore(DataStoreContext dataStoreContextUtil) {
90         Network result = null;
91         File portmappingFile = new File(PORTMAPPING_FILE);
92         if (portmappingFile.exists()) {
93             String fileName = portmappingFile.getName();
94             InputStream targetStream;
95             try {
96                 targetStream = new FileInputStream(portmappingFile);
97                 Optional<NormalizedNode<?, ?>> transformIntoNormalizedNode = null;
98                 transformIntoNormalizedNode = XMLDataObjectConverter.createWithDataStoreUtil(dataStoreContextUtil)
99                     .transformIntoNormalizedNode(targetStream);
100                 if (!transformIntoNormalizedNode.isPresent()) {
101                     throw new IllegalStateException(String.format(
102                         "Could not transform the input %s into normalized nodes", fileName));
103                 }
104                 Optional<DataObject> dataObject = XMLDataObjectConverter.createWithDataStoreUtil(dataStoreContextUtil)
105                     .getDataObject(transformIntoNormalizedNode.get(), Network.QNAME);
106                 if (!dataObject.isPresent()) {
107                     throw new IllegalStateException("Could not transform normalized nodes into data object");
108                 } else {
109                     result = (Network) dataObject.get();
110                 }
111             } catch (FileNotFoundException e) {
112                 LOG.error("File not found : {} at {}", e.getMessage(), e.getLocalizedMessage());
113             }
114         } else {
115             LOG.error("xml file {} not found at {}", portmappingFile.getName(), portmappingFile.getAbsolutePath());
116         }
117         InstanceIdentifier<Network> portmappingIID = InstanceIdentifier.builder(Network.class).build();
118         writeTransaction(dataStoreContextUtil.getDataBroker(), portmappingIID, result);
119         LOG.info("portmapping-example stored with success in datastore");
120     }
121
122     private TopologyDataUtils() {
123
124     }
125
126 }