mirror of
https://github.com/qdm12/gluetun.git
synced 2025-12-12 18:32:13 -06:00
114 lines
3.0 KiB
Go
114 lines
3.0 KiB
Go
package wireguard
|
|
|
|
import (
|
|
"errors"
|
|
"net/netip"
|
|
"testing"
|
|
|
|
"github.com/golang/mock/gomock"
|
|
"github.com/qdm12/gluetun/internal/netlink"
|
|
"github.com/stretchr/testify/assert"
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
func Test_Wireguard_addAddresses(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
ipNetOne := netip.PrefixFrom(netip.AddrFrom4([4]byte{1, 2, 3, 4}), 32)
|
|
ipNetTwo := netip.PrefixFrom(netip.MustParseAddr("::1234"), 64)
|
|
|
|
errDummy := errors.New("dummy")
|
|
|
|
testCases := map[string]struct {
|
|
link netlink.Link
|
|
addrs []netip.Prefix
|
|
wgBuilder func(ctrl *gomock.Controller, link netlink.Link) *Wireguard
|
|
err error
|
|
}{
|
|
"success": {
|
|
link: netlink.Link{Type: "wireguard"},
|
|
addrs: []netip.Prefix{ipNetOne, ipNetTwo},
|
|
wgBuilder: func(ctrl *gomock.Controller, link netlink.Link) *Wireguard {
|
|
netLinker := NewMockNetLinker(ctrl)
|
|
firstCall := netLinker.EXPECT().
|
|
AddrReplace(link, netlink.Addr{Network: ipNetOne}).
|
|
Return(nil)
|
|
netLinker.EXPECT().
|
|
AddrReplace(link, netlink.Addr{Network: ipNetTwo}).
|
|
Return(nil).After(firstCall)
|
|
return &Wireguard{
|
|
netlink: netLinker,
|
|
settings: Settings{
|
|
IPv6: ptrTo(true),
|
|
},
|
|
}
|
|
},
|
|
},
|
|
"first add error": {
|
|
link: netlink.Link{Type: "wireguard", Name: "a_bridge"},
|
|
addrs: []netip.Prefix{ipNetOne, ipNetTwo},
|
|
wgBuilder: func(ctrl *gomock.Controller, link netlink.Link) *Wireguard {
|
|
netLinker := NewMockNetLinker(ctrl)
|
|
netLinker.EXPECT().
|
|
AddrReplace(link, netlink.Addr{Network: ipNetOne}).
|
|
Return(errDummy)
|
|
return &Wireguard{
|
|
netlink: netLinker,
|
|
settings: Settings{
|
|
IPv6: ptrTo(true),
|
|
},
|
|
}
|
|
},
|
|
err: errors.New("dummy: when adding address 1.2.3.4/32 to link a_bridge"),
|
|
},
|
|
"second add error": {
|
|
link: netlink.Link{Type: "wireguard", Name: "a_bridge"},
|
|
addrs: []netip.Prefix{ipNetOne, ipNetTwo},
|
|
wgBuilder: func(ctrl *gomock.Controller, link netlink.Link) *Wireguard {
|
|
netLinker := NewMockNetLinker(ctrl)
|
|
firstCall := netLinker.EXPECT().
|
|
AddrReplace(link, netlink.Addr{Network: ipNetOne}).
|
|
Return(nil)
|
|
netLinker.EXPECT().
|
|
AddrReplace(link, netlink.Addr{Network: ipNetTwo}).
|
|
Return(errDummy).After(firstCall)
|
|
return &Wireguard{
|
|
netlink: netLinker,
|
|
settings: Settings{
|
|
IPv6: ptrTo(true),
|
|
},
|
|
}
|
|
},
|
|
err: errors.New("dummy: when adding address ::1234/64 to link a_bridge"),
|
|
},
|
|
"ignore IPv6": {
|
|
addrs: []netip.Prefix{ipNetTwo},
|
|
wgBuilder: func(_ *gomock.Controller, _ netlink.Link) *Wireguard {
|
|
return &Wireguard{
|
|
settings: Settings{
|
|
IPv6: ptrTo(false),
|
|
},
|
|
}
|
|
},
|
|
},
|
|
}
|
|
|
|
for name, testCase := range testCases {
|
|
t.Run(name, func(t *testing.T) {
|
|
t.Parallel()
|
|
ctrl := gomock.NewController(t)
|
|
|
|
wg := testCase.wgBuilder(ctrl, testCase.link)
|
|
|
|
err := wg.addAddresses(testCase.link, testCase.addrs)
|
|
|
|
if testCase.err != nil {
|
|
require.Error(t, err)
|
|
assert.Equal(t, testCase.err.Error(), err.Error())
|
|
} else {
|
|
require.NoError(t, err)
|
|
}
|
|
})
|
|
}
|
|
}
|