Skip to content

Commit

Permalink
make dhcp client
Browse files Browse the repository at this point in the history
  • Loading branch information
QxBytes committed Sep 9, 2024
1 parent 31bd3ad commit 202ac09
Show file tree
Hide file tree
Showing 12 changed files with 116 additions and 38 deletions.
3 changes: 2 additions & 1 deletion cni/network/network.go
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@ import (
"github.com/Azure/azure-container-networking/cns"
cnscli "github.com/Azure/azure-container-networking/cns/client"
"github.com/Azure/azure-container-networking/common"
"github.com/Azure/azure-container-networking/dhcp"
"github.com/Azure/azure-container-networking/iptables"
"github.com/Azure/azure-container-networking/netio"
"github.com/Azure/azure-container-networking/netlink"
Expand Down Expand Up @@ -130,7 +131,7 @@ func NewPlugin(name string,

nl := netlink.NewNetlink()
// Setup network manager.
nm, err := network.NewNetworkManager(nl, platform.NewExecClient(logger), &netio.NetIO{}, network.NewNamespaceClient(), iptables.NewClient())
nm, err := network.NewNetworkManager(nl, platform.NewExecClient(logger), &netio.NetIO{}, network.NewNamespaceClient(), iptables.NewClient(), dhcp.New(logger))
if err != nil {
return nil, err
}
Expand Down
File renamed without changes.
55 changes: 55 additions & 0 deletions dhcp/dhcp_windows.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,55 @@
package dhcp

import (
"context"
"go.uber.org/zap"
"net"
"time"
)

const (
dhcpDiscover = 1
bootRequest = 1
ethPAll = 0x0003
MaxUDPReceivedPacketSize = 8192
dhcpServerPort = 67
dhcpClientPort = 68
dhcpOpCodeReply = 2
bootpMinLen = 300
bytesInAddress = 4 // bytes in an ip address
macBytes = 6 // bytes in a mac address
udpProtocol = 17

opRequest = 1

Check failure on line 23 in dhcp/dhcp_windows.go

View workflow job for this annotation

GitHub Actions / Lint (1.21.x, windows-latest)

const `opRequest` is unused (unused)

Check failure on line 23 in dhcp/dhcp_windows.go

View workflow job for this annotation

GitHub Actions / Lint (1.22.x, windows-latest)

const `opRequest` is unused (unused)
htypeEthernet = 1

Check failure on line 24 in dhcp/dhcp_windows.go

View workflow job for this annotation

GitHub Actions / Lint (1.21.x, windows-latest)

const `htypeEthernet` is unused (unused)

Check failure on line 24 in dhcp/dhcp_windows.go

View workflow job for this annotation

GitHub Actions / Lint (1.22.x, windows-latest)

const `htypeEthernet` is unused (unused)
hlenEthernet = 6

Check failure on line 25 in dhcp/dhcp_windows.go

View workflow job for this annotation

GitHub Actions / Lint (1.21.x, windows-latest)

const `hlenEthernet` is unused (unused)

Check failure on line 25 in dhcp/dhcp_windows.go

View workflow job for this annotation

GitHub Actions / Lint (1.22.x, windows-latest)

const `hlenEthernet` is unused (unused)
hops = 0

Check failure on line 26 in dhcp/dhcp_windows.go

View workflow job for this annotation

GitHub Actions / Lint (1.21.x, windows-latest)

const `hops` is unused (unused)

Check failure on line 26 in dhcp/dhcp_windows.go

View workflow job for this annotation

GitHub Actions / Lint (1.22.x, windows-latest)

const `hops` is unused (unused)
secs = 0

Check failure on line 27 in dhcp/dhcp_windows.go

View workflow job for this annotation

GitHub Actions / Lint (1.21.x, windows-latest)

const `secs` is unused (unused)

Check failure on line 27 in dhcp/dhcp_windows.go

View workflow job for this annotation

GitHub Actions / Lint (1.22.x, windows-latest)

const `secs` is unused (unused)
flags = 0x8000 // Broadcast flag

Check failure on line 28 in dhcp/dhcp_windows.go

View workflow job for this annotation

GitHub Actions / Lint (1.21.x, windows-latest)

const `flags` is unused (unused)

Check failure on line 28 in dhcp/dhcp_windows.go

View workflow job for this annotation

GitHub Actions / Lint (1.22.x, windows-latest)

const `flags` is unused (unused)
)

// TransactionID represents a 4-byte DHCP transaction ID as defined in RFC 951,
// Section 3.
//
// The TransactionID is used to match DHCP replies to their original request.
type TransactionID [4]byte

var (
magicCookie = []byte{0x63, 0x82, 0x53, 0x63} // DHCP magic cookie

Check failure on line 38 in dhcp/dhcp_windows.go

View workflow job for this annotation

GitHub Actions / Lint (1.21.x, windows-latest)

var `magicCookie` is unused (unused)

Check failure on line 38 in dhcp/dhcp_windows.go

View workflow job for this annotation

GitHub Actions / Lint (1.22.x, windows-latest)

var `magicCookie` is unused (unused)
DefaultReadTimeout = 3 * time.Second
DefaultTimeout = 3 * time.Second
)

type DHCP struct {
logger *zap.Logger
}

func New(logger *zap.Logger) *DHCP {
return &DHCP{
logger: logger,
}
}

func (c *DHCP) DiscoverRequest(_ context.Context, _ net.HardwareAddr, _ string) error {
return nil
}
17 changes: 17 additions & 0 deletions network/dhcp.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
package network

import (
"context"
"net"
)

type dhcpClient interface {
DiscoverRequest(context.Context, net.HardwareAddr, string) error
}

type mockDHCP struct {
}

func (netns *mockDHCP) DiscoverRequest(context.Context, net.HardwareAddr, string) error {
return nil
}
7 changes: 4 additions & 3 deletions network/endpoint.go
Original file line number Diff line number Diff line change
Expand Up @@ -169,6 +169,7 @@ func (nw *network) newEndpoint(
netioCli netio.NetIOInterface,
nsc NamespaceClientInterface,
iptc ipTablesClient,
dhcpc dhcpClient,
epInfo *EndpointInfo,
) (*endpoint, error) {
var ep *endpoint
Expand All @@ -182,7 +183,7 @@ func (nw *network) newEndpoint(

// Call the platform implementation.
// Pass nil for epClient and will be initialized in newendpointImpl
ep, err = nw.newEndpointImpl(apipaCli, nl, plc, netioCli, nil, nsc, iptc, epInfo)
ep, err = nw.newEndpointImpl(apipaCli, nl, plc, netioCli, nil, nsc, iptc, dhcpc, epInfo)
if err != nil {
return nil, err
}
Expand All @@ -195,7 +196,7 @@ func (nw *network) newEndpoint(

// DeleteEndpoint deletes an existing endpoint from the network.
func (nw *network) deleteEndpoint(nl netlink.NetlinkInterface, plc platform.ExecClient, nioc netio.NetIOInterface, nsc NamespaceClientInterface,
iptc ipTablesClient, endpointID string,
iptc ipTablesClient, dhcpc dhcpClient, endpointID string,
) error {
var err error

Expand All @@ -215,7 +216,7 @@ func (nw *network) deleteEndpoint(nl netlink.NetlinkInterface, plc platform.Exec

// Call the platform implementation.
// Pass nil for epClient and will be initialized in deleteEndpointImpl
err = nw.deleteEndpointImpl(nl, plc, nil, nioc, nsc, iptc, ep)
err = nw.deleteEndpointImpl(nl, plc, nil, nioc, nsc, iptc, dhcpc, ep)
if err != nil {
return err
}
Expand Down
8 changes: 4 additions & 4 deletions network/endpoint_linux.go
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,6 @@ import (
"strings"

"github.com/Azure/azure-container-networking/cns"
"github.com/Azure/azure-container-networking/dhcp"
"github.com/Azure/azure-container-networking/netio"
"github.com/Azure/azure-container-networking/netlink"
"github.com/Azure/azure-container-networking/network/networkutils"
Expand Down Expand Up @@ -58,6 +57,7 @@ func (nw *network) newEndpointImpl(
testEpClient EndpointClient,
nsc NamespaceClientInterface,
iptc ipTablesClient,
dhcpclient dhcpClient,
epInfo *EndpointInfo,
) (*endpoint, error) {
var (
Expand Down Expand Up @@ -168,7 +168,7 @@ func (nw *network) newEndpointImpl(
epClient = NewLinuxBridgeEndpointClient(nw.extIf, hostIfName, contIfName, nw.Mode, nl, plc)
} else if epInfo.NICType == cns.NodeNetworkInterfaceFrontendNIC {
logger.Info("Secondary client")
epClient = NewSecondaryEndpointClient(nl, netioCli, plc, nsc, dhcp.New(logger), ep)
epClient = NewSecondaryEndpointClient(nl, netioCli, plc, nsc, dhcpclient, ep)
} else {
logger.Info("Transparent client")
epClient = NewTransparentEndpointClient(nw.extIf, hostIfName, contIfName, nw.Mode, nl, netioCli, plc)
Expand Down Expand Up @@ -266,7 +266,7 @@ func (nw *network) newEndpointImpl(

// deleteEndpointImpl deletes an existing endpoint from the network.
func (nw *network) deleteEndpointImpl(nl netlink.NetlinkInterface, plc platform.ExecClient, epClient EndpointClient, nioc netio.NetIOInterface, nsc NamespaceClientInterface,
iptc ipTablesClient, ep *endpoint,
iptc ipTablesClient, dhcpc dhcpClient, ep *endpoint,
) error {
// Delete the veth pair by deleting one of the peer interfaces.
// Deleting the host interface is more convenient since it does not require
Expand All @@ -288,7 +288,7 @@ func (nw *network) deleteEndpointImpl(nl netlink.NetlinkInterface, plc platform.
} else {
// delete if secondary interfaces populated or endpoint of type delegated (new way)
if len(ep.SecondaryInterfaces) > 0 || ep.NICType == cns.NodeNetworkInterfaceFrontendNIC {
epClient = NewSecondaryEndpointClient(nl, nioc, plc, nsc, dhcp.New(logger), ep)
epClient = NewSecondaryEndpointClient(nl, nioc, plc, nsc, dhcpc, ep)
epClient.DeleteEndpointRules(ep)
//nolint:errcheck // ignore error
epClient.DeleteEndpoints(ep)
Expand Down
28 changes: 14 additions & 14 deletions network/endpoint_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -186,7 +186,7 @@ var _ = Describe("Test Endpoint", func() {
It("Should be added", func() {
// Add endpoint with valid id
ep, err := nw.newEndpointImpl(nil, netlink.NewMockNetlink(false, ""), platform.NewMockExecClient(false),
netio.NewMockNetIO(false, 0), NewMockEndpointClient(nil), NewMockNamespaceClient(), iptables.NewClient(), epInfo)
netio.NewMockNetIO(false, 0), NewMockEndpointClient(nil), NewMockNamespaceClient(), iptables.NewClient(), &mockDHCP{}, epInfo)
Expect(err).NotTo(HaveOccurred())
Expect(ep).NotTo(BeNil())
Expect(ep.Id).To(Equal(epInfo.EndpointID))
Expand All @@ -198,7 +198,7 @@ var _ = Describe("Test Endpoint", func() {
extIf: &externalInterface{IPv4Gateway: net.ParseIP("192.168.0.1")},
}
ep, err := nw2.newEndpointImpl(nil, netlink.NewMockNetlink(false, ""), platform.NewMockExecClient(false),
netio.NewMockNetIO(false, 0), NewMockEndpointClient(nil), NewMockNamespaceClient(), iptables.NewClient(), epInfo)
netio.NewMockNetIO(false, 0), NewMockEndpointClient(nil), NewMockNamespaceClient(), iptables.NewClient(), &mockDHCP{}, epInfo)
Expect(err).NotTo(HaveOccurred())
Expect(ep).NotTo(BeNil())
Expect(ep.Id).To(Equal(epInfo.EndpointID))
Expand All @@ -216,7 +216,7 @@ var _ = Describe("Test Endpoint", func() {
Expect(err).ToNot(HaveOccurred())
// Adding endpoint with same id should fail and delete should cleanup the state
ep2, err := nw.newEndpointImpl(nil, netlink.NewMockNetlink(false, ""), platform.NewMockExecClient(false),
netio.NewMockNetIO(false, 0), mockCli, NewMockNamespaceClient(), iptables.NewClient(), epInfo)
netio.NewMockNetIO(false, 0), mockCli, NewMockNamespaceClient(), iptables.NewClient(), &mockDHCP{}, epInfo)
Expect(err).To(HaveOccurred())
Expect(ep2).To(BeNil())
assert.Contains(GinkgoT(), err.Error(), "Endpoint already exists")
Expand All @@ -226,17 +226,17 @@ var _ = Describe("Test Endpoint", func() {
// Adding an endpoint with an id.
mockCli := NewMockEndpointClient(nil)
ep2, err := nw.newEndpointImpl(nil, netlink.NewMockNetlink(false, ""), platform.NewMockExecClient(false),
netio.NewMockNetIO(false, 0), mockCli, NewMockNamespaceClient(), iptables.NewClient(), epInfo)
netio.NewMockNetIO(false, 0), mockCli, NewMockNamespaceClient(), iptables.NewClient(), &mockDHCP{}, epInfo)
Expect(err).ToNot(HaveOccurred())
Expect(ep2).ToNot(BeNil())
Expect(len(mockCli.endpoints)).To(Equal(1))
// Deleting the endpoint
//nolint:errcheck // ignore error
nw.deleteEndpointImpl(netlink.NewMockNetlink(false, ""), platform.NewMockExecClient(false), mockCli, netio.NewMockNetIO(false, 0), NewMockNamespaceClient(), iptables.NewClient(), ep2)
nw.deleteEndpointImpl(netlink.NewMockNetlink(false, ""), platform.NewMockExecClient(false), mockCli, netio.NewMockNetIO(false, 0), NewMockNamespaceClient(), iptables.NewClient(), &mockDHCP{}, ep2)
Expect(len(mockCli.endpoints)).To(Equal(0))
// Deleting same endpoint with same id should not fail
//nolint:errcheck // ignore error
nw.deleteEndpointImpl(netlink.NewMockNetlink(false, ""), platform.NewMockExecClient(false), mockCli, netio.NewMockNetIO(false, 0), NewMockNamespaceClient(), iptables.NewClient(), ep2)
nw.deleteEndpointImpl(netlink.NewMockNetlink(false, ""), platform.NewMockExecClient(false), mockCli, netio.NewMockNetIO(false, 0), NewMockNamespaceClient(), iptables.NewClient(), &mockDHCP{}, ep2)
Expect(len(mockCli.endpoints)).To(Equal(0))
})
})
Expand All @@ -256,7 +256,7 @@ var _ = Describe("Test Endpoint", func() {
extIf: &externalInterface{IPv4Gateway: net.ParseIP("192.168.0.1")},
}
ep, err := nw2.newEndpointImpl(nil, netlink.NewMockNetlink(false, ""), platform.NewMockExecClient(false),
netio.NewMockNetIO(false, 0), NewMockEndpointClient(nil), NewMockNamespaceClient(), iptables.NewClient(), epInfo)
netio.NewMockNetIO(false, 0), NewMockEndpointClient(nil), NewMockNamespaceClient(), iptables.NewClient(), &mockDHCP{}, epInfo)
Expect(err).NotTo(HaveOccurred())
Expect(ep).NotTo(BeNil())
Expect(ep.Id).To(Equal(epInfo.EndpointID))
Expand All @@ -282,7 +282,7 @@ var _ = Describe("Test Endpoint", func() {
extIf: &externalInterface{IPv4Gateway: net.ParseIP("192.168.0.1")},
}
ep, err := nw2.newEndpointImpl(nil, netlink.NewMockNetlink(false, ""), platform.NewMockExecClient(false),
netio.NewMockNetIO(false, 0), NewMockEndpointClient(nil), NewMockNamespaceClient(), iptables.NewClient(), epInfo)
netio.NewMockNetIO(false, 0), NewMockEndpointClient(nil), NewMockNamespaceClient(), iptables.NewClient(), &mockDHCP{}, epInfo)
Expect(err).NotTo(HaveOccurred())
Expect(ep).NotTo(BeNil())
Expect(ep.Id).To(Equal(epInfo.EndpointID))
Expand All @@ -309,11 +309,11 @@ var _ = Describe("Test Endpoint", func() {
}

return nil
}), NewMockNamespaceClient(), iptables.NewClient(), epInfo)
}), NewMockNamespaceClient(), iptables.NewClient(), &mockDHCP{}, epInfo)
Expect(err).To(HaveOccurred())
Expect(ep).To(BeNil())
ep, err = nw.newEndpointImpl(nil, netlink.NewMockNetlink(false, ""), platform.NewMockExecClient(false),
netio.NewMockNetIO(false, 0), NewMockEndpointClient(nil), NewMockNamespaceClient(), iptables.NewClient(), epInfo)
netio.NewMockNetIO(false, 0), NewMockEndpointClient(nil), NewMockNamespaceClient(), iptables.NewClient(), &mockDHCP{}, epInfo)
Expect(err).NotTo(HaveOccurred())
Expect(ep).NotTo(BeNil())
Expect(ep.Id).To(Equal(epInfo.EndpointID))
Expand Down Expand Up @@ -342,27 +342,27 @@ var _ = Describe("Test Endpoint", func() {
It("Should not add endpoint to the network when there is an error", func() {
secondaryEpInfo.MacAddress = netio.BadHwAddr // mock netlink will fail to set link state on bad eth
ep, err := nw.newEndpointImpl(nil, netlink.NewMockNetlink(false, ""), platform.NewMockExecClient(false),
netio.NewMockNetIO(false, 0), nil, NewMockNamespaceClient(), iptables.NewClient(), secondaryEpInfo)
netio.NewMockNetIO(false, 0), nil, NewMockNamespaceClient(), iptables.NewClient(), &mockDHCP{}, secondaryEpInfo)
Expect(err).To(HaveOccurred())
Expect(err.Error()).To(Equal("SecondaryEndpointClient Error: " + netlink.ErrorMockNetlink.Error()))
Expect(ep).To(BeNil())
// should not panic or error when going through the unified endpoint impl flow with only the delegated nic type fields
secondaryEpInfo.MacAddress = netio.HwAddr
ep, err = nw.newEndpointImpl(nil, netlink.NewMockNetlink(false, ""), platform.NewMockExecClient(false),
netio.NewMockNetIO(false, 0), nil, NewMockNamespaceClient(), iptables.NewClient(), secondaryEpInfo)
netio.NewMockNetIO(false, 0), nil, NewMockNamespaceClient(), iptables.NewClient(), &mockDHCP{}, secondaryEpInfo)
Expect(err).ToNot(HaveOccurred())
Expect(ep.Id).To(Equal(epInfo.EndpointID))
})

It("Should add endpoint when there are no errors", func() {
secondaryEpInfo.MacAddress = netio.HwAddr
ep, err := nw.newEndpointImpl(nil, netlink.NewMockNetlink(false, ""), platform.NewMockExecClient(false),
netio.NewMockNetIO(false, 0), nil, NewMockNamespaceClient(), iptables.NewClient(), secondaryEpInfo)
netio.NewMockNetIO(false, 0), nil, NewMockNamespaceClient(), iptables.NewClient(), &mockDHCP{}, secondaryEpInfo)
Expect(err).ToNot(HaveOccurred())
Expect(ep.Id).To(Equal(epInfo.EndpointID))

ep, err = nw.newEndpointImpl(nil, netlink.NewMockNetlink(false, ""), platform.NewMockExecClient(false),
netio.NewMockNetIO(false, 0), nil, NewMockNamespaceClient(), iptables.NewClient(), epInfo)
netio.NewMockNetIO(false, 0), nil, NewMockNamespaceClient(), iptables.NewClient(), &mockDHCP{}, epInfo)
Expect(err).ToNot(HaveOccurred())
Expect(ep.Id).To(Equal(epInfo.EndpointID))
})
Expand Down
3 changes: 2 additions & 1 deletion network/endpoint_windows.go
Original file line number Diff line number Diff line change
Expand Up @@ -150,6 +150,7 @@ func (nw *network) newEndpointImpl(
_ EndpointClient,
_ NamespaceClientInterface,
_ ipTablesClient,
_ dhcpClient,
epInfo *EndpointInfo,
) (*endpoint, error) {
if epInfo.NICType == cns.BackendNIC {
Expand Down Expand Up @@ -521,7 +522,7 @@ func (nw *network) newEndpointImplHnsV2(cli apipaClient, epInfo *EndpointInfo) (

// deleteEndpointImpl deletes an existing endpoint from the network.
func (nw *network) deleteEndpointImpl(_ netlink.NetlinkInterface, _ platform.ExecClient, _ EndpointClient, _ netio.NetIOInterface, _ NamespaceClientInterface,
_ ipTablesClient, ep *endpoint,
_ ipTablesClient, _ dhcpClient, ep *endpoint,
) error {
// endpoint deletion is not required for IB
if ep.NICType == cns.BackendNIC {
Expand Down
10 changes: 5 additions & 5 deletions network/endpoint_windows_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -107,7 +107,7 @@ func TestDeleteEndpointImplHnsV2ForIB(t *testing.T) {
}

mockCli := NewMockEndpointClient(nil)
err := nw.deleteEndpointImpl(netlink.NewMockNetlink(false, ""), platform.NewMockExecClient(false), mockCli, netio.NewMockNetIO(false, 0), NewMockNamespaceClient(), iptables.NewClient(), &ep)
err := nw.deleteEndpointImpl(netlink.NewMockNetlink(false, ""), platform.NewMockExecClient(false), mockCli, netio.NewMockNetIO(false, 0), NewMockNamespaceClient(), iptables.NewClient(), &mockDHCP{}, &ep)
if err != nil {
t.Fatal("endpoint deletion for IB is executed")
}
Expand All @@ -134,7 +134,7 @@ func TestDeleteEndpointImplHnsV2WithEmptyHNSID(t *testing.T) {

// should return nil because HnsID is empty
mockCli := NewMockEndpointClient(nil)
err := nw.deleteEndpointImpl(netlink.NewMockNetlink(false, ""), platform.NewMockExecClient(false), mockCli, netio.NewMockNetIO(false, 0), NewMockNamespaceClient(), iptables.NewClient(), &ep)
err := nw.deleteEndpointImpl(netlink.NewMockNetlink(false, ""), platform.NewMockExecClient(false), mockCli, netio.NewMockNetIO(false, 0), NewMockNamespaceClient(), iptables.NewClient(), &mockDHCP{}, &ep)
if err != nil {
t.Fatal("endpoint deletion gets executed")
}
Expand Down Expand Up @@ -492,7 +492,7 @@ func TestNewEndpointImplHnsv2ForIBHappyPath(t *testing.T) {

// Happy Path
endpoint, err := nw.newEndpointImpl(nil, netlink.NewMockNetlink(false, ""), platform.NewMockExecClient(false),
netio.NewMockNetIO(false, 0), NewMockEndpointClient(nil), NewMockNamespaceClient(), iptables.NewClient(), epInfo)
netio.NewMockNetIO(false, 0), NewMockEndpointClient(nil), NewMockNamespaceClient(), iptables.NewClient(), &mockDHCP{}, epInfo)

if endpoint != nil || err != nil {
t.Fatalf("Endpoint is created for IB due to %v", err)
Expand Down Expand Up @@ -522,7 +522,7 @@ func TestNewEndpointImplHnsv2ForIBUnHappyPath(t *testing.T) {

// Set UnHappy Path
_, err := nw.newEndpointImpl(nil, netlink.NewMockNetlink(false, ""), platform.NewMockExecClient(true),
netio.NewMockNetIO(false, 0), NewMockEndpointClient(nil), NewMockNamespaceClient(), iptables.NewClient(), epInfo)
netio.NewMockNetIO(false, 0), NewMockEndpointClient(nil), NewMockNamespaceClient(), iptables.NewClient(), &mockDHCP{}, epInfo)

if err == nil {
t.Fatal("Failed to test Endpoint creation for IB with unhappy path")
Expand Down Expand Up @@ -562,7 +562,7 @@ func TestCreateAndDeleteEndpointImplHnsv2ForDelegatedHappyPath(t *testing.T) {
}

mockCli := NewMockEndpointClient(nil)
err = nw.deleteEndpointImpl(netlink.NewMockNetlink(false, ""), platform.NewMockExecClient(false), mockCli, netio.NewMockNetIO(false, 0), NewMockNamespaceClient(), iptables.NewClient(), ep)
err = nw.deleteEndpointImpl(netlink.NewMockNetlink(false, ""), platform.NewMockExecClient(false), mockCli, netio.NewMockNetIO(false, 0), NewMockNamespaceClient(), iptables.NewClient(), &mockDHCP{}, ep)
if err != nil {
t.Fatalf("Failed to delete endpoint for Delegated NIC due to %v", err)
}
Expand Down
Loading

0 comments on commit 202ac09

Please sign in to comment.