From 7d6c038cb30b933582d15fb6ab92fed60ce8092f Mon Sep 17 00:00:00 2001 From: Marek Gradzki Date: Fri, 1 Jun 2018 12:48:27 +0200 Subject: HC2VPP-336: reenable NSH plugin This patch reverts https://gerrit.fd.io/r/#/c/12822/ and bumps jvpp nsh_sfc dependency to 18.07-SNAPSHOT. Change-Id: Idce70d39c9c273b7db3c771430ef5af58417b43b Signed-off-by: Marek Gradzki --- it/api-test/pom.xml | 6 +++ nsh/impl/pom.xml | 8 +--- pom.xml | 3 +- vpp-integration/api-docs/docs/pom.xml | 1 + vpp-integration/api-docs/scripts/pom.xml | 5 +++ .../docs/scripts/ApiDocsIndexGenerator.groovy | 3 +- .../docs/core/mock/binding/MockNshModule.java | 48 ++++++++++++++++++++++ vpp-integration/minimal-distribution/pom.xml | 7 ++++ 8 files changed, 71 insertions(+), 10 deletions(-) create mode 100644 vpp-integration/api-docs/scripts/src/main/java/io/fd/hc2vpp/docs/core/mock/binding/MockNshModule.java diff --git a/it/api-test/pom.xml b/it/api-test/pom.xml index b40c5af49..28263ec0d 100644 --- a/it/api-test/pom.xml +++ b/it/api-test/pom.xml @@ -86,6 +86,12 @@ + + io.fd.hc2vpp.nsh + vppnsh-api + ${project.version} + + io.fd.hc2vpp.ioam vppioam-api diff --git a/nsh/impl/pom.xml b/nsh/impl/pom.xml index 0b8cd1fc2..38038a42d 100644 --- a/nsh/impl/pom.xml +++ b/nsh/impl/pom.xml @@ -86,13 +86,7 @@ io.fd.nsh_sfc nsh-sfc - 18.04-SNAPSHOT - - - io.fd.vpp - jvpp-registry - - + 18.07-SNAPSHOT io.fd.hc2vpp.common diff --git a/pom.xml b/pom.xml index 851beb518..e5f7b7fc8 100644 --- a/pom.xml +++ b/pom.xml @@ -39,8 +39,7 @@ vpp-common v3po ioam - - + nsh routing nat lisp diff --git a/vpp-integration/api-docs/docs/pom.xml b/vpp-integration/api-docs/docs/pom.xml index 03ebbc5c3..6545ed671 100644 --- a/vpp-integration/api-docs/docs/pom.xml +++ b/vpp-integration/api-docs/docs/pom.xml @@ -46,6 +46,7 @@ io.fd.hc2vpp.dhcp.DhcpModule, io.fd.hc2vpp.policer.PolicerModule, io.fd.hc2vpp.mpls.MplsModule, + io.fd.hc2vpp.docs.core.mock.binding.MockNshModule, io.fd.hc2vpp.docs.core.mock.binding.MockIoamModule, io.fd.hc2vpp.bgp.inet.BgpInetModule, io.fd.hc2vpp.bgp.prefix.sid.BgpPrefixSidModule diff --git a/vpp-integration/api-docs/scripts/pom.xml b/vpp-integration/api-docs/scripts/pom.xml index c24fcac6a..cdc05e876 100644 --- a/vpp-integration/api-docs/scripts/pom.xml +++ b/vpp-integration/api-docs/scripts/pom.xml @@ -85,6 +85,11 @@ vppioam-impl ${project.version} + + io.fd.hc2vpp.nsh + vppnsh-impl + ${project.version} + io.fd.hc2vpp.v3po v3po2vpp diff --git a/vpp-integration/api-docs/scripts/src/main/groovy/io/fd/hc2vpp/docs/scripts/ApiDocsIndexGenerator.groovy b/vpp-integration/api-docs/scripts/src/main/groovy/io/fd/hc2vpp/docs/scripts/ApiDocsIndexGenerator.groovy index 0cd528992..65ee2ed1e 100644 --- a/vpp-integration/api-docs/scripts/src/main/groovy/io/fd/hc2vpp/docs/scripts/ApiDocsIndexGenerator.groovy +++ b/vpp-integration/api-docs/scripts/src/main/groovy/io/fd/hc2vpp/docs/scripts/ApiDocsIndexGenerator.groovy @@ -26,6 +26,7 @@ import io.fd.vpp.jvpp.core.future.FutureJVppCore import io.fd.vpp.jvpp.ioamexport.future.FutureJVppIoamexport import io.fd.vpp.jvpp.ioampot.future.FutureJVppIoampot import io.fd.vpp.jvpp.ioamtrace.future.FutureJVppIoamtrace +import io.fd.vpp.jvpp.nsh.future.FutureJVppNsh import io.fd.vpp.jvpp.nat.future.FutureJVppNat import java.nio.charset.StandardCharsets @@ -44,7 +45,7 @@ class ApiDocsIndexGenerator { private static def NL = System.lineSeparator() // TODO - check if list of plugin classes can be generated based on list of modules enabled for doc generation private static - def PLUGIN_CLASSES = [FutureJVppCore.class, FutureJVppAcl.class, FutureJVppNat.class, + def PLUGIN_CLASSES = [FutureJVppCore.class, FutureJVppAcl.class, FutureJVppNat.class, FutureJVppNsh.class, FutureJVppIoamexport.class, FutureJVppIoampot.class, FutureJVppIoamtrace.class] private static def TABLE_PART_MARK = "|" diff --git a/vpp-integration/api-docs/scripts/src/main/java/io/fd/hc2vpp/docs/core/mock/binding/MockNshModule.java b/vpp-integration/api-docs/scripts/src/main/java/io/fd/hc2vpp/docs/core/mock/binding/MockNshModule.java new file mode 100644 index 000000000..dace214e8 --- /dev/null +++ b/vpp-integration/api-docs/scripts/src/main/java/io/fd/hc2vpp/docs/core/mock/binding/MockNshModule.java @@ -0,0 +1,48 @@ +/* + * 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.docs.core.mock.binding; + +import static io.fd.hc2vpp.docs.core.mock.binding.MockBindingModule.noOpProxy; + +import com.google.inject.Provider; +import io.fd.hc2vpp.vppnsh.impl.VppNshModule; +import io.fd.vpp.jvpp.JVpp; +import io.fd.vpp.jvpp.JVppRegistry; +import io.fd.vpp.jvpp.nsh.future.FutureJVppNshFacade; +import java.io.IOException; + +/** + * Use to bypass jvpp registration + */ +public class MockNshModule extends VppNshModule { + + public MockNshModule() { + super(MockJVppNshProvider.class); + } + + private static class MockJVppNshProvider implements Provider { + + @Override + public FutureJVppNshFacade get() { + try { + return new FutureJVppNshFacade(noOpProxy(JVppRegistry.class), noOpProxy(JVpp.class)); + } catch (IOException e) { + throw new IllegalStateException(e); + } + } + } +} diff --git a/vpp-integration/minimal-distribution/pom.xml b/vpp-integration/minimal-distribution/pom.xml index 791ad9515..8399ff27e 100644 --- a/vpp-integration/minimal-distribution/pom.xml +++ b/vpp-integration/minimal-distribution/pom.xml @@ -65,6 +65,8 @@ io.fd.hc2vpp.dhcp.DhcpModule, io.fd.hc2vpp.policer.PolicerModule, io.fd.hc2vpp.mpls.MplsModule, + + // io.fd.hc2vpp.vppnsh.impl.VppNshModule, // io.fd.hc2vpp.vppioam.impl.VppIoamModule, @@ -127,6 +129,11 @@ lisp2vpp ${lisp.version} + + io.fd.hc2vpp.nsh + vppnsh-impl + ${vppnsh.version} + io.fd.hc2vpp.nat nat2vpp -- cgit 1.2.3-korg