* terms of the Eclipse Public License v1.0 which accompanies this distribution,
* and is available at http://www.eclipse.org/legal/epl-v10.html
*/
-
package org.opendaylight.yangtools.yang.data.codec.xml;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertTrue;
+import com.google.common.collect.ImmutableSet;
import java.io.InputStream;
import java.net.URI;
import java.util.Collection;
-import java.util.List;
import java.util.Optional;
-import javax.annotation.Nonnull;
-import javax.xml.stream.XMLInputFactory;
import javax.xml.stream.XMLStreamReader;
import org.junit.Before;
import org.junit.Test;
+import org.opendaylight.yangtools.odlext.model.api.YangModeledAnyxmlSchemaNode;
+import org.opendaylight.yangtools.util.xml.UntrustedXML;
import org.opendaylight.yangtools.yang.common.QName;
import org.opendaylight.yangtools.yang.common.QNameModule;
import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier.NodeIdentifier;
-import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier.PathArgument;
import org.opendaylight.yangtools.yang.data.api.schema.ContainerNode;
import org.opendaylight.yangtools.yang.data.api.schema.DataContainerChild;
import org.opendaylight.yangtools.yang.data.api.schema.LeafNode;
import org.opendaylight.yangtools.yang.data.api.schema.stream.NormalizedNodeStreamWriter;
import org.opendaylight.yangtools.yang.data.impl.schema.ImmutableNormalizedNodeStreamWriter;
import org.opendaylight.yangtools.yang.data.impl.schema.NormalizedNodeResult;
-import org.opendaylight.yangtools.yang.model.api.ConstraintDefinition;
import org.opendaylight.yangtools.yang.model.api.ContainerSchemaNode;
import org.opendaylight.yangtools.yang.model.api.DataSchemaNode;
+import org.opendaylight.yangtools.yang.model.api.EffectiveModelContext;
import org.opendaylight.yangtools.yang.model.api.Module;
-import org.opendaylight.yangtools.yang.model.api.SchemaContext;
+import org.opendaylight.yangtools.yang.model.api.MustDefinition;
import org.opendaylight.yangtools.yang.model.api.SchemaPath;
import org.opendaylight.yangtools.yang.model.api.Status;
-import org.opendaylight.yangtools.yang.model.api.UnknownSchemaNode;
-import org.opendaylight.yangtools.yang.model.api.YangModeledAnyXmlSchemaNode;
+import org.opendaylight.yangtools.yang.model.api.stmt.AnyxmlEffectiveStatement;
import org.opendaylight.yangtools.yang.test.util.YangParserTestUtils;
+import org.opendaylight.yangtools.yang.xpath.api.YangXPathExpression.QualifiedBound;
public class YangModeledAnyXMLDeserializationTest {
private QName myLeaf1;
private QName myAnyXMLDataBar;
private QName myAnyXMLDataFoo;
- private SchemaContext schemaContext;
+ private EffectiveModelContext schemaContext;
@Before
public void setUp() {
- barModuleQName = QNameModule.create(URI.create("bar"), null);
+ barModuleQName = QNameModule.create(URI.create("bar"));
myContainer1 = QName.create(barModuleQName, "my-container-1");
myLeaf1 = QName.create(barModuleQName, "my-leaf-1");
myAnyXMLDataBar = QName.create(barModuleQName, "my-anyxml-data");
- fooModuleQName = QNameModule.create(URI.create("foo"), null);
+ fooModuleQName = QNameModule.create(URI.create("foo"));
myContainer2 = QName.create(fooModuleQName, "my-container-2");
innerContainer = QName.create(fooModuleQName, "inner-container");
myLeaf3 = QName.create(fooModuleQName, "my-leaf-3");
@Test
public void testRawAnyXMLFromBar() throws Exception {
- DataSchemaNode barContainer = schemaContext.getDataChildByName(QName.create(barModuleQName, "bar"));
+ DataSchemaNode barContainer = schemaContext.findDataChildByName(QName.create(barModuleQName, "bar")).get();
assertTrue(barContainer instanceof ContainerSchemaNode);
- final YangModeledAnyXmlSchemaNode yangModeledAnyXML = new YangModeledAnyXMLSchemaNodeImplTest(myAnyXMLDataBar,
+ final YangModeledAnyxmlSchemaNode yangModeledAnyXML = new YangModeledAnyXMLSchemaNodeImplTest(myAnyXMLDataBar,
(ContainerSchemaNode) barContainer);
final InputStream resourceAsStream = YangModeledAnyXMLDeserializationTest.class.getResourceAsStream(
"/anyxml-support/xml/bar.xml");
- final XMLInputFactory factory = XMLInputFactory.newInstance();
- final XMLStreamReader reader = factory.createXMLStreamReader(resourceAsStream);
+ final XMLStreamReader reader = UntrustedXML.createXMLStreamReader(resourceAsStream);
final NormalizedNodeResult result = new NormalizedNodeResult();
final NormalizedNodeStreamWriter streamWriter = ImmutableNormalizedNodeStreamWriter.from(result);
final XmlParserStream xmlParser = XmlParserStream.create(streamWriter, schemaContext, yangModeledAnyXML);
xmlParser.parse(reader);
- final NormalizedNode<?, ?> output = result.getResult();
+ final NormalizedNode output = result.getResult();
assertTrue(output instanceof YangModeledAnyXmlNode);
final YangModeledAnyXmlNode yangModeledAnyXmlNode = (YangModeledAnyXmlNode) output;
- Collection<DataContainerChild<? extends PathArgument, ?>> value = yangModeledAnyXmlNode.getValue();
+ Collection<DataContainerChild> value = yangModeledAnyXmlNode.body();
assertEquals(2, value.size());
- Optional<DataContainerChild<? extends PathArgument, ?>> child = yangModeledAnyXmlNode
- .getChild(new NodeIdentifier(myContainer1));
- assertTrue(child.orElse(null) instanceof ContainerNode);
- ContainerNode myContainerNode1 = (ContainerNode) child.get();
+ DataContainerChild child = yangModeledAnyXmlNode.childByArg(new NodeIdentifier(myContainer1));
+ assertTrue(child instanceof ContainerNode);
+ ContainerNode myContainerNode1 = (ContainerNode) child;
- Optional<DataContainerChild<? extends PathArgument, ?>> child2 = myContainerNode1.getChild(new NodeIdentifier(
- myLeaf1));
- assertTrue(child2.orElse(null) instanceof LeafNode);
- LeafNode<?> leafNode1 = (LeafNode<?>) child2.get();
+ DataContainerChild child2 = myContainerNode1.childByArg(new NodeIdentifier(myLeaf1));
+ assertTrue(child2 instanceof LeafNode);
+ LeafNode<?> leafNode1 = (LeafNode<?>) child2;
- Object leafNode1Value = leafNode1.getValue();
+ Object leafNode1Value = leafNode1.body();
assertEquals("value1", leafNode1Value);
}
final InputStream resourceAsStream = YangModeledAnyXMLDeserializationTest.class.getResourceAsStream(
"/anyxml-support/xml/foo.xml");
final Module foo = schemaContext.findModules("foo").iterator().next();
- final YangModeledAnyXmlSchemaNode myAnyXmlData = (YangModeledAnyXmlSchemaNode) foo.getDataChildByName(
- QName.create(foo.getQNameModule(), "my-anyxml-data"));
+ final YangModeledAnyxmlSchemaNode myAnyXmlData = (YangModeledAnyxmlSchemaNode) foo.findDataChildByName(
+ QName.create(foo.getQNameModule(), "my-anyxml-data")).get();
- final XMLInputFactory factory = XMLInputFactory.newInstance();
- final XMLStreamReader reader = factory.createXMLStreamReader(resourceAsStream);
+ final XMLStreamReader reader = UntrustedXML.createXMLStreamReader(resourceAsStream);
final NormalizedNodeResult result = new NormalizedNodeResult();
final NormalizedNodeStreamWriter streamWriter = ImmutableNormalizedNodeStreamWriter.from(result);
final XmlParserStream xmlParser = XmlParserStream.create(streamWriter, schemaContext, myAnyXmlData);
xmlParser.parse(reader);
- final NormalizedNode<?, ?> output = result.getResult();
+ final NormalizedNode output = result.getResult();
assertTrue(output instanceof YangModeledAnyXmlNode);
final YangModeledAnyXmlNode yangModeledAnyXmlNode = (YangModeledAnyXmlNode) output;
DataSchemaNode schemaOfAnyXmlData = yangModeledAnyXmlNode.getSchemaOfAnyXmlData();
- DataSchemaNode expectedSchemaOfAnyXmlData = schemaContext.getDataChildByName(myContainer2);
+ DataSchemaNode expectedSchemaOfAnyXmlData = schemaContext.findDataChildByName(myContainer2).get();
assertEquals(expectedSchemaOfAnyXmlData, schemaOfAnyXmlData);
- Collection<DataContainerChild<? extends PathArgument, ?>> value = yangModeledAnyXmlNode.getValue();
+ Collection<DataContainerChild> value = yangModeledAnyXmlNode.body();
assertEquals(2, value.size());
- Optional<DataContainerChild<? extends PathArgument, ?>> child2 = yangModeledAnyXmlNode
- .getChild(new NodeIdentifier(innerContainer));
- assertTrue(child2.orElse(null) instanceof ContainerNode);
- ContainerNode innerContainerNode = (ContainerNode) child2.get();
+ DataContainerChild child2 = yangModeledAnyXmlNode.childByArg(new NodeIdentifier(innerContainer));
+ assertTrue(child2 instanceof ContainerNode);
+ ContainerNode innerContainerNode = (ContainerNode) child2;
- Optional<DataContainerChild<? extends PathArgument, ?>> child3 = innerContainerNode
- .getChild(new NodeIdentifier(myLeaf2));
- assertTrue(child3.orElse(null) instanceof LeafNode);
- LeafNode<?> leafNode2 = (LeafNode<?>) child3.get();
+ DataContainerChild child3 = innerContainerNode.childByArg(new NodeIdentifier(myLeaf2));
+ assertTrue(child3 instanceof LeafNode);
+ LeafNode<?> leafNode2 = (LeafNode<?>) child3;
- Object leafNode2Value = leafNode2.getValue();
+ Object leafNode2Value = leafNode2.body();
assertEquals("any-xml-leaf-2-value", leafNode2Value);
- Optional<DataContainerChild<? extends PathArgument, ?>> child4 = yangModeledAnyXmlNode
- .getChild(new NodeIdentifier(myLeaf3));
- assertTrue(child4.orElse(null) instanceof LeafNode);
- LeafNode<?> leafNode3 = (LeafNode<?>) child4.get();
+ DataContainerChild child4 = yangModeledAnyXmlNode.childByArg(new NodeIdentifier(myLeaf3));
+ assertTrue(child4 instanceof LeafNode);
+ LeafNode<?> leafNode3 = (LeafNode<?>) child4;
- Object leafNode3Value = leafNode3.getValue();
+ Object leafNode3Value = leafNode3.body();
assertEquals("any-xml-leaf-3-value", leafNode3Value);
}
- private static final class YangModeledAnyXMLSchemaNodeImplTest implements YangModeledAnyXmlSchemaNode {
+ private static final class YangModeledAnyXMLSchemaNodeImplTest implements YangModeledAnyxmlSchemaNode {
private final QName qname;
private final ContainerSchemaNode contentSchema;
}
@Override
- public boolean isConfiguration() {
- return false;
+ public Optional<Boolean> effectiveConfig() {
+ return Optional.of(Boolean.FALSE);
}
@Override
- public ConstraintDefinition getConstraints() {
- return null;
+ public boolean isMandatory() {
+ return false;
}
- @Nonnull
@Override
public QName getQName() {
return qname;
}
- @Nonnull
@Override
+ @Deprecated
public SchemaPath getPath() {
return null;
}
- @Nonnull
- @Override
- public List<UnknownSchemaNode> getUnknownSchemaNodes() {
- return null;
- }
-
@Override
- public String getDescription() {
- return null;
+ public Optional<String> getDescription() {
+ return Optional.empty();
}
@Override
- public String getReference() {
- return null;
+ public Optional<String> getReference() {
+ return Optional.empty();
}
- @Nonnull
@Override
public Status getStatus() {
- return null;
+ return Status.CURRENT;
}
- @Nonnull
@Override
public ContainerSchemaNode getSchemaOfAnyXmlData() {
return contentSchema;
}
+
+ @Override
+ public Collection<MustDefinition> getMustConstraints() {
+ return ImmutableSet.of();
+ }
+
+ @Override
+ public Optional<? extends QualifiedBound> getWhenCondition() {
+ return Optional.empty();
+ }
+
+ @Override
+ public AnyxmlEffectiveStatement asEffectiveStatement() {
+ throw new UnsupportedOperationException();
+ }
}
}