diff options
author | Jan Srnicek <jsrnicek@cisco.com> | 2017-02-10 10:43:31 +0100 |
---|---|---|
committer | Marek Gradzki <mgradzki@cisco.com> | 2017-02-10 12:21:36 +0000 |
commit | 3c310e16d44083b03a64a78295b3295c8a0465bc (patch) | |
tree | 445ba741f108d647b27907b5beeab1a4205550a4 /lisp/lisp2vpp | |
parent | 3cecf2cd177bbcb87ad0d5eb19e8e0c80a016a5d (diff) |
HONEYCOMB-335 - Initialization test support
- initialization test support for container and list customizers
- test samples
Change-Id: If3fe4faf82a86c43fafdfab694a4388d50f61de4
Signed-off-by: Jan Srnicek <jsrnicek@cisco.com>
Diffstat (limited to 'lisp/lisp2vpp')
5 files changed, 102 insertions, 18 deletions
diff --git a/lisp/lisp2vpp/src/test/java/io/fd/hc2vpp/lisp/translate/read/LispStateCustomizerTest.java b/lisp/lisp2vpp/src/test/java/io/fd/hc2vpp/lisp/translate/read/LispStateCustomizerTest.java index 3df3f35b7..06eda220f 100644 --- a/lisp/lisp2vpp/src/test/java/io/fd/hc2vpp/lisp/translate/read/LispStateCustomizerTest.java +++ b/lisp/lisp2vpp/src/test/java/io/fd/hc2vpp/lisp/translate/read/LispStateCustomizerTest.java @@ -16,21 +16,32 @@ package io.fd.hc2vpp.lisp.translate.read; -import static org.junit.Assert.assertEquals; -import static org.mockito.Mockito.when; - +import com.google.common.collect.ImmutableSet; +import io.fd.hc2vpp.common.test.read.InitializingReaderCustomizerTest; +import io.fd.honeycomb.test.tools.HoneycombTestRunner; +import io.fd.honeycomb.test.tools.annotations.InjectTestData; +import io.fd.honeycomb.test.tools.annotations.InjectablesProcessor; +import io.fd.honeycomb.test.tools.annotations.SchemaContextProvider; import io.fd.honeycomb.translate.read.ReadFailedException; import io.fd.honeycomb.translate.spi.read.ReaderCustomizer; -import io.fd.hc2vpp.common.test.read.ReaderCustomizerTest; +import io.fd.vpp.jvpp.core.dto.ShowLispStatusReply; import org.junit.Before; import org.junit.Test; +import org.junit.runner.RunWith; import org.mockito.Mockito; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.lisp.rev170315.$YangModuleInfoImpl; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.lisp.rev170315.Lisp; import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.lisp.rev170315.LispState; import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.lisp.rev170315.LispStateBuilder; +import org.opendaylight.yangtools.sal.binding.generator.impl.ModuleInfoBackedContext; import org.opendaylight.yangtools.yang.binding.InstanceIdentifier; -import io.fd.vpp.jvpp.core.dto.ShowLispStatusReply; -public class LispStateCustomizerTest extends ReaderCustomizerTest<LispState, LispStateBuilder> { +import static org.junit.Assert.assertEquals; +import static org.mockito.Mockito.when; + +@RunWith(HoneycombTestRunner.class) +public class LispStateCustomizerTest extends InitializingReaderCustomizerTest<LispState, LispStateBuilder> + implements InjectablesProcessor{ private InstanceIdentifier<LispState> identifier; @@ -56,6 +67,21 @@ public class LispStateCustomizerTest extends ReaderCustomizerTest<LispState, Lis assertEquals(true, builder.build().isEnable()); } + @SchemaContextProvider + public ModuleInfoBackedContext schemaContext() { + return provideSchemaContextFor(ImmutableSet.of($YangModuleInfoImpl.getInstance())); + } + + + @Test + public void testInit(@InjectTestData(resourcePath = "/lisp-config.json") Lisp config, + @InjectTestData(resourcePath = "/lisp-operational.json") LispState operational) { + final InstanceIdentifier<LispState> operationalPath = InstanceIdentifier.create(LispState.class); + final InstanceIdentifier<Lisp> configPath = InstanceIdentifier.create(Lisp.class); + + invokeInitTest(operationalPath, operational, configPath, config); + } + @Override protected ReaderCustomizer<LispState, LispStateBuilder> initCustomizer() { return new LispStateCustomizer(api); diff --git a/lisp/lisp2vpp/src/test/java/io/fd/hc2vpp/lisp/translate/read/LocatorSetCustomizerTest.java b/lisp/lisp2vpp/src/test/java/io/fd/hc2vpp/lisp/translate/read/LocatorSetCustomizerTest.java index 7c57e6b63..744c57590 100644 --- a/lisp/lisp2vpp/src/test/java/io/fd/hc2vpp/lisp/translate/read/LocatorSetCustomizerTest.java +++ b/lisp/lisp2vpp/src/test/java/io/fd/hc2vpp/lisp/translate/read/LocatorSetCustomizerTest.java @@ -16,32 +16,50 @@ package io.fd.hc2vpp.lisp.translate.read; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertNotNull; -import static org.mockito.Matchers.any; -import static org.mockito.Mockito.when; - import com.google.common.collect.ImmutableList; -import io.fd.honeycomb.translate.spi.read.ReaderCustomizer; +import com.google.common.collect.ImmutableSet; +import io.fd.hc2vpp.common.test.read.InitializingListReaderCustomizerTest; import io.fd.hc2vpp.common.translate.util.NamingContext; -import io.fd.hc2vpp.common.test.read.ListReaderCustomizerTest; -import java.nio.charset.StandardCharsets; -import java.util.List; +import io.fd.honeycomb.test.tools.HoneycombTestRunner; +import io.fd.honeycomb.test.tools.annotations.InjectTestData; +import io.fd.honeycomb.test.tools.annotations.InjectablesProcessor; +import io.fd.honeycomb.test.tools.annotations.SchemaContextProvider; +import io.fd.honeycomb.translate.spi.read.ReaderCustomizer; +import io.fd.vpp.jvpp.core.dto.LispLocatorSetDetails; +import io.fd.vpp.jvpp.core.dto.LispLocatorSetDetailsReplyDump; import org.junit.Before; import org.junit.Test; +import org.junit.runner.RunWith; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.lisp.rev170315.$YangModuleInfoImpl; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.lisp.rev170315.Lisp; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.lisp.rev170315.LispState; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.lisp.rev170315.lisp.feature.data.grouping.LispFeatureData; import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.lisp.rev170315.locator.sets.grouping.LocatorSets; import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.lisp.rev170315.locator.sets.grouping.LocatorSetsBuilder; import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.lisp.rev170315.locator.sets.grouping.locator.sets.LocatorSet; import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.lisp.rev170315.locator.sets.grouping.locator.sets.LocatorSetBuilder; import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.lisp.rev170315.locator.sets.grouping.locator.sets.LocatorSetKey; +import org.opendaylight.yangtools.sal.binding.generator.impl.ModuleInfoBackedContext; import org.opendaylight.yangtools.yang.binding.InstanceIdentifier; -import io.fd.vpp.jvpp.core.dto.LispLocatorSetDetails; -import io.fd.vpp.jvpp.core.dto.LispLocatorSetDetailsReplyDump; +import org.opendaylight.yangtools.yang.binding.KeyedInstanceIdentifier; +import java.nio.charset.StandardCharsets; +import java.util.List; + +import static org.junit.Assert.assertEquals; +import static org.junit.Assert.assertNotNull; +import static org.mockito.Matchers.any; +import static org.mockito.Mockito.when; +@RunWith(HoneycombTestRunner.class) public class LocatorSetCustomizerTest - extends ListReaderCustomizerTest<LocatorSet, LocatorSetKey, LocatorSetBuilder> { + extends InitializingListReaderCustomizerTest<LocatorSet, LocatorSetKey, LocatorSetBuilder> + implements InjectablesProcessor { + private static final String LOC_1_PATH = "/lisp:lisp-state" + + "/lisp:lisp-feature-data" + + "/lisp:locator-sets" + + "/lisp:locator-set[lisp:name='loc1']"; private InstanceIdentifier<LocatorSet> emptyId; private InstanceIdentifier<LocatorSet> validId; @@ -89,6 +107,27 @@ public class LocatorSetCustomizerTest assertEquals("loc-set", keys.get(0).getName()); } + @SchemaContextProvider + public ModuleInfoBackedContext schemaContext() { + return provideSchemaContextFor(ImmutableSet.of($YangModuleInfoImpl.getInstance())); + } + + @Test + public void testInit(@InjectTestData(resourcePath = "/locator-set.json", id = LOC_1_PATH) LocatorSet locatorSet) { + final LocatorSetKey loc1Key = new LocatorSetKey("loc1"); + final KeyedInstanceIdentifier<LocatorSet, LocatorSetKey> operationalPath = InstanceIdentifier.create(LispState.class) + .child(LispFeatureData.class) + .child(LocatorSets.class) + .child(LocatorSet.class, loc1Key); + + final KeyedInstanceIdentifier<LocatorSet, LocatorSetKey> configPath = InstanceIdentifier.create(Lisp.class) + .child(LispFeatureData.class) + .child(LocatorSets.class) + .child(LocatorSet.class, loc1Key); + + invokeInitTest(operationalPath, locatorSet, configPath, locatorSet); + } + @Override protected ReaderCustomizer<LocatorSet, LocatorSetBuilder> initCustomizer() { return new LocatorSetCustomizer(api, new NamingContext("loc", "locator-set-context")); diff --git a/lisp/lisp2vpp/src/test/resources/lisp-config.json b/lisp/lisp2vpp/src/test/resources/lisp-config.json new file mode 100644 index 000000000..27a92db58 --- /dev/null +++ b/lisp/lisp2vpp/src/test/resources/lisp-config.json @@ -0,0 +1,7 @@ +{ + "lisp": { + "enable": true, + "lisp-feature-data": { + } + } +}
\ No newline at end of file diff --git a/lisp/lisp2vpp/src/test/resources/lisp-operational.json b/lisp/lisp2vpp/src/test/resources/lisp-operational.json new file mode 100644 index 000000000..436b71292 --- /dev/null +++ b/lisp/lisp2vpp/src/test/resources/lisp-operational.json @@ -0,0 +1,7 @@ +{ + "lisp-state": { + "enable":true, + "lisp-feature-data": { + } + } +}
\ No newline at end of file diff --git a/lisp/lisp2vpp/src/test/resources/locator-set.json b/lisp/lisp2vpp/src/test/resources/locator-set.json new file mode 100644 index 000000000..446ba1104 --- /dev/null +++ b/lisp/lisp2vpp/src/test/resources/locator-set.json @@ -0,0 +1,5 @@ +{ + "locator-set": { + "name": "loc1" + } +}
\ No newline at end of file |