Reduce use of getChildByName()
[yangtools.git] / yang / yang-data-impl / src / test / java / org / opendaylight / yangtools / yang / data / impl / leafref / context / DataTreeCandidateValidatorTest2.java
index 60d47246dff0440eeb56c46cdc7862d4a251f267..4450c8ae2c2cd12f2a2b7fde96506e32ea172573 100644 (file)
@@ -9,12 +9,10 @@ package org.opendaylight.yangtools.yang.data.impl.leafref.context;
 
 import static org.junit.Assert.assertEquals;
 import static org.junit.Assert.assertTrue;
-import java.io.File;
-import java.io.FileNotFoundException;
-import java.net.URISyntaxException;
-import java.util.Arrays;
+
 import java.util.Set;
 import org.apache.log4j.BasicConfigurator;
+import org.junit.AfterClass;
 import org.junit.BeforeClass;
 import org.junit.Test;
 import org.opendaylight.yangtools.yang.common.QName;
@@ -26,24 +24,23 @@ import org.opendaylight.yangtools.yang.data.api.schema.ContainerNode;
 import org.opendaylight.yangtools.yang.data.api.schema.LeafNode;
 import org.opendaylight.yangtools.yang.data.api.schema.MapEntryNode;
 import org.opendaylight.yangtools.yang.data.api.schema.MapNode;
+import org.opendaylight.yangtools.yang.data.api.schema.tree.DataTree;
 import org.opendaylight.yangtools.yang.data.api.schema.tree.DataTreeCandidate;
+import org.opendaylight.yangtools.yang.data.api.schema.tree.DataTreeConfiguration;
 import org.opendaylight.yangtools.yang.data.api.schema.tree.DataTreeModification;
-import org.opendaylight.yangtools.yang.data.api.schema.tree.TipProducingDataTree;
-import org.opendaylight.yangtools.yang.data.api.schema.tree.TreeType;
-import org.opendaylight.yangtools.yang.data.impl.TestUtils;
 import org.opendaylight.yangtools.yang.data.impl.leafref.LeafRefContext;
 import org.opendaylight.yangtools.yang.data.impl.leafref.LeafRefDataValidationFailedException;
-import org.opendaylight.yangtools.yang.data.impl.leafref.LeafRefValidatation;
+import org.opendaylight.yangtools.yang.data.impl.leafref.LeafRefValidation;
 import org.opendaylight.yangtools.yang.data.impl.schema.Builders;
 import org.opendaylight.yangtools.yang.data.impl.schema.ImmutableNodes;
 import org.opendaylight.yangtools.yang.data.impl.schema.builder.api.CollectionNodeBuilder;
-import org.opendaylight.yangtools.yang.data.impl.schema.builder.api.DataContainerNodeAttrBuilder;
+import org.opendaylight.yangtools.yang.data.impl.schema.builder.api.DataContainerNodeBuilder;
 import org.opendaylight.yangtools.yang.data.impl.schema.tree.InMemoryDataTreeFactory;
 import org.opendaylight.yangtools.yang.model.api.ContainerSchemaNode;
 import org.opendaylight.yangtools.yang.model.api.ListSchemaNode;
 import org.opendaylight.yangtools.yang.model.api.Module;
 import org.opendaylight.yangtools.yang.model.api.SchemaContext;
-import org.opendaylight.yangtools.yang.parser.spi.meta.ReactorException;
+import org.opendaylight.yangtools.yang.test.util.YangParserTestUtils;
 import org.slf4j.Logger;
 import org.slf4j.LoggerFactory;
 
@@ -53,7 +50,7 @@ public class DataTreeCandidateValidatorTest2 {
     private static Module mainModule;
     private static QNameModule rootModuleQname;
     private static LeafRefContext rootLeafRefContext;
-    public static TipProducingDataTree inMemoryDataTree;
+    public static DataTree inMemoryDataTree;
 
     private static QName chips;
     private static QName chip;
@@ -81,12 +78,63 @@ public class DataTreeCandidateValidatorTest2 {
     }
 
     @BeforeClass
-    public static void init() throws FileNotFoundException, ReactorException, URISyntaxException {
+    public static void init() {
+        context = YangParserTestUtils.parseYangResourceDirectory("/leafref-validation");
+
+        final Set<Module> modules = context.getModules();
+        for (final Module module : modules) {
+            if (module.getName().equals("leafref-validation2")) {
+                mainModule = module;
+            }
+        }
+
+        rootModuleQname = mainModule.getQNameModule();
+        rootLeafRefContext = LeafRefContext.create(context);
+
+        chips = QName.create(rootModuleQname, "chips");
+        chip = QName.create(rootModuleQname, "chip");
+        devType = QName.create(rootModuleQname, "dev_type");
+        chipDesc = QName.create(rootModuleQname, "chip_desc");
+
+        devices = QName.create(rootModuleQname, "devices");
+        device = QName.create(rootModuleQname, "device");
+        typeText = QName.create(rootModuleQname, "type_text");
+        devDesc = QName.create(rootModuleQname, "dev_desc");
+        sn = QName.create(rootModuleQname, "sn");
+        defaultIp = QName.create(rootModuleQname, "default_ip");
+
+        deviceTypeStr = QName.create(rootModuleQname, "device_types");
+        deviceType = QName.create(rootModuleQname, "device_type");
+        type = QName.create(rootModuleQname, "type");
+        desc = QName.create(rootModuleQname, "desc");
+
+        inMemoryDataTree = new InMemoryDataTreeFactory().create(DataTreeConfiguration.DEFAULT_OPERATIONAL, context);
+        final DataTreeModification initialDataTreeModification = inMemoryDataTree.takeSnapshot().newModification();
+        final ContainerSchemaNode chipsListContSchemaNode = (ContainerSchemaNode) mainModule.findDataChildByName(chips)
+                .get();
+        final ContainerNode chipsContainer = createChipsContainer(chipsListContSchemaNode);
+        final YangInstanceIdentifier path1 = YangInstanceIdentifier.of(chips);
+        initialDataTreeModification.write(path1, chipsContainer);
+
+        final ContainerSchemaNode devTypesListContSchemaNode = (ContainerSchemaNode) mainModule
+                .findDataChildByName(deviceTypeStr).get();
+        final ContainerNode deviceTypesContainer = createDevTypeStrContainer(devTypesListContSchemaNode);
+        final YangInstanceIdentifier path2 = YangInstanceIdentifier.of(deviceTypeStr);
+        initialDataTreeModification.write(path2, deviceTypesContainer);
 
-        initSchemaContext();
-        initLeafRefContext();
-        initQnames();
-        initDataTree();
+        initialDataTreeModification.ready();
+        final DataTreeCandidate writeChipsCandidate = inMemoryDataTree.prepare(initialDataTreeModification);
+
+        inMemoryDataTree.commit(writeChipsCandidate);
+        LOG.debug("{}", inMemoryDataTree);
+    }
+
+    @AfterClass
+    public static void cleanup() {
+        inMemoryDataTree = null;
+        rootLeafRefContext = null;
+        mainModule = null;
+        context = null;
     }
 
     @Test
@@ -97,7 +145,8 @@ public class DataTreeCandidateValidatorTest2 {
 
     private static void writeDevices() {
 
-        final ContainerSchemaNode devicesContSchemaNode = (ContainerSchemaNode) mainModule.getDataChildByName(devices);
+        final ContainerSchemaNode devicesContSchemaNode = (ContainerSchemaNode) mainModule.findDataChildByName(devices)
+                .get();
 
         final ContainerNode devicesContainer = createDevicesContainer(devicesContSchemaNode);
 
@@ -111,13 +160,13 @@ public class DataTreeCandidateValidatorTest2 {
         LOG.debug("*************************");
         LOG.debug("Before writeDevices: ");
         LOG.debug("*************************");
-        LOG.debug(inMemoryDataTree.toString());
+        LOG.debug("{}", inMemoryDataTree);
 
         boolean exception = false;
         try {
-            LeafRefValidatation.validate(writeDevicesCandidate, rootLeafRefContext);
+            LeafRefValidation.validate(writeDevicesCandidate, rootLeafRefContext);
         } catch (final LeafRefDataValidationFailedException e) {
-            LOG.debug("All validation errors:" + NEW_LINE + e.getMessage());
+            LOG.debug("All validation errors:{}{}", NEW_LINE, e.getMessage());
 
             assertEquals(4, e.getValidationsErrorsCount());
             exception = true;
@@ -130,82 +179,14 @@ public class DataTreeCandidateValidatorTest2 {
         LOG.debug("*************************");
         LOG.debug("After write: ");
         LOG.debug("*************************");
-        LOG.debug(inMemoryDataTree.toString());
-    }
-
-    private static void initQnames() {
-
-        chips = QName.create(rootModuleQname, "chips");
-        chip = QName.create(rootModuleQname, "chip");
-        devType = QName.create(rootModuleQname, "dev_type");
-        chipDesc = QName.create(rootModuleQname, "chip_desc");
-
-        devices = QName.create(rootModuleQname, "devices");
-        device = QName.create(rootModuleQname, "device");
-        typeText = QName.create(rootModuleQname, "type_text");
-        devDesc = QName.create(rootModuleQname, "dev_desc");
-        sn = QName.create(rootModuleQname, "sn");
-        defaultIp = QName.create(rootModuleQname, "default_ip");
-
-        deviceTypeStr = QName.create(rootModuleQname, "device_types");
-        deviceType = QName.create(rootModuleQname, "device_type");
-        type = QName.create(rootModuleQname, "type");
-        desc = QName.create(rootModuleQname, "desc");
-    }
-
-    private static void initSchemaContext() throws URISyntaxException, FileNotFoundException, ReactorException {
-
-        final File resourceFile = new File(DataTreeCandidateValidatorTest.class.getResource(
-                "/leafref-validation/leafref-validation2.yang").toURI());
-        final File resourceDir = resourceFile.getParentFile();
-
-        context = TestUtils.parseYangSources(Arrays.asList(resourceDir.listFiles()));
-
-        final Set<Module> modules = context.getModules();
-        for (final Module module : modules) {
-            if (module.getName().equals("leafref-validation2")) {
-                mainModule = module;
-            }
-        }
-
-        rootModuleQname = mainModule.getQNameModule();
-    }
-
-    private static void initDataTree() {
-
-        inMemoryDataTree = InMemoryDataTreeFactory.getInstance().create(TreeType.OPERATIONAL);
-        inMemoryDataTree.setSchemaContext(context);
-
-        final DataTreeModification initialDataTreeModification = inMemoryDataTree.takeSnapshot().newModification();
-
-        final ContainerSchemaNode chipsListContSchemaNode = (ContainerSchemaNode) mainModule.getDataChildByName(chips);
-        final ContainerNode chipsContainer = createChipsContainer(chipsListContSchemaNode);
-        final YangInstanceIdentifier path1 = YangInstanceIdentifier.of(chips);
-        initialDataTreeModification.write(path1, chipsContainer);
-
-        final ContainerSchemaNode devTypesListContSchemaNode = (ContainerSchemaNode) mainModule
-                .getDataChildByName(deviceTypeStr);
-        final ContainerNode deviceTypesContainer = createDevTypeStrContainer(devTypesListContSchemaNode);
-        final YangInstanceIdentifier path2 = YangInstanceIdentifier.of(deviceTypeStr);
-        initialDataTreeModification.write(path2, deviceTypesContainer);
-
-        initialDataTreeModification.ready();
-        final DataTreeCandidate writeChipsCandidate = inMemoryDataTree.prepare(initialDataTreeModification);
-
-        inMemoryDataTree.commit(writeChipsCandidate);
-
-        System.out.println(inMemoryDataTree.toString());
-    }
-
-    private static void initLeafRefContext() {
-        rootLeafRefContext = LeafRefContext.create(context);
+        LOG.debug("{}", inMemoryDataTree);
     }
 
     private static ContainerNode createDevTypeStrContainer(final ContainerSchemaNode container) {
 
-        final ListSchemaNode devTypeListSchemaNode = (ListSchemaNode) container.getDataChildByName(deviceType);
+        final ListSchemaNode devTypeListSchemaNode = (ListSchemaNode) container.findDataChildByName(deviceType).get();
 
-        final DataContainerNodeAttrBuilder<NodeIdentifier, ContainerNode> devTypeContainerBldr = Builders
+        final DataContainerNodeBuilder<NodeIdentifier, ContainerNode> devTypeContainerBldr = Builders
                 .containerBuilder(container);
 
         final MapNode devTypeMap = createDevTypeList(devTypeListSchemaNode);
@@ -231,7 +212,7 @@ public class DataTreeCandidateValidatorTest2 {
         final LeafNode<String> typeLeaf = ImmutableNodes.leafNode(type, typeVal);
         final LeafNode<String> descLeaf = ImmutableNodes.leafNode(desc, descVal);
 
-        final DataContainerNodeAttrBuilder<NodeIdentifierWithPredicates, MapEntryNode> devTypeMapEntryBldr = Builders
+        final DataContainerNodeBuilder<NodeIdentifierWithPredicates, MapEntryNode> devTypeMapEntryBldr = Builders
                 .mapEntryBuilder(devTypeListSchemaNode);
 
         devTypeMapEntryBldr.addChild(typeLeaf);
@@ -242,9 +223,9 @@ public class DataTreeCandidateValidatorTest2 {
 
     private static ContainerNode createChipsContainer(final ContainerSchemaNode container) {
 
-        final ListSchemaNode chipsListSchemaNode = (ListSchemaNode) container.getDataChildByName(chip);
+        final ListSchemaNode chipsListSchemaNode = (ListSchemaNode) container.findDataChildByName(chip).get();
 
-        final DataContainerNodeAttrBuilder<NodeIdentifier, ContainerNode> chipsContainerBldr = Builders
+        final DataContainerNodeBuilder<NodeIdentifier, ContainerNode> chipsContainerBldr = Builders
                 .containerBuilder(container);
 
         final MapNode chipsMap = createChipsList(chipsListSchemaNode);
@@ -269,7 +250,7 @@ public class DataTreeCandidateValidatorTest2 {
         final LeafNode<String> devTypeLeaf = ImmutableNodes.leafNode(devType, devTypeVal);
         final LeafNode<String> chipDescLeaf = ImmutableNodes.leafNode(chipDesc, chipDescVal);
 
-        final DataContainerNodeAttrBuilder<NodeIdentifierWithPredicates, MapEntryNode> chipsMapEntryBldr = Builders
+        final DataContainerNodeBuilder<NodeIdentifierWithPredicates, MapEntryNode> chipsMapEntryBldr = Builders
                 .mapEntryBuilder(chipsListSchemaNode);
 
         chipsMapEntryBldr.addChild(devTypeLeaf);
@@ -280,9 +261,9 @@ public class DataTreeCandidateValidatorTest2 {
 
     private static ContainerNode createDevicesContainer(final ContainerSchemaNode container) {
 
-        final ListSchemaNode devicesListSchemaNode = (ListSchemaNode) container.getDataChildByName(device);
+        final ListSchemaNode devicesListSchemaNode = (ListSchemaNode) container.findDataChildByName(device).get();
 
-        final DataContainerNodeAttrBuilder<NodeIdentifier, ContainerNode> devicesContainerBldr = Builders
+        final DataContainerNodeBuilder<NodeIdentifier, ContainerNode> devicesContainerBldr = Builders
                 .containerBuilder(container);
 
         final MapNode devicesMap = createDeviceList(devicesListSchemaNode);
@@ -317,7 +298,7 @@ public class DataTreeCandidateValidatorTest2 {
         final LeafNode<Integer> snValLeaf = ImmutableNodes.leafNode(sn, snVal);
         final LeafNode<String> defaultIpLeaf = ImmutableNodes.leafNode(defaultIp, defaultIpVal);
 
-        final DataContainerNodeAttrBuilder<NodeIdentifierWithPredicates, MapEntryNode> devicesMapEntryBldr = Builders
+        final DataContainerNodeBuilder<NodeIdentifierWithPredicates, MapEntryNode> devicesMapEntryBldr = Builders
                 .mapEntryBuilder(devicesListSchemaNode);
 
         devicesMapEntryBldr.addChild(typeTextLeaf);
@@ -327,4 +308,4 @@ public class DataTreeCandidateValidatorTest2 {
 
         return devicesMapEntryBldr.build();
     }
-}
\ No newline at end of file
+}