From 3c310e16d44083b03a64a78295b3295c8a0465bc Mon Sep 17 00:00:00 2001 From: Jan Srnicek Date: Fri, 10 Feb 2017 10:43:31 +0100 Subject: HONEYCOMB-335 - Initialization test support - initialization test support for container and list customizers - test samples Change-Id: If3fe4faf82a86c43fafdfab694a4388d50f61de4 Signed-off-by: Jan Srnicek --- .../common/test/read/InitializationTest.java | 54 ++++++++++++++++++++++ .../read/InitializingListReaderCustomizerTest.java | 17 +++++-- .../read/InitializingReaderCustomizerTest.java | 12 ++++- 3 files changed, 79 insertions(+), 4 deletions(-) create mode 100644 vpp-common/vpp-translate-test/src/main/java/io/fd/hc2vpp/common/test/read/InitializationTest.java (limited to 'vpp-common') diff --git a/vpp-common/vpp-translate-test/src/main/java/io/fd/hc2vpp/common/test/read/InitializationTest.java b/vpp-common/vpp-translate-test/src/main/java/io/fd/hc2vpp/common/test/read/InitializationTest.java new file mode 100644 index 000000000..5ea1257ce --- /dev/null +++ b/vpp-common/vpp-translate-test/src/main/java/io/fd/hc2vpp/common/test/read/InitializationTest.java @@ -0,0 +1,54 @@ +/* + * Copyright (c) 2017 Cisco and/or its affiliates. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at: + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package io.fd.hc2vpp.common.test.read; + + +import io.fd.honeycomb.translate.read.ReadContext; +import io.fd.honeycomb.translate.spi.read.Initialized; +import io.fd.honeycomb.translate.spi.read.InitializingCustomizer; +import org.opendaylight.yangtools.yang.binding.DataObject; +import org.opendaylight.yangtools.yang.binding.InstanceIdentifier; + +import javax.annotation.Nonnull; + +import static org.junit.Assert.assertEquals; +import static org.junit.Assert.assertNotNull; + +interface InitializationTest { + + /** + * Invokes initialization test + * + * @param customizer initialization capable customizer + * @param ctx read context + * @param operationalPath paths passed to initialization + * @param operationalData data passed to initialization + * @param configPath expected data path + * @param configData expected data + */ + default void invokeInit(@Nonnull final InitializingCustomizer customizer, + @Nonnull final ReadContext ctx, + @Nonnull final InstanceIdentifier operationalPath, + @Nonnull final D operationalData, + @Nonnull final InstanceIdentifier configPath, + @Nonnull final Object configData) { + final Initialized init = customizer.init(operationalPath, operationalData, ctx); + assertNotNull(init); + assertEquals(configPath, init.getId()); + assertEquals(configData, init.getData()); + } +} diff --git a/vpp-common/vpp-translate-test/src/main/java/io/fd/hc2vpp/common/test/read/InitializingListReaderCustomizerTest.java b/vpp-common/vpp-translate-test/src/main/java/io/fd/hc2vpp/common/test/read/InitializingListReaderCustomizerTest.java index b6089c4da..7ad2055c7 100644 --- a/vpp-common/vpp-translate-test/src/main/java/io/fd/hc2vpp/common/test/read/InitializingListReaderCustomizerTest.java +++ b/vpp-common/vpp-translate-test/src/main/java/io/fd/hc2vpp/common/test/read/InitializingListReaderCustomizerTest.java @@ -21,6 +21,9 @@ import org.opendaylight.yangtools.concepts.Builder; import org.opendaylight.yangtools.yang.binding.DataObject; import org.opendaylight.yangtools.yang.binding.Identifiable; import org.opendaylight.yangtools.yang.binding.Identifier; +import org.opendaylight.yangtools.yang.binding.InstanceIdentifier; + +import javax.annotation.Nonnull; /** * Generic test for classes implementing {@link InitializingListReaderCustomizer} interface. @@ -30,11 +33,12 @@ import org.opendaylight.yangtools.yang.binding.Identifier; * @param Specific Builder for handled type (D) */ public abstract class InitializingListReaderCustomizerTest, K extends Identifier, B extends Builder> extends - ListReaderCustomizerTest { + ListReaderCustomizerTest implements InitializationTest { + protected InitializingListReaderCustomizerTest( - final Class dataObjectClass, - final Class> parentBuilderClass) { + final Class dataObjectClass, + final Class> parentBuilderClass) { super(dataObjectClass, parentBuilderClass); } @@ -42,4 +46,11 @@ public abstract class InitializingListReaderCustomizerTest getCustomizer() { return InitializingListReaderCustomizer.class.cast(super.getCustomizer()); } + + protected void invokeInitTest(@Nonnull InstanceIdentifier operationalPath, + @Nonnull D operationalData, + @Nonnull InstanceIdentifier configPath, + @Nonnull Object configData) { + invokeInit(getCustomizer(), ctx, operationalPath, operationalData, configPath, configData); + } } diff --git a/vpp-common/vpp-translate-test/src/main/java/io/fd/hc2vpp/common/test/read/InitializingReaderCustomizerTest.java b/vpp-common/vpp-translate-test/src/main/java/io/fd/hc2vpp/common/test/read/InitializingReaderCustomizerTest.java index e102ef827..69fd6abac 100644 --- a/vpp-common/vpp-translate-test/src/main/java/io/fd/hc2vpp/common/test/read/InitializingReaderCustomizerTest.java +++ b/vpp-common/vpp-translate-test/src/main/java/io/fd/hc2vpp/common/test/read/InitializingReaderCustomizerTest.java @@ -19,6 +19,9 @@ package io.fd.hc2vpp.common.test.read; import io.fd.honeycomb.translate.spi.read.InitializingReaderCustomizer; import org.opendaylight.yangtools.concepts.Builder; import org.opendaylight.yangtools.yang.binding.DataObject; +import org.opendaylight.yangtools.yang.binding.InstanceIdentifier; + +import javax.annotation.Nonnull; /** * Generic test for classes implementing {@link InitializingReaderCustomizer} interface. @@ -27,7 +30,7 @@ import org.opendaylight.yangtools.yang.binding.DataObject; * @param Specific Builder for handled type (D) */ public abstract class InitializingReaderCustomizerTest> extends - ReaderCustomizerTest { + ReaderCustomizerTest implements InitializationTest { protected InitializingReaderCustomizerTest( final Class dataObjectClass, @@ -39,4 +42,11 @@ public abstract class InitializingReaderCustomizerTest getCustomizer() { return InitializingReaderCustomizer.class.cast(super.getCustomizer()); } + + protected void invokeInitTest(@Nonnull InstanceIdentifier operationalPath, + @Nonnull D operationalData, + @Nonnull InstanceIdentifier configPath, + @Nonnull Object configData) { + invokeInit(getCustomizer(), ctx, operationalPath, operationalData, configPath, configData); + } } -- cgit 1.2.3-korg