X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=binding%2Fmdsal-binding-dom-codec%2Fsrc%2Ftest%2Fjava%2Forg%2Fopendaylight%2Fmdsal%2Fbinding%2Fdom%2Fcodec%2Fimpl%2FExceptionReportingTest.java;h=2e0de327aacfa668dcaa36a2fb18ebc91e7ea946;hb=eb7ab8e1bb6a28cfafd22a5a62ea66e5f85a8c2d;hp=831eccb20e4db58989ac4423bf807373e609fc37;hpb=191052b2c293127f62f39802da76151653cf369b;p=mdsal.git diff --git a/binding/mdsal-binding-dom-codec/src/test/java/org/opendaylight/mdsal/binding/dom/codec/impl/ExceptionReportingTest.java b/binding/mdsal-binding-dom-codec/src/test/java/org/opendaylight/mdsal/binding/dom/codec/impl/ExceptionReportingTest.java index 831eccb20e..2e0de327aa 100644 --- a/binding/mdsal-binding-dom-codec/src/test/java/org/opendaylight/mdsal/binding/dom/codec/impl/ExceptionReportingTest.java +++ b/binding/mdsal-binding-dom-codec/src/test/java/org/opendaylight/mdsal/binding/dom/codec/impl/ExceptionReportingTest.java @@ -7,13 +7,14 @@ */ package org.opendaylight.mdsal.binding.dom.codec.impl; +import static org.junit.Assert.assertThrows; + import org.junit.Test; -import org.opendaylight.binding.runtime.spi.BindingRuntimeHelpers; import org.opendaylight.mdsal.binding.dom.codec.api.BindingNormalizedNodeSerializer; import org.opendaylight.mdsal.binding.dom.codec.api.IncorrectNestingException; import org.opendaylight.mdsal.binding.dom.codec.api.MissingSchemaException; import org.opendaylight.mdsal.binding.dom.codec.api.MissingSchemaForClassException; -import org.opendaylight.mdsal.binding.generator.impl.DefaultBindingRuntimeGenerator; +import org.opendaylight.mdsal.binding.runtime.spi.BindingRuntimeHelpers; import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.mdsal.test.augment.rev140709.TreeComplexUsesAugment; import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.mdsal.test.augment.rev140709.TreeLeafOnlyAugment; import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.mdsal.test.binding.rev140701.Top; @@ -21,7 +22,6 @@ import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.mdsal.te import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.mdsal.test.binding.rev140701.two.level.list.TopLevelListKey; import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.yangtools.test.union.rev150121.LowestLevel1; import org.opendaylight.yangtools.yang.binding.InstanceIdentifier; -import org.opendaylight.yangtools.yang.common.QName; import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier; public class ExceptionReportingTest { @@ -30,50 +30,53 @@ public class ExceptionReportingTest { private static final BindingNormalizedNodeSerializer FULL_CODEC = codec(TreeComplexUsesAugment.class); private static final TopLevelListKey TOP_FOO_KEY = new TopLevelListKey("foo"); - private static final InstanceIdentifier BA_TOP_LEVEL_LIST = InstanceIdentifier - .builder(Top.class).child(TopLevelList.class, TOP_FOO_KEY).build(); + private static final InstanceIdentifier BA_TOP_LEVEL_LIST = InstanceIdentifier.builder(Top.class) + .child(TopLevelList.class, TOP_FOO_KEY) + .build(); private static final InstanceIdentifier BA_TREE_LEAF_ONLY = - BA_TOP_LEVEL_LIST.augmentation(TreeLeafOnlyAugment.class); + BA_TOP_LEVEL_LIST.augmentation(TreeLeafOnlyAugment.class); - private static final QName TOP_QNAME = Top.QNAME; - private static final YangInstanceIdentifier BI_TOP_PATH = YangInstanceIdentifier.builder().node(TOP_QNAME).build(); - private static final YangInstanceIdentifier BI_TREE_LEAF_ONLY = FULL_CODEC.toYangInstanceIdentifier( - BA_TREE_LEAF_ONLY); + private static final YangInstanceIdentifier BI_TOP_PATH = YangInstanceIdentifier.of(Top.QNAME); - @Test(expected = MissingSchemaException.class) + @Test public void testDOMTop() { - CODEC_WITHOUT_TOP.fromYangInstanceIdentifier(BI_TOP_PATH); + assertThrows(MissingSchemaException.class, + () -> CODEC_WITHOUT_TOP.fromYangInstanceIdentifier(BI_TOP_PATH)); } - @Test(expected = MissingSchemaException.class) + @Test public void testDOMAugment() { - CODEC_WITHOUT_TOP.fromYangInstanceIdentifier(BI_TREE_LEAF_ONLY); + final var yiid = FULL_CODEC.toYangInstanceIdentifier(BA_TREE_LEAF_ONLY); + assertThrows(MissingSchemaException.class, () -> CODEC_WITHOUT_TOP.fromYangInstanceIdentifier(yiid)); } - @Test(expected = MissingSchemaForClassException.class) + @Test public void testBindingTop() { - CODEC_WITHOUT_TOP.toYangInstanceIdentifier(BA_TOP_LEVEL_LIST); + assertThrows(MissingSchemaForClassException.class, + () -> CODEC_WITHOUT_TOP.toYangInstanceIdentifier(BA_TOP_LEVEL_LIST)); } - @Test(expected = MissingSchemaForClassException.class) + @Test public void testBindingAugment() { - ONLY_TOP_CODEC.toYangInstanceIdentifier(BA_TREE_LEAF_ONLY); + assertThrows(MissingSchemaForClassException.class, + () -> ONLY_TOP_CODEC.toYangInstanceIdentifier(BA_TREE_LEAF_ONLY)); } - @Test(expected = IncorrectNestingException.class) + @Test public void testBindingSkippedRoot() { - FULL_CODEC.toYangInstanceIdentifier(InstanceIdentifier.create(TopLevelList.class)); + @SuppressWarnings({"unchecked", "rawtypes"}) + final var iid = InstanceIdentifier.create((Class) TopLevelList.class); + assertThrows(IncorrectNestingException.class, () -> FULL_CODEC.toYangInstanceIdentifier(iid)); } - @SuppressWarnings({"unchecked", "rawtypes"}) - @Test(expected = IncorrectNestingException.class) + @Test public void testBindingIncorrectAugment() { - FULL_CODEC.toYangInstanceIdentifier(InstanceIdentifier.create(Top.class).augmentation( - (Class) TreeComplexUsesAugment.class)); + @SuppressWarnings({"unchecked", "rawtypes"}) + final var iid = InstanceIdentifier.create(Top.class).augmentation((Class) TreeComplexUsesAugment.class); + assertThrows(IncorrectNestingException.class, () -> FULL_CODEC.toYangInstanceIdentifier(iid)); } private static BindingNormalizedNodeSerializer codec(final Class... classes) { - return new BindingCodecContext(BindingRuntimeHelpers.createRuntimeContext( - new DefaultBindingRuntimeGenerator(), classes)); + return new BindingCodecContext(BindingRuntimeHelpers.createRuntimeContext(classes)); } }