From 51d14eec11a226a11beb607421ef7ff656a7be0c Mon Sep 17 00:00:00 2001 From: Hongjun Ni Date: Thu, 13 Oct 2016 21:04:25 +0800 Subject: Add NSH map test case. HONEYCOMB-198 Change-Id: I2d2fc50e25350d95d6b529eb3af045ea23e661ec Signed-off-by: Hongjun Ni --- .../impl/config/NshMapWriterCustomizerTest.java | 184 +++++++++++++++++++++ .../impl/oper/NshEntryReaderCustomizerTest.java | 1 - .../impl/oper/NshMapReaderCustomizerTest.java | 119 +++++++++++++ 3 files changed, 303 insertions(+), 1 deletion(-) create mode 100644 nsh/impl/src/test/java/io/fd/honeycomb/vppnsh/impl/config/NshMapWriterCustomizerTest.java create mode 100644 nsh/impl/src/test/java/io/fd/honeycomb/vppnsh/impl/oper/NshMapReaderCustomizerTest.java (limited to 'nsh') diff --git a/nsh/impl/src/test/java/io/fd/honeycomb/vppnsh/impl/config/NshMapWriterCustomizerTest.java b/nsh/impl/src/test/java/io/fd/honeycomb/vppnsh/impl/config/NshMapWriterCustomizerTest.java new file mode 100644 index 000000000..e15e9c6e8 --- /dev/null +++ b/nsh/impl/src/test/java/io/fd/honeycomb/vppnsh/impl/config/NshMapWriterCustomizerTest.java @@ -0,0 +1,184 @@ +/* + * Copyright (c) 2016 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.honeycomb.vppnsh.impl.config; + +import static org.junit.Assert.assertTrue; +import static org.junit.Assert.fail; +import static org.mockito.Matchers.any; +import static org.mockito.Mockito.doReturn; +import static org.mockito.Mockito.times; +import static org.mockito.Mockito.verify; +import static org.mockito.Mockito.when; + +import io.fd.honeycomb.translate.vpp.util.NamingContext; +import io.fd.honeycomb.translate.write.WriteFailedException; +import io.fd.honeycomb.vpp.test.write.WriterCustomizerTest; +import org.junit.Test; +import org.mockito.Mock; +import org.opendaylight.yangtools.yang.binding.InstanceIdentifier; +import io.fd.honeycomb.translate.MappingContext; + +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.vpp.nsh.rev160624.VxlanGpe; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.vpp.nsh.rev160624.vpp.nsh.NshMaps; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.vpp.nsh.rev160624.vpp.nsh.NshMapsBuilder; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.vpp.nsh.rev160624.vpp.nsh.nsh.maps.NshMap; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.vpp.nsh.rev160624.vpp.nsh.nsh.maps.NshMapBuilder; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.vpp.nsh.rev160624.vpp.nsh.nsh.maps.NshMapKey; + +import io.fd.vpp.jvpp.VppBaseCallException; +import io.fd.vpp.jvpp.nsh.dto.NshAddDelMap; +import io.fd.vpp.jvpp.nsh.dto.NshAddDelMapReply; +import io.fd.vpp.jvpp.nsh.future.FutureJVppNsh; + +public class NshMapWriterCustomizerTest extends WriterCustomizerTest { + + private static final String MAP_CTX_NAME = "nsh-map-instance"; + private static final int MAP_INDEX = 1; + private static final String MAP_NAME = "map"; + + private static final String INT_CTX_NAME = "interface-instance"; + private static final int ITF_INDEX = 3; + private static final String ITF_NAME = "vxlanGpeTun3"; + + @Mock + protected FutureJVppNsh jvppNsh; + + private NamingContext nshContext; + + private NamingContext interfaceContext; + + private NshMapWriterCustomizer customizer; + + @Override + public void setUp() throws Exception { + nshContext = new NamingContext("nsh_map", MAP_CTX_NAME); + defineMapping(mappingContext, MAP_NAME, MAP_INDEX, MAP_CTX_NAME); + interfaceContext = new NamingContext("interface", INT_CTX_NAME); + defineMapping(mappingContext, ITF_NAME, ITF_INDEX, INT_CTX_NAME); + + customizer = new NshMapWriterCustomizer(jvppNsh, nshContext, interfaceContext); + } + + private static NshMap generateNshMap(final String name) { + final NshMapBuilder builder = new NshMapBuilder(); + builder.setName(name); + builder.setKey(new NshMapKey(name)); + builder.setNsp(184L); + builder.setNsi((short) 255); + builder.setMappedNsp(183L); + builder.setMappedNsi((short) 254); + builder.setEncapType(VxlanGpe.class); + builder.setEncapIfName("vxlanGpeTun3"); + + return builder.build(); + } + + private static InstanceIdentifier getNshMapId(final String name) { + return InstanceIdentifier.create(NshMaps.class) + .child(NshMap.class, new NshMapKey(name)); + } + + private void whenNshAddDelMapThenSuccess() { + final NshAddDelMapReply reply = new NshAddDelMapReply(); + reply.mapIndex = MAP_INDEX; + doReturn(future(reply)).when(jvppNsh).nshAddDelMap(any(NshAddDelMap.class)); + } + + private void whenNshAddDelMapThenFailure() { + doReturn(failedFuture()).when(jvppNsh).nshAddDelMap(any(NshAddDelMap.class)); + } + + private static NshAddDelMap generateNshAddDelMap(final byte isAdd) { + final NshAddDelMap request = new NshAddDelMap(); + request.isAdd = isAdd; + request.nspNsi = 184<<8 | 255; + request.mappedNspNsi = 183<<8 | 254; + request.swIfIndex = ITF_INDEX; + request.nextNode = 2; + + return request; + } + + @Test + public void testCreate() throws Exception { + final NshMap nshMap = generateNshMap(MAP_NAME); + final InstanceIdentifier id = getNshMapId(MAP_NAME); + + whenNshAddDelMapThenSuccess(); + + customizer.writeCurrentAttributes(id, nshMap, writeContext); + + verify(jvppNsh).nshAddDelMap(generateNshAddDelMap((byte) 1)); + + } + + @Test + public void testCreateFailed() throws Exception { + final NshMap nshMap = generateNshMap(MAP_NAME); + final InstanceIdentifier id = getNshMapId(MAP_NAME); + + whenNshAddDelMapThenFailure(); + + try { + customizer.writeCurrentAttributes(id, nshMap, writeContext); + } catch (WriteFailedException e) { + assertTrue(e.getCause() instanceof VppBaseCallException); + verify(jvppNsh).nshAddDelMap(generateNshAddDelMap((byte) 1)); + + return; + } + fail("WriteFailedException.CreateFailedException was expected"); + } + + @Test + public void testDelete() throws Exception { + final NshMap nshMap = generateNshMap(MAP_NAME); + final InstanceIdentifier id = getNshMapId(MAP_NAME); + + whenNshAddDelMapThenSuccess(); + + customizer.deleteCurrentAttributes(id, nshMap, writeContext); + + verify(jvppNsh).nshAddDelMap(generateNshAddDelMap((byte) 0)); + } + + @Test + public void testDeleteFailed() throws Exception { + final NshMap nshMap = generateNshMap(MAP_NAME); + final InstanceIdentifier id = getNshMapId(MAP_NAME); + + whenNshAddDelMapThenFailure(); + + try { + customizer.deleteCurrentAttributes(id, nshMap, writeContext); + } catch (WriteFailedException e) { + assertTrue(e.getCause() instanceof VppBaseCallException); + verify(jvppNsh).nshAddDelMap(generateNshAddDelMap((byte) 0)); + return; + } + fail("WriteFailedException.DeleteFailedException was expected"); + + customizer.deleteCurrentAttributes(id, nshMap, writeContext); + } + + @Test(expected = UnsupportedOperationException.class) + public void testUpdate() throws Exception { + final NshMap nshMapBefore = generateNshMap(MAP_NAME); + final InstanceIdentifier id = getNshMapId(MAP_NAME); + customizer.updateCurrentAttributes(id, nshMapBefore, new NshMapBuilder().build(), writeContext); + } +} \ No newline at end of file diff --git a/nsh/impl/src/test/java/io/fd/honeycomb/vppnsh/impl/oper/NshEntryReaderCustomizerTest.java b/nsh/impl/src/test/java/io/fd/honeycomb/vppnsh/impl/oper/NshEntryReaderCustomizerTest.java index 3171081c9..61e89bc1c 100644 --- a/nsh/impl/src/test/java/io/fd/honeycomb/vppnsh/impl/oper/NshEntryReaderCustomizerTest.java +++ b/nsh/impl/src/test/java/io/fd/honeycomb/vppnsh/impl/oper/NshEntryReaderCustomizerTest.java @@ -36,7 +36,6 @@ import org.mockito.Mock; import io.fd.honeycomb.translate.vpp.util.NamingContext; import org.opendaylight.yangtools.yang.binding.InstanceIdentifier; -import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.vpp.classifier.rev150603.vpp.classifier.state.ClassifyTableKey; import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.vpp.nsh.rev160624.Ethernet; import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.vpp.nsh.rev160624.Ipv4; import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.vpp.nsh.rev160624.Ipv6; diff --git a/nsh/impl/src/test/java/io/fd/honeycomb/vppnsh/impl/oper/NshMapReaderCustomizerTest.java b/nsh/impl/src/test/java/io/fd/honeycomb/vppnsh/impl/oper/NshMapReaderCustomizerTest.java new file mode 100644 index 000000000..0c14939c1 --- /dev/null +++ b/nsh/impl/src/test/java/io/fd/honeycomb/vppnsh/impl/oper/NshMapReaderCustomizerTest.java @@ -0,0 +1,119 @@ +/* + * Copyright (c) 2016 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.honeycomb.vppnsh.impl.oper; + +import static org.junit.Assert.assertEquals; +import static org.mockito.Matchers.any; +import static org.mockito.Matchers.anyString; +import static org.mockito.Mockito.doReturn; +import static org.mockito.Mockito.mock; +import static org.mockito.Mockito.times; +import static org.mockito.Mockito.verify; +import static org.mockito.Mockito.when; + +import com.google.common.base.Optional; +import com.google.common.collect.Lists; +import io.fd.honeycomb.translate.read.ReadFailedException; +import io.fd.honeycomb.translate.spi.read.ReaderCustomizer; +import io.fd.honeycomb.vpp.test.read.ListReaderCustomizerTest; +import java.util.List; +import org.junit.Test; +import org.mockito.Mock; + +import io.fd.honeycomb.translate.vpp.util.NamingContext; +import org.opendaylight.yangtools.yang.binding.InstanceIdentifier; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.vpp.nsh.rev160624.VxlanGpe; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.vpp.nsh.rev160624.VppNshState; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.vpp.nsh.rev160624.VppNshStateBuilder; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.vpp.nsh.rev160624.vpp.nsh.state.NshMaps; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.vpp.nsh.rev160624.vpp.nsh.state.NshMapsBuilder; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.vpp.nsh.rev160624.vpp.nsh.state.nsh.maps.NshMap; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.vpp.nsh.rev160624.vpp.nsh.state.nsh.maps.NshMapBuilder; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.vpp.nsh.rev160624.vpp.nsh.state.nsh.maps.NshMapKey; + +import io.fd.vpp.jvpp.VppBaseCallException; +import io.fd.vpp.jvpp.nsh.dto.NshMapDetails; +import io.fd.vpp.jvpp.nsh.dto.NshMapDetailsReplyDump; +import io.fd.vpp.jvpp.nsh.dto.NshMapDump; +import io.fd.vpp.jvpp.nsh.future.FutureJVppNsh; + + +public class NshMapReaderCustomizerTest extends + ListReaderCustomizerTest { + + private static final String MAP_CTX_NAME = "nsh-map-instance"; + private static final int MAP_INDEX_1 = 1; + private static final String MAP_NAME_1 = "map1"; + + private static final String INT_CTX_NAME = "interface-instance"; + private static final int ITF_INDEX = 3; + private static final String ITF_NAME = "vxlanGpeTun3"; + + @Mock + protected FutureJVppNsh jvppNsh; + + private NamingContext nshContext; + + private NamingContext interfaceContext; + + public NshMapReaderCustomizerTest() { + super(NshMap.class, NshMapsBuilder.class); + } + + @Override + protected ReaderCustomizer initCustomizer() { + return new NshMapReaderCustomizer(jvppNsh, nshContext, interfaceContext); + } + + private static InstanceIdentifier getNshMapId(final String name) { + return InstanceIdentifier.create(NshMaps.class) + .child(NshMap.class, new NshMapKey(name)); + } + + @Override + public void setUp() throws VppBaseCallException { + nshContext = new NamingContext("nsh_map", MAP_CTX_NAME); + defineMapping(mappingContext, MAP_NAME_1, MAP_INDEX_1, MAP_CTX_NAME); + interfaceContext = new NamingContext("interface", INT_CTX_NAME); + defineMapping(mappingContext, ITF_NAME, ITF_INDEX, INT_CTX_NAME); + + final NshMapDetailsReplyDump reply = new NshMapDetailsReplyDump(); + final NshMapDetails nshMapDetails = new NshMapDetails(); + nshMapDetails.nspNsi = (184<<8 | 255); + nshMapDetails.mappedNspNsi = (183<<8 | 254); + nshMapDetails.swIfIndex = ITF_INDEX; + nshMapDetails.nextNode = 2; + reply.nshMapDetails = Lists.newArrayList(nshMapDetails); + doReturn(future(reply)).when(jvppNsh).nshMapDump(any(NshMapDump.class)); + } + + @Test + public void testreadCurrentAttributes() throws ReadFailedException { + + NshMapBuilder builder = new NshMapBuilder(); + getCustomizer().readCurrentAttributes(getNshMapId(MAP_NAME_1), builder, ctx); + + assertEquals(184, builder.getNsp().intValue()); + assertEquals(255, builder.getNsi().intValue()); + assertEquals(183, builder.getMappedNsp().intValue()); + assertEquals(254, builder.getMappedNsi().intValue()); + assertEquals(VxlanGpe.class, builder.getEncapType()); + assertEquals("vxlanGpeTun3", builder.getEncapIfName()); + + verify(jvppNsh).nshMapDump(any(NshMapDump.class)); + } +} -- cgit 1.2.3-korg