Merge "BUG 2854 : Do not add empty read write transactions to the replicable journal"
[controller.git] / opendaylight / md-sal / sal-rest-connector / src / test / java / org / opendaylight / controller / sal / restconf / impl / test / CnSnToXmlAndJsonInstanceIdentifierTest.java
index 47171bf2470141bc509d2d96423b676a850826da..b45ba019593a4fe73bdbc5fd41c8c5adf48935a7 100644 (file)
@@ -9,10 +9,7 @@ package org.opendaylight.controller.sal.restconf.impl.test;
 
 import static org.junit.Assert.assertNotNull;
 import static org.junit.Assert.assertTrue;
-import static org.opendaylight.controller.sal.restconf.impl.test.TestUtils.containsStringData;
-
 import java.io.ByteArrayInputStream;
-import java.io.IOException;
 import java.net.URI;
 import java.net.URISyntaxException;
 import java.util.ArrayList;
@@ -20,27 +17,18 @@ import java.util.HashMap;
 import java.util.Iterator;
 import java.util.List;
 import java.util.Map;
-import javax.ws.rs.WebApplicationException;
 import javax.xml.stream.XMLEventReader;
 import javax.xml.stream.XMLInputFactory;
 import javax.xml.stream.XMLStreamException;
 import javax.xml.stream.events.StartElement;
 import javax.xml.stream.events.XMLEvent;
 import org.junit.BeforeClass;
-import org.junit.Test;
-import org.opendaylight.controller.sal.rest.impl.StructuredDataToJsonProvider;
-import org.opendaylight.controller.sal.rest.impl.StructuredDataToXmlProvider;
 import org.opendaylight.yangtools.yang.common.QName;
-import org.opendaylight.yangtools.yang.data.api.CompositeNode;
-import org.opendaylight.yangtools.yang.data.api.InstanceIdentifier;
-import org.opendaylight.yangtools.yang.data.api.InstanceIdentifier.NodeIdentifier;
-import org.opendaylight.yangtools.yang.data.api.InstanceIdentifier.NodeIdentifierWithPredicates;
-import org.opendaylight.yangtools.yang.data.api.InstanceIdentifier.NodeWithValue;
-import org.opendaylight.yangtools.yang.data.api.InstanceIdentifier.PathArgument;
-import org.opendaylight.yangtools.yang.data.api.SimpleNode;
-import org.opendaylight.yangtools.yang.data.impl.ImmutableCompositeNode;
-import org.opendaylight.yangtools.yang.data.impl.NodeFactory;
-import org.opendaylight.yangtools.yang.data.impl.util.CompositeNodeBuilder;
+import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier;
+import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier.NodeIdentifier;
+import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier.NodeIdentifierWithPredicates;
+import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier.NodeWithValue;
+import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier.PathArgument;
 
 public class CnSnToXmlAndJsonInstanceIdentifierTest extends YangAndXmlAndDataSchemaLoader {
 
@@ -49,71 +37,9 @@ public class CnSnToXmlAndJsonInstanceIdentifierTest extends YangAndXmlAndDataSch
         dataLoad("/instanceidentifier/yang", 4, "instance-identifier-module", "cont");
     }
 
-    @Test
-    public void saveCnSnToXmlTest() throws WebApplicationException, IOException, URISyntaxException, XMLStreamException {
-        CompositeNode cnSn = prepareCnSn(createInstanceIdentifier());
-        String output = TestUtils.writeCompNodeWithSchemaContextToOutput(cnSn, modules, dataSchemaNode,
-                StructuredDataToXmlProvider.INSTANCE);
-        validateXmlOutput(output);
-
-    }
-
-    @Test
-    public void saveCnSnWithLeafListInstIdentifierToXmlTest() throws WebApplicationException, IOException,
-            URISyntaxException, XMLStreamException {
-        CompositeNode cnSn = prepareCnSn(createInstanceIdentifierWithLeafList());
-        String output = TestUtils.writeCompNodeWithSchemaContextToOutput(cnSn, modules, dataSchemaNode,
-                StructuredDataToXmlProvider.INSTANCE);
-        validateXmlOutputWithLeafList(output);
-    }
-
-    @Test
-    public void saveCnSnToJsonTest() throws WebApplicationException, IOException, URISyntaxException {
-        CompositeNode cnSn = prepareCnSn(createInstanceIdentifier());
-        String output = TestUtils.writeCompNodeWithSchemaContextToOutput(cnSn, modules, dataSchemaNode,
-                StructuredDataToJsonProvider.INSTANCE);
-        boolean strInOutput = false;
-        strInOutput = containsStringData(
-                output,
-                "\"augment-augment-module:lf111\"",
-                ":",
-                "\"/instance-identifier-module:cont/instance-identifier-module:cont1/augment-module:lst11\\[augment-module:keyvalue111=\\\\\"value1\\\\\"\\]\\[augment-module:keyvalue112=\\\\\"value2\\\\\"\\]/augment-augment-module:lf112\"");
-
-        if (!strInOutput) {
-            strInOutput = containsStringData(
-                    output,
-                    "\"augment-augment-module:lf111\"",
-                    ":",
-                    "\"/instance-identifier-module:cont/instance-identifier-module:cont1/augment-module:lst11\\[augment-module:keyvalue111='value1'\\]\\[augment-module:keyvalue112='value2'\\]/augment-augment-module:lf112\"");
-        }
-        assertTrue(strInOutput);
-    }
-
-    @Test
-    public void saveCnSnWithLeafListInstIdentifierToJsonTest() throws WebApplicationException, IOException,
-            URISyntaxException {
-        CompositeNode cnSn = prepareCnSn(createInstanceIdentifierWithLeafList());
-        String output = TestUtils.writeCompNodeWithSchemaContextToOutput(cnSn, modules, dataSchemaNode,
-                StructuredDataToJsonProvider.INSTANCE);
-        boolean strInOutput = false;
-        strInOutput = containsStringData(
-                output,
-                "\"augment-augment-module:lf111\"",
-                ":",
-                "\"/instance-identifier-module:cont/instance-identifier-module:cont1/augment-module-leaf-list:lflst11\\[.='lflst11_1'\\]\"");
-        if (!strInOutput) {
-            strInOutput = containsStringData(
-                    output,
-                    "\"augment-augment-module:lf111\"",
-                    ":",
-                    "\"/instance-identifier-module:cont/instance-identifier-module:cont1/augment-module-leaf-list:lflst11\\[.=\\\\\"lflst11_1\\\\\"\\]\"");
-        }
-
-        assertTrue(strInOutput);
-    }
 
     private void validateXmlOutput(final String xml) throws XMLStreamException {
-        XMLInputFactory xmlInFactory = XMLInputFactory.newInstance();
+        final XMLInputFactory xmlInFactory = XMLInputFactory.newInstance();
         XMLEventReader eventReader;
 
         eventReader = xmlInFactory.createXMLEventReader(new ByteArrayInputStream(xml.getBytes()));
@@ -121,14 +47,14 @@ public class CnSnToXmlAndJsonInstanceIdentifierTest extends YangAndXmlAndDataSch
         String aModulePrefix = null;
         String iiModulePrefix = null;
         while (eventReader.hasNext()) {
-            XMLEvent nextEvent = eventReader.nextEvent();
+            final XMLEvent nextEvent = eventReader.nextEvent();
             if (nextEvent.isStartElement()) {
-                StartElement startElement = (StartElement) nextEvent;
+                final StartElement startElement = (StartElement) nextEvent;
                 if (startElement.getName().getLocalPart().equals("lf111")) {
-                    Iterator<?> prefixes = startElement.getNamespaceContext().getPrefixes("augment:augment:module");
+                    final Iterator<?> prefixes = startElement.getNamespaceContext().getPrefixes("augment:augment:module");
 
                     while (prefixes.hasNext() && aaModulePrefix == null) {
-                        String prefix = (String) prefixes.next();
+                        final String prefix = (String) prefixes.next();
                         if (!prefix.isEmpty()) {
                             aaModulePrefix = prefix;
                         }
@@ -145,7 +71,7 @@ public class CnSnToXmlAndJsonInstanceIdentifierTest extends YangAndXmlAndDataSch
         assertNotNull(aModulePrefix);
         assertNotNull(iiModulePrefix);
 
-        String instanceIdentifierValue = "/" + iiModulePrefix + ":cont/" + iiModulePrefix + ":cont1/" + aModulePrefix
+        final String instanceIdentifierValue = "/" + iiModulePrefix + ":cont/" + iiModulePrefix + ":cont1/" + aModulePrefix
                 + ":lst11[" + aModulePrefix + ":keyvalue111='value1'][" + aModulePrefix + ":keyvalue112='value2']/"
                 + aaModulePrefix + ":lf112";
 
@@ -154,21 +80,21 @@ public class CnSnToXmlAndJsonInstanceIdentifierTest extends YangAndXmlAndDataSch
     }
 
     private void validateXmlOutputWithLeafList(final String xml) throws XMLStreamException {
-        XMLInputFactory xmlInFactory = XMLInputFactory.newInstance();
+        final XMLInputFactory xmlInFactory = XMLInputFactory.newInstance();
         XMLEventReader eventReader;
 
         eventReader = xmlInFactory.createXMLEventReader(new ByteArrayInputStream(xml.getBytes()));
         String aModuleLfLstPrefix = null;
         String iiModulePrefix = null;
         while (eventReader.hasNext()) {
-            XMLEvent nextEvent = eventReader.nextEvent();
+            final XMLEvent nextEvent = eventReader.nextEvent();
             if (nextEvent.isStartElement()) {
-                StartElement startElement = (StartElement) nextEvent;
+                final StartElement startElement = (StartElement) nextEvent;
                 if (startElement.getName().getLocalPart().equals("lf111")) {
-                    Iterator<?> prefixes = startElement.getNamespaceContext().getPrefixes("augment:module:leaf:list");
+                    final Iterator<?> prefixes = startElement.getNamespaceContext().getPrefixes("augment:module:leaf:list");
 
                     while (prefixes.hasNext() && aModuleLfLstPrefix == null) {
-                        String prefix = (String) prefixes.next();
+                        final String prefix = (String) prefixes.next();
                         if (!prefix.isEmpty()) {
                             aModuleLfLstPrefix = prefix;
                         }
@@ -182,55 +108,37 @@ public class CnSnToXmlAndJsonInstanceIdentifierTest extends YangAndXmlAndDataSch
         assertNotNull(aModuleLfLstPrefix);
         assertNotNull(iiModulePrefix);
 
-        String instanceIdentifierValue = "/" + iiModulePrefix + ":cont/" + iiModulePrefix + ":cont1/"
+        final String instanceIdentifierValue = "/" + iiModulePrefix + ":cont/" + iiModulePrefix + ":cont1/"
                 + aModuleLfLstPrefix + ":lflst11[.='lflst11_1']";
 
         assertTrue(xml.contains(instanceIdentifierValue));
 
     }
 
-    private CompositeNode prepareCnSn(final InstanceIdentifier instanceIdentifier) throws URISyntaxException {
-        CompositeNodeBuilder<ImmutableCompositeNode> cont = ImmutableCompositeNode.builder();
-        cont.setQName(QName.create("instance:identifier:module", "2014-01-17", "cont"));
-
-        CompositeNodeBuilder<ImmutableCompositeNode> cont1 = ImmutableCompositeNode.builder();
-        cont1.setQName(QName.create("instance:identifier:module", "2014-01-17", "cont1"));
-
-        CompositeNodeBuilder<ImmutableCompositeNode> lst11 = ImmutableCompositeNode.builder();
-        lst11.setQName(QName.create("augment:module", "2014-01-17", "lst11"));
-
-        SimpleNode<?> lf111 = NodeFactory.createImmutableSimpleNode(
-                QName.create("augment:augment:module", "2014-01-17", "lf111"), null, instanceIdentifier);
-        lst11.add(lf111);
-        cont1.add(lst11.toInstance());
-        cont.add(cont1.toInstance());
-        return cont.toInstance();
-    }
-
-    private InstanceIdentifier createInstanceIdentifier() throws URISyntaxException {
-        List<PathArgument> pathArguments = new ArrayList<>();
+    private YangInstanceIdentifier createInstanceIdentifier() throws URISyntaxException {
+        final List<PathArgument> pathArguments = new ArrayList<>();
         pathArguments.add(new NodeIdentifier(new QName(new URI("instance:identifier:module"), "cont")));
         pathArguments.add(new NodeIdentifier(new QName(new URI("instance:identifier:module"), "cont1")));
 
-        QName qName = new QName(new URI("augment:module"), "lst11");
-        Map<QName, Object> keyValues = new HashMap<>();
+        final QName qName = new QName(new URI("augment:module"), "lst11");
+        final Map<QName, Object> keyValues = new HashMap<>();
         keyValues.put(new QName(new URI("augment:module"), "keyvalue111"), "value1");
         keyValues.put(new QName(new URI("augment:module"), "keyvalue112"), "value2");
-        NodeIdentifierWithPredicates nodeIdentifierWithPredicates = new NodeIdentifierWithPredicates(qName, keyValues);
+        final NodeIdentifierWithPredicates nodeIdentifierWithPredicates = new NodeIdentifierWithPredicates(qName, keyValues);
         pathArguments.add(nodeIdentifierWithPredicates);
 
         pathArguments.add(new NodeIdentifier(new QName(new URI("augment:augment:module"), "lf112")));
 
-        return InstanceIdentifier.create(pathArguments);
+        return YangInstanceIdentifier.create(pathArguments);
     }
 
-    private InstanceIdentifier createInstanceIdentifierWithLeafList() throws URISyntaxException {
-        List<PathArgument> pathArguments = new ArrayList<>();
+    private YangInstanceIdentifier createInstanceIdentifierWithLeafList() throws URISyntaxException {
+        final List<PathArgument> pathArguments = new ArrayList<>();
         pathArguments.add(new NodeIdentifier(new QName(new URI("instance:identifier:module"), "cont")));
         pathArguments.add(new NodeIdentifier(new QName(new URI("instance:identifier:module"), "cont1")));
         pathArguments.add(new NodeWithValue(new QName(new URI("augment:module:leaf:list"), "lflst11"), "lflst11_1"));
 
-        return InstanceIdentifier.create(pathArguments);
+        return YangInstanceIdentifier.create(pathArguments);
     }
 
 }