Skip to content

Commit

Permalink
added kernel to vxlan to kernel test
Browse files Browse the repository at this point in the history
Signed-off-by: Mikhail Avramenko <[email protected]>
  • Loading branch information
Mixaster995 committed Aug 11, 2021
1 parent c06c5d8 commit 3799507
Show file tree
Hide file tree
Showing 6 changed files with 353 additions and 1,394 deletions.
8 changes: 6 additions & 2 deletions go.mod
Original file line number Diff line number Diff line change
Expand Up @@ -11,9 +11,11 @@ require (
github.com/edwarnicke/grpcfd v0.1.0
github.com/edwarnicke/vpphelper v0.0.0-20210512223648-f914b171f679
github.com/golang/protobuf v1.4.3
github.com/google/uuid v1.1.2 // indirect
github.com/kelseyhightower/envconfig v1.4.0
github.com/networkservicemesh/api v0.5.1-0.20210618184350-e3fc29dc170b
github.com/networkservicemesh/sdk v0.5.1-0.20210630092016-3b8e683e3d9c
github.com/networkservicemesh/api v1.0.1-0.20210715134717-6e4a0f8eae3e
github.com/networkservicemesh/sdk v1.0.0
github.com/networkservicemesh/sdk-kernel v0.0.0-20210811064243-0548354e4811
github.com/networkservicemesh/sdk-vpp v0.0.0-20210702090826-b6ed43b14a02
github.com/pkg/errors v0.9.1
github.com/sirupsen/logrus v1.7.0
Expand All @@ -24,3 +26,5 @@ require (
github.com/vishvananda/netns v0.0.0-20200728191858-db3c7e526aae
google.golang.org/grpc v1.35.0
)

replace github.com/networkservicemesh/sdk-vpp => github.com/Mixaster995/sdk-vpp v0.0.0-20210811094428-725a2a321882
9 changes: 9 additions & 0 deletions go.sum
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@ github.com/BurntSushi/toml v0.3.1/go.mod h1:xHWCNGjB5oqiDr8zfno3MHue2Ht5sIBksp03
github.com/DataDog/datadog-go v2.2.0+incompatible/go.mod h1:LButxg5PwREeZtORoXG3tL4fMGNddJ+vMq1mwgfaqoQ=
github.com/HdrHistogram/hdrhistogram-go v1.0.1 h1:GX8GAYDuhlFQnI2fRDHQhTlkHMz8bEn0jTI6LJU0mpw=
github.com/HdrHistogram/hdrhistogram-go v1.0.1/go.mod h1:BWJ+nMSHY3L41Zj7CA3uXnloDp7xxV0YvstAE7nKTaM=
github.com/Mixaster995/sdk-vpp v0.0.0-20210811094428-725a2a321882/go.mod h1:bIRy8a8ELFstX+/SotbrHKGwYcBrstDPc1r1Ga+19yg=
github.com/OneOfOne/xxhash v1.2.2/go.mod h1:HSdplMjZKSmBqAxg5vPj2TmRDmfkzw+cTzAElWljhcU=
github.com/OneOfOne/xxhash v1.2.3 h1:wS8NNaIgtzapuArKIAjsyXtEN/IUjQkbw90xszUdS40=
github.com/OneOfOne/xxhash v1.2.3/go.mod h1:HSdplMjZKSmBqAxg5vPj2TmRDmfkzw+cTzAElWljhcU=
Expand Down Expand Up @@ -150,8 +151,16 @@ github.com/nats-io/nuid v1.0.1/go.mod h1:19wcPz3Ph3q0Jbyiqsd0kePYG7A95tJPxeL+1OS
github.com/nats-io/stan.go v0.6.0/go.mod h1:eIcD5bi3pqbHT/xIIvXMwvzXYElgouBvaVRftaE+eac=
github.com/networkservicemesh/api v0.5.1-0.20210618184350-e3fc29dc170b h1:sylDyLDA6UkwtyByLos62/jLQOx0Hymw3O1qELYtdIo=
github.com/networkservicemesh/api v0.5.1-0.20210618184350-e3fc29dc170b/go.mod h1:B6meq/SWjWR6bGXZdXPfbOeaBK+T1JayLdtEJQCsXKU=
github.com/networkservicemesh/api v1.0.0/go.mod h1:B6meq/SWjWR6bGXZdXPfbOeaBK+T1JayLdtEJQCsXKU=
github.com/networkservicemesh/api v1.0.1-0.20210715134717-6e4a0f8eae3e/go.mod h1:B6meq/SWjWR6bGXZdXPfbOeaBK+T1JayLdtEJQCsXKU=
github.com/networkservicemesh/sdk v0.5.1-0.20210630092016-3b8e683e3d9c h1:PXSbJGzstgLMpnDbpJGN2ds9l8BNkLkb1rNSP4YxTBk=
github.com/networkservicemesh/sdk v0.5.1-0.20210630092016-3b8e683e3d9c/go.mod h1:Z1IJPdvcBsS2X8pHeCGwo91Fs+BJTEvUQKpinAfG/hM=
github.com/networkservicemesh/sdk v0.5.1-0.20210811063905-15a33a429304/go.mod h1:7whufn2CIGBX+KW3U5b0IWB6f7bJJizY1vV1a5t2HXI=
github.com/networkservicemesh/sdk v1.0.0/go.mod h1:fkkI+GO5nMQL0G5bnmMLiWxIZUHZOFPOrlv5oWlSxys=
github.com/networkservicemesh/sdk-kernel v0.0.0-20210811064243-0548354e4811 h1:6BEC8aed4vUzRGO8ngRTiQk+hxb/D75PdIEB5NxoTrk=
github.com/networkservicemesh/sdk-kernel v0.0.0-20210811064243-0548354e4811/go.mod h1:I/gLTrgmGShoKlObcvHpQ9J7fCjsPL8BIvfWkjaqk6g=
github.com/networkservicemesh/sdk-kernel v1.0.1 h1:Jty3FkjMxSI47C9kGEGSFQZjao6tqa4wBlIRzByk0w0=
github.com/networkservicemesh/sdk-kernel v1.0.1/go.mod h1:EiVrGipqU2Y6n7FcBZuBcROOzrZs+euVruVKJQRgxBk=
github.com/networkservicemesh/sdk-vpp v0.0.0-20210702090826-b6ed43b14a02 h1:Y3wBK3kxcKITqiWDT/ovBR1DS0FTWPKfmJIB1OI6VVE=
github.com/networkservicemesh/sdk-vpp v0.0.0-20210702090826-b6ed43b14a02/go.mod h1:BUxM0Vxaw2EEYV8JE/a6iu9+T0Jm/cTQ7GhEhylOa6Q=
github.com/niemeyer/pretty v0.0.0-20200227124842-a10e7caefd8e h1:fD57ERR4JtEqsWbfPhv4DMiApHyliiK5xCTNVSPiaAs=
Expand Down
56 changes: 56 additions & 0 deletions internal/tests/copyfile/server.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,56 @@
// Copyright (c) 2020 Doc.ai and/or its affiliates.
//
// SPDX-License-Identifier: Apache-2.0
//
// 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 copyfile provides the necessary mechanisms to request and inject a kernel interface.
package copyfile

import (
"context"
"github.com/golang/protobuf/ptypes/empty"
"github.com/networkservicemesh/api/pkg/api/networkservice"
"github.com/networkservicemesh/api/pkg/api/networkservice/mechanisms/kernel"
"github.com/networkservicemesh/sdk/pkg/networkservice/core/next"
"net/url"
)

type copyFileServer struct{
name string
}

// NewServer - creates a NetworkServiceServer that requests a kernel interface and populates the netns inode
func NewServer(name string) networkservice.NetworkServiceServer {
return &copyFileServer{
name: name,
}
}

func (m *copyFileServer) Request(ctx context.Context, request *networkservice.NetworkServiceRequest) (*networkservice.Connection, error) {
if mechanism := kernel.ToMechanism(request.GetConnection().GetMechanism()); mechanism != nil {
//nsHandle, err := mechutils.ToNSHandle(mechanism)
//fd, err := syscall.Open("/run/netns/" + m.name, unix.O_RDONLY|unix.O_CLOEXEC, 0)
//if err != nil {
// return nil, err
//}
//filename := fmt.Sprintf("/proc/%d/fd/%d", os.Getpid(), fd)
mechanism.SetNetNSURL((&url.URL{Scheme: "file", Path: "/run/netns/" + m.name}).String())
}
return next.Server(ctx).Request(ctx, request)
}

func (m *copyFileServer) Close(ctx context.Context, conn *networkservice.Connection) (*empty.Empty, error) {
return next.Server(ctx).Close(ctx, conn)
}

170 changes: 170 additions & 0 deletions internal/tests/suite_kernel_vxlan_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,170 @@
package tests

import (
"context"
"fmt"
"git.fd.io/govpp.git/api"
"github.com/edwarnicke/vpphelper"
"github.com/google/uuid"
"github.com/networkservicemesh/api/pkg/api/networkservice"
"github.com/networkservicemesh/api/pkg/api/networkservice/mechanisms/cls"
"github.com/networkservicemesh/cmd-forwarder-vpp/internal/tests/copyfile"
"github.com/networkservicemesh/cmd-forwarder-vpp/internal/tests/ns"
"github.com/networkservicemesh/sdk-kernel/pkg/kernel/networkservice/connectioncontextkernel"
"github.com/networkservicemesh/sdk-vpp/pkg/networkservice/connectioncontext"
"github.com/networkservicemesh/sdk-vpp/pkg/networkservice/connectioncontext/mtu"

"github.com/networkservicemesh/sdk-vpp/pkg/networkservice/mechanisms/kernel"
"github.com/networkservicemesh/sdk-vpp/pkg/networkservice/mechanisms/memif"
"github.com/networkservicemesh/sdk-vpp/pkg/networkservice/mechanisms/vxlan"
"github.com/networkservicemesh/sdk-vpp/pkg/networkservice/mechanisms/wireguard"
"github.com/networkservicemesh/sdk-vpp/pkg/networkservice/pinhole"
"github.com/networkservicemesh/sdk-vpp/pkg/networkservice/stats"
"github.com/networkservicemesh/sdk-vpp/pkg/networkservice/tag"
"github.com/networkservicemesh/sdk-vpp/pkg/networkservice/up"
"github.com/networkservicemesh/sdk-vpp/pkg/networkservice/xconnect"
"github.com/networkservicemesh/sdk/pkg/networkservice/chains/endpoint"
"github.com/networkservicemesh/sdk/pkg/networkservice/common/authorize"
"github.com/networkservicemesh/sdk/pkg/networkservice/common/mechanisms"
kernelmechanism "github.com/networkservicemesh/sdk/pkg/networkservice/common/mechanisms/kernel"
"github.com/networkservicemesh/sdk/pkg/networkservice/common/mechanismtranslation"
"github.com/networkservicemesh/sdk/pkg/networkservice/common/refresh"
"github.com/networkservicemesh/sdk/pkg/networkservice/common/serialize"
"github.com/networkservicemesh/sdk/pkg/networkservice/common/updatepath"
"github.com/networkservicemesh/sdk/pkg/networkservice/core/adapters"
"github.com/networkservicemesh/sdk/pkg/networkservice/core/chain"
"github.com/networkservicemesh/sdk/pkg/networkservice/ipam/point2pointipam"
"github.com/networkservicemesh/sdk/pkg/networkservice/utils/metadata"
"github.com/networkservicemesh/sdk/pkg/tools/token"
"github.com/thanhpk/randstr"
"github.com/vishvananda/netns"
"net"
)

type kernelToVxlanVerifiableEndpoint struct {
ctx context.Context
vppConn api.Connection
endpointNSHandle netns.NsHandle
endpoint.Endpoint
}

func newKernelToVxlanVerifiableEndpoint(ctx context.Context,
prefix1, prefix2 *net.IPNet,
tokenGenerator token.GeneratorFunc,
vppConn vpphelper.Connection) verifiableEndpoint {

rootNSHandle, err := netns.Get()
if err != nil {
panic(fmt.Sprintf("unable to get root netNs: %+v", err))
}
endpointNSName := fmt.Sprintf("endpoint-%s", randstr.Hex(4))
endpointNSHandle, err := netns.NewNamed(endpointNSName)
if err != nil {
panic(fmt.Sprintf("unable create netNs %s: %+v", endpointNSName, err))
}
go func(endpointNsName string) {
<-ctx.Done()
_ = netns.DeleteNamed(endpointNsName)
}(endpointNSName)

rv := &kernelToVxlanVerifiableEndpoint{
ctx: ctx,
vppConn: vppConn,
endpointNSHandle: endpointNSHandle,
}
name := "vxlanVerifiableEndpoint"
rv.Endpoint = endpoint.NewServer(ctx,
tokenGenerator,
endpoint.WithName(name),
endpoint.WithAuthorizeServer(authorize.NewServer()),
endpoint.WithAdditionalFunctionality(
metadata.NewServer(),
connectioncontext.NewServer(vppConn),
up.NewServer(ctx, vppConn),
xconnect.NewServer(vppConn),
connectioncontextkernel.NewServer(),
tag.NewServer(ctx, vppConn),
mtu.NewServer(vppConn),
pinhole.NewServer(vppConn),
mechanisms.NewServer(map[string]networkservice.NetworkServiceServer{
vxlan.MECHANISM: vxlan.NewServer(vppConn, net.ParseIP(serverIP)),
}),
adapters.NewClientToServer(clientChain(ctx, vppConn, net.ParseIP(serverIP))),
updatepath.NewServer("ep-" + uuid.New().String()),
//metadata.NewServer(),
point2pointipam.NewServer(prefix1),
point2pointipam.NewServer(prefix2),
mechanisms.NewServer(map[string]networkservice.NetworkServiceServer{
kernel.MECHANISM: chain.NewNetworkServiceServer(
kernelmechanism.NewServer(),
),
}),
ns.NewServer(endpointNSHandle),
copyfile.NewServer(endpointNSName),
ns.NewServer(rootNSHandle),
),
)

return rv
}

func clientChain(ctx context.Context, vppConn vpphelper.Connection, tunnelIP net.IP) networkservice.NetworkServiceClient{
return chain.NewNetworkServiceClient(
[]networkservice.NetworkServiceClient{
mechanismtranslation.NewClient(),
updatepath.NewClient("client-" + uuid.New().String()),
serialize.NewClient(),
refresh.NewClient(ctx),
metadata.NewClient(),
mechanismtranslation.NewClient(),
connectioncontextkernel.NewClient(),
stats.NewClient(ctx),
up.NewClient(ctx, vppConn),
mtu.NewClient(vppConn),
tag.NewClient(ctx, vppConn),
// mechanisms
memif.NewClient(vppConn),
kernel.NewClient(vppConn),
vxlan.NewClient(vppConn, tunnelIP),
wireguard.NewClient(vppConn, tunnelIP),
pinhole.NewClient(vppConn),
}...)
}

func (v *kernelToVxlanVerifiableEndpoint) VerifyConnection(conn *networkservice.Connection) error {
//namingConn := conn.Clone()
//namingConn.Id = conn.GetPath().GetPathSegments()[len(conn.GetPath().GetPathSegments())-1].GetId()
//namingConn.Mechanism = &networkservice.Mechanism{
// Cls: cls.LOCAL,
// Type: kernel.MECHANISM,
// Parameters: map[string]string{
// krnl.InterfaceNameKey : "ns-",
// },
//}
////rootNSHandle, err := netns.Get()
////if err != nil {
//// panic(fmt.Sprintf("unable to get root netNs: %+v", err))
////}
//if err := checkKernelInterface(namingConn, conn.GetContext().GetIpContext().GetDstIPNets(), v.endpointNSHandle); err != nil {
// return err
//}
namingConn := conn.Clone()
namingConn.Id = conn.GetPath().GetPathSegments()[len(conn.GetPath().GetPathSegments())-1].GetId()
namingConn.Mechanism = &networkservice.Mechanism{
Cls: cls.LOCAL,
Type: kernel.MECHANISM,
}
if err := checkKernelInterface(namingConn, conn.GetContext().GetIpContext().GetDstIPNets(), v.endpointNSHandle); err != nil {
return err
}
for _, ip := range conn.GetContext().GetIpContext().GetSrcIPNets() {
if err := pingKernel(ip, v.endpointNSHandle); err != nil {
return err
}
}
return nil
}

func (v *kernelToVxlanVerifiableEndpoint) VerifyClose(conn *networkservice.Connection) error {
return checkNoKernelInterface(conn, v.endpointNSHandle)
}
Loading

0 comments on commit 3799507

Please sign in to comment.