* 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 java.io.InputStream;
-import java.net.URI;
import java.util.Collection;
-import java.util.Optional;
import javax.xml.stream.XMLStreamReader;
-import org.junit.Before;
import org.junit.Test;
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.common.Revision;
+import org.opendaylight.yangtools.yang.common.XMLNamespace;
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.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.MapEntryNode;
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.ContainerSchemaNode;
-import org.opendaylight.yangtools.yang.model.api.DataSchemaNode;
-import org.opendaylight.yangtools.yang.model.api.Module;
-import org.opendaylight.yangtools.yang.model.api.SchemaContext;
+import org.opendaylight.yangtools.yang.model.api.EffectiveModelContext;
+import org.opendaylight.yangtools.yang.model.util.SchemaInferenceStack.Inference;
import org.opendaylight.yangtools.yang.test.util.YangParserTestUtils;
public class Bug890Test {
- private static final QNameModule FOO_MODULE = QNameModule.create(URI.create("foo"), Revision.of("2018-07-10"));
+ private static final QNameModule FOO_MODULE = QNameModule.create(XMLNamespace.of("foo"), Revision.of("2018-07-10"));
private static final QName OUTGOING_LABELS_QNAME = QName.create(FOO_MODULE, "outgoing-labels");
private static final QName INDEX_QNAME = QName.create(FOO_MODULE, "index");
- private SchemaContext schemaContext;
-
- @Before
- public void setUp() throws Exception {
- schemaContext = YangParserTestUtils.parseYangResource("/bug890/yang/foo.yang");
- }
-
@Test
public void testinputXml() throws Exception {
+ final EffectiveModelContext schemaContext = YangParserTestUtils.parseYangResource("/bug890/yang/foo.yang");
final InputStream resourceAsStream = XmlToNormalizedNodesTest.class.getResourceAsStream("/bug890/xml/foo.xml");
- final Module fooModule = schemaContext.getModules().iterator().next();
- final Optional<DataSchemaNode> rootCont = fooModule.findDataChildByName(
- QName.create(fooModule.getQNameModule(), "root"));
- assertTrue(rootCont.isPresent());
- ContainerSchemaNode containerSchemaNode = (ContainerSchemaNode) rootCont.get();
- assertNotNull(containerSchemaNode);
final XMLStreamReader reader = UntrustedXML.createXMLStreamReader(resourceAsStream);
final NormalizedNodeStreamWriter streamWriter = ImmutableNormalizedNodeStreamWriter.from(result);
- final XmlParserStream xmlParser = XmlParserStream.create(streamWriter, schemaContext, containerSchemaNode);
+ final XmlParserStream xmlParser = XmlParserStream.create(streamWriter,
+ Inference.ofDataTreePath(schemaContext, QName.create(FOO_MODULE, "root")));
xmlParser.parse(reader);
assertNotNull(result.getResult());
assertTrue(result.getResult() instanceof ContainerNode);
final ContainerNode rootContainer = (ContainerNode) result.getResult();
- Optional<DataContainerChild<? extends PathArgument, ?>> myLeaf =
- rootContainer.getChild(new NodeIdentifier(OUTGOING_LABELS_QNAME));
- assertTrue(myLeaf.orElse(null) instanceof ContainerNode);
+ DataContainerChild myLeaf = rootContainer.childByArg(new NodeIdentifier(OUTGOING_LABELS_QNAME));
+ assertTrue(myLeaf instanceof ContainerNode);
- ContainerNode outgoingLabelsContainer = (ContainerNode)myLeaf.get();
- Optional<DataContainerChild<? extends PathArgument, ?>> outgoingLabelsList =
- outgoingLabelsContainer.getChild(new NodeIdentifier(OUTGOING_LABELS_QNAME));
- assertTrue(outgoingLabelsList.orElse(null) instanceof MapNode);
- MapNode outgoingLabelsMap = (MapNode) outgoingLabelsList.get();
+ ContainerNode outgoingLabelsContainer = (ContainerNode)myLeaf;
+ DataContainerChild outgoingLabelsList =
+ outgoingLabelsContainer.childByArg(new NodeIdentifier(OUTGOING_LABELS_QNAME));
+ assertTrue(outgoingLabelsList instanceof MapNode);
+ MapNode outgoingLabelsMap = (MapNode) outgoingLabelsList;
assertEquals(2, outgoingLabelsMap.size());
- Collection<MapEntryNode> labels = outgoingLabelsMap.getValue();
+ Collection<MapEntryNode> labels = outgoingLabelsMap.body();
NodeIdentifierWithPredicates firstNodeId =
NodeIdentifierWithPredicates.of(OUTGOING_LABELS_QNAME, INDEX_QNAME, 0);
NodeIdentifierWithPredicates secondNodeId =