summaryrefslogtreecommitdiffstats
path: root/lisp/lisp2vpp/src/test/java/io/fd
diff options
context:
space:
mode:
authorJan Srnicek <jsrnicek@cisco.com>2017-06-16 08:32:59 +0200
committerMarek Gradzki <mgradzki@cisco.com>2017-06-19 05:36:32 +0000
commit71b28394e5024ecc87c2a8dc5adbabd812cae740 (patch)
tree9d0efe4d8dddf1acd32c2930369f63c2a6be1110 /lisp/lisp2vpp/src/test/java/io/fd
parent351c2a3f03c1bea10030dfce99d0a2a9cba72bb6 (diff)
HC2VPP-168 - Gpe native entries support(write only)
requires https://gerrit.fd.io/r/#/c/7168 to be merged Change-Id: I5b734af662e651df5753f64f14b6b44d863ecbe8 Signed-off-by: Jan Srnicek <jsrnicek@cisco.com>
Diffstat (limited to 'lisp/lisp2vpp/src/test/java/io/fd')
-rw-r--r--lisp/lisp2vpp/src/test/java/io/fd/hc2vpp/lisp/gpe/translate/GpeModuleTest.java7
-rw-r--r--lisp/lisp2vpp/src/test/java/io/fd/hc2vpp/lisp/gpe/translate/write/NativeForwardPathCustomizerTest.java132
-rw-r--r--lisp/lisp2vpp/src/test/java/io/fd/hc2vpp/lisp/gpe/translate/write/NativeForwardPathsTableCustomizerTest.java116
3 files changed, 255 insertions, 0 deletions
diff --git a/lisp/lisp2vpp/src/test/java/io/fd/hc2vpp/lisp/gpe/translate/GpeModuleTest.java b/lisp/lisp2vpp/src/test/java/io/fd/hc2vpp/lisp/gpe/translate/GpeModuleTest.java
index 2d5dd8b11..982239c80 100644
--- a/lisp/lisp2vpp/src/test/java/io/fd/hc2vpp/lisp/gpe/translate/GpeModuleTest.java
+++ b/lisp/lisp2vpp/src/test/java/io/fd/hc2vpp/lisp/gpe/translate/GpeModuleTest.java
@@ -25,8 +25,10 @@ import static org.mockito.MockitoAnnotations.initMocks;
import com.google.inject.Guice;
import com.google.inject.Inject;
+import com.google.inject.name.Named;
import com.google.inject.testing.fieldbinder.Bind;
import com.google.inject.testing.fieldbinder.BoundFieldModule;
+import io.fd.hc2vpp.common.translate.util.NamingContext;
import io.fd.hc2vpp.lisp.gpe.GpeModule;
import io.fd.honeycomb.translate.impl.read.registry.CompositeReaderRegistryBuilder;
import io.fd.honeycomb.translate.impl.write.registry.FlatWriterRegistryBuilder;
@@ -52,9 +54,14 @@ public class GpeModuleTest {
@Inject
private Set<WriterFactory> writerFactories = new HashSet<>();
+ @Named("interface-context")
+ @Bind
+ private NamingContext interfaceContext;
+
@Before
public void setUp() throws Exception {
initMocks(this);
+ interfaceContext = new NamingContext("interfaceContext", "interfaceContext");
Guice.createInjector(new GpeModule(), BoundFieldModule.of(this)).injectMembers(this);
}
diff --git a/lisp/lisp2vpp/src/test/java/io/fd/hc2vpp/lisp/gpe/translate/write/NativeForwardPathCustomizerTest.java b/lisp/lisp2vpp/src/test/java/io/fd/hc2vpp/lisp/gpe/translate/write/NativeForwardPathCustomizerTest.java
new file mode 100644
index 000000000..2ce9789cd
--- /dev/null
+++ b/lisp/lisp2vpp/src/test/java/io/fd/hc2vpp/lisp/gpe/translate/write/NativeForwardPathCustomizerTest.java
@@ -0,0 +1,132 @@
+/*
+ * 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.lisp.gpe.translate.write;
+
+import static org.junit.Assert.assertEquals;
+import static org.mockito.ArgumentMatchers.any;
+import static org.mockito.Mockito.times;
+import static org.mockito.Mockito.verify;
+import static org.mockito.Mockito.when;
+
+import io.fd.hc2vpp.common.test.write.WriterCustomizerTest;
+import io.fd.hc2vpp.common.translate.util.NamingContext;
+import io.fd.honeycomb.translate.write.WriteFailedException;
+import io.fd.vpp.jvpp.core.dto.GpeAddDelNativeFwdRpath;
+import io.fd.vpp.jvpp.core.dto.GpeAddDelNativeFwdRpathReply;
+import org.junit.Test;
+import org.mockito.ArgumentCaptor;
+import org.mockito.Captor;
+import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.inet.types.rev130715.IpAddress;
+import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.inet.types.rev130715.Ipv4Address;
+import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.inet.types.rev130715.Ipv6Address;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.gpe.rev170518.NativeForwardPathsTables;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.gpe.rev170518._native.forward.paths.tables.NativeForwardPathsTable;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.gpe.rev170518._native.forward.paths.tables.NativeForwardPathsTableKey;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.gpe.rev170518._native.forward.paths.tables._native.forward.paths.table.NativeForwardPath;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.gpe.rev170518._native.forward.paths.tables._native.forward.paths.table.NativeForwardPathBuilder;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.gpe.rev170518._native.forward.paths.tables._native.forward.paths.table.NativeForwardPathKey;
+import org.opendaylight.yangtools.yang.binding.InstanceIdentifier;
+
+public class NativeForwardPathCustomizerTest extends WriterCustomizerTest {
+
+ private static final long TABLE_ID = 1L;
+ private static final String IFC_CTX = "ifc-ctx";
+ private static final String ETH_0 = "eth-0";
+ private static final String ETH_1 = "eth-1";
+ private static final int ETH_0_IDX = 2;
+ private static final int ETH_1_IDX = 7;
+ private static final byte[] V4_WITH_IF_ADDR = {-64, -88, 2, 1};
+ private static final byte[] V4_WITHOUT_IF_ADDR = {-64, -88, 2, 3};
+ private static final byte[] V6_WITH_IF_ADDR = {32, 1, 13, -72, 10, 11, 18, -16, 0, 0, 0, 0, 0, 0, 0, 1};
+
+ private NamingContext ifcCtx;
+ private NativeForwardPathCustomizer customizer;
+ private InstanceIdentifier<NativeForwardPath> validId;
+
+ @Captor
+ private ArgumentCaptor<GpeAddDelNativeFwdRpath> requestCaptor;
+
+ @Override
+ protected void setUpTest() throws Exception {
+ ifcCtx = new NamingContext("iface", IFC_CTX);
+ defineMapping(mappingContext, ETH_0, ETH_0_IDX, IFC_CTX);
+ defineMapping(mappingContext, ETH_1, ETH_1_IDX, IFC_CTX);
+ customizer = new NativeForwardPathCustomizer(api, ifcCtx);
+ validId = InstanceIdentifier.create(NativeForwardPathsTables.class)
+ .child(NativeForwardPathsTable.class, new NativeForwardPathsTableKey(TABLE_ID))
+ .child(NativeForwardPath.class,
+ new NativeForwardPathKey(new IpAddress(new Ipv4Address("192.168.2.1"))));
+ when(api.gpeAddDelNativeFwdRpath(any())).thenReturn(future(new GpeAddDelNativeFwdRpathReply()));
+ }
+
+ @Test
+ public void testWriteV4WithIfc() throws WriteFailedException {
+ customizer.writeCurrentAttributes(validId, v4WithIfc(), writeContext);
+ verify(api, times(1)).gpeAddDelNativeFwdRpath(requestCaptor.capture());
+ final GpeAddDelNativeFwdRpath request = requestCaptor.getValue();
+ assertEquals(desiredRequest(1, 1, V4_WITH_IF_ADDR, ETH_0_IDX, (int) TABLE_ID), request);
+ }
+
+ @Test
+ public void testWriteV4WithoutIfc() throws WriteFailedException {
+ customizer.writeCurrentAttributes(validId, v4WithoutIfc(), writeContext);
+ verify(api, times(1)).gpeAddDelNativeFwdRpath(requestCaptor.capture());
+ final GpeAddDelNativeFwdRpath request = requestCaptor.getValue();
+ assertEquals(desiredRequest(1, 1, V4_WITHOUT_IF_ADDR, ~0, (int) TABLE_ID), request);
+ }
+
+ @Test
+ public void testWriteV6() throws WriteFailedException {
+ customizer.writeCurrentAttributes(validId, v6WithIfc(), writeContext);
+ verify(api, times(1)).gpeAddDelNativeFwdRpath(requestCaptor.capture());
+ final GpeAddDelNativeFwdRpath request = requestCaptor.getValue();
+ assertEquals(desiredRequest(1, 0, V6_WITH_IF_ADDR, ETH_1_IDX, (int) TABLE_ID), request);
+ }
+
+ private static GpeAddDelNativeFwdRpath desiredRequest(final int add, final int isV4,
+ final byte[] addr, final int swIfIndex,
+ final int tableId) {
+ GpeAddDelNativeFwdRpath request = new GpeAddDelNativeFwdRpath();
+ request.isAdd = (byte) add;
+ request.isIp4 = (byte) isV4;
+ request.nhAddr = addr;
+ request.nhSwIfIndex = swIfIndex;
+ request.tableId = tableId;
+
+ return request;
+ }
+
+ private static NativeForwardPath v6WithIfc() {
+ return new NativeForwardPathBuilder()
+ .setNextHopAddress(new IpAddress(new Ipv6Address("2001:0db8:0a0b:12f0:0000:0000:0000:0001")))
+ .setNextHopInterface(ETH_1)
+ .build();
+ }
+
+ private static NativeForwardPath v4WithoutIfc() {
+ return new NativeForwardPathBuilder()
+ .setNextHopAddress(new IpAddress(new Ipv4Address("192.168.2.3")))
+ .build();
+ }
+
+ private static NativeForwardPath v4WithIfc() {
+ return new NativeForwardPathBuilder()
+ .setNextHopAddress(new IpAddress(new Ipv4Address("192.168.2.1")))
+ .setNextHopInterface(ETH_0)
+ .build();
+ }
+} \ No newline at end of file
diff --git a/lisp/lisp2vpp/src/test/java/io/fd/hc2vpp/lisp/gpe/translate/write/NativeForwardPathsTableCustomizerTest.java b/lisp/lisp2vpp/src/test/java/io/fd/hc2vpp/lisp/gpe/translate/write/NativeForwardPathsTableCustomizerTest.java
new file mode 100644
index 000000000..923aaad44
--- /dev/null
+++ b/lisp/lisp2vpp/src/test/java/io/fd/hc2vpp/lisp/gpe/translate/write/NativeForwardPathsTableCustomizerTest.java
@@ -0,0 +1,116 @@
+/*
+ * 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.lisp.gpe.translate.write;
+
+import static org.junit.Assert.assertEquals;
+import static org.mockito.ArgumentMatchers.any;
+import static org.mockito.Mockito.times;
+import static org.mockito.Mockito.verify;
+import static org.mockito.Mockito.when;
+
+import io.fd.hc2vpp.common.test.write.WriterCustomizerTest;
+import io.fd.honeycomb.translate.write.WriteFailedException;
+import io.fd.vpp.jvpp.core.dto.GpeAddDelIface;
+import io.fd.vpp.jvpp.core.dto.GpeAddDelIfaceReply;
+import io.fd.vpp.jvpp.core.dto.GpeAddDelNativeFwdRpathReply;
+import java.util.List;
+import org.junit.Test;
+import org.mockito.ArgumentCaptor;
+import org.mockito.Captor;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.gpe.rev170518.NativeForwardPathsTables;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.gpe.rev170518._native.forward.paths.tables.NativeForwardPathsTable;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.gpe.rev170518._native.forward.paths.tables.NativeForwardPathsTableBuilder;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.gpe.rev170518._native.forward.paths.tables.NativeForwardPathsTableKey;
+import org.opendaylight.yangtools.yang.binding.InstanceIdentifier;
+
+public class NativeForwardPathsTableCustomizerTest extends WriterCustomizerTest {
+
+ private static final long TABLE_ID = 1L;
+ private NativeForwardPathsTableCustomizer customizer;
+ private InstanceIdentifier<NativeForwardPathsTable> validId;
+
+ @Captor
+ private ArgumentCaptor<GpeAddDelIface> requestCaptor;
+
+ @Override
+ protected void setUpTest() throws Exception {
+ customizer = new NativeForwardPathsTableCustomizer(api);
+ validId = InstanceIdentifier.create(NativeForwardPathsTables.class)
+ .child(NativeForwardPathsTable.class, new NativeForwardPathsTableKey(TABLE_ID));
+ when(api.gpeAddDelIface(any())).thenReturn(future(new GpeAddDelIfaceReply()));
+ }
+
+ @Test
+ public void testWriteValid() throws WriteFailedException {
+ when(api.gpeAddDelNativeFwdRpath(any())).thenReturn(future(new GpeAddDelNativeFwdRpathReply()));
+ customizer.writeCurrentAttributes(validId, validTable(), writeContext);
+ verify(api, times(1)).gpeAddDelIface(requestCaptor.capture());
+
+ final List<GpeAddDelIface> requests = requestCaptor.getAllValues();
+
+ assertEquals(desiredRequest(1, 1), requests.get(0));
+ }
+
+ @Test
+ public void testDeleteValid() throws WriteFailedException {
+ when(api.gpeAddDelNativeFwdRpath(any())).thenReturn(future(new GpeAddDelNativeFwdRpathReply()));
+ customizer.deleteCurrentAttributes(validId, validTable(), writeContext);
+ verify(api, times(1)).gpeAddDelIface(requestCaptor.capture());
+
+ final List<GpeAddDelIface> requests = requestCaptor.getAllValues();
+
+ assertEquals(desiredRequest(0, 1), requests.get(0));
+ }
+
+ @Test
+ public void testUpdateValid() throws WriteFailedException {
+ when(api.gpeAddDelNativeFwdRpath(any())).thenReturn(future(new GpeAddDelNativeFwdRpathReply()));
+ customizer.updateCurrentAttributes(validId, validTableBefore(), validTable(), writeContext);
+ verify(api, times(2)).gpeAddDelIface(requestCaptor.capture());
+
+ final List<GpeAddDelIface> requests = requestCaptor.getAllValues();
+
+ // removes one from old data
+ assertEquals(desiredRequest(0, 1), requests.get(0));
+
+ // defines 3 new
+ assertEquals(desiredRequest(1, 1), requests.get(1));
+ }
+
+
+ private GpeAddDelIface desiredRequest(final int isAdd, final int tableId) {
+ GpeAddDelIface request = new GpeAddDelIface();
+
+ request.isL2 = 0;
+ request.dpTable = tableId;
+ request.vni = request.dpTable;
+ request.isAdd = (byte) isAdd;
+ return request;
+ }
+
+ private NativeForwardPathsTable validTableBefore() {
+ return new NativeForwardPathsTableBuilder()
+ .setTableId(TABLE_ID)
+ .build();
+ }
+
+ private NativeForwardPathsTable validTable() {
+ return new NativeForwardPathsTableBuilder()
+ .setTableId(TABLE_ID)
+ .build();
+ }
+} \ No newline at end of file