mirror of
https://github.com/AdguardTeam/AdGuardHome.git
synced 2024-12-16 11:52:58 +03:00
506b459842
Merge in DNS/adguard-home from 3225-bsd-dhcp to master Closes #3225. Closes #3417. Squashed commit of the following: commit e7ea691824c7ebc8cafd8c9e206679346cbc8592 Author: Eugene Burkov <e.burkov@adguard.com> Date: Thu Aug 12 17:02:02 2021 +0300 all: imp code, docs commit 5b598fc18a9b69a0256569f4c691bb6a2193dfbd Author: Eugene Burkov <e.burkov@adguard.com> Date: Thu Aug 12 16:28:12 2021 +0300 all: mv logic, imp code, docs, log changes commit e3e1577a668fe3e5c61d075c390e4bd7268181ba Author: Eugene Burkov <e.burkov@adguard.com> Date: Thu Aug 12 14:15:10 2021 +0300 dhcpd: imp checkother commit 3cc8b058195c30a7ef0b7741ee8463270d9e47ff Author: Eugene Burkov <e.burkov@adguard.com> Date: Wed Aug 11 13:20:18 2021 +0300 all: imp bsd support
182 lines
4.1 KiB
Go
182 lines
4.1 KiB
Go
package aghnet
|
|
|
|
import (
|
|
"net"
|
|
"testing"
|
|
|
|
"github.com/AdguardTeam/golibs/errors"
|
|
"github.com/stretchr/testify/assert"
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
type fakeIface struct {
|
|
addrs []net.Addr
|
|
err error
|
|
}
|
|
|
|
// Addrs implements the NetIface interface for *fakeIface.
|
|
func (iface *fakeIface) Addrs() (addrs []net.Addr, err error) {
|
|
if iface.err != nil {
|
|
return nil, iface.err
|
|
}
|
|
|
|
return iface.addrs, nil
|
|
}
|
|
|
|
func TestIfaceIPAddrs(t *testing.T) {
|
|
const errTest errors.Error = "test error"
|
|
|
|
ip4 := net.IP{1, 2, 3, 4}
|
|
addr4 := &net.IPNet{IP: ip4}
|
|
|
|
ip6 := net.IP{1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6}
|
|
addr6 := &net.IPNet{IP: ip6}
|
|
|
|
testCases := []struct {
|
|
name string
|
|
iface NetIface
|
|
ipv IPVersion
|
|
want []net.IP
|
|
wantErr error
|
|
}{{
|
|
name: "ipv4_success",
|
|
iface: &fakeIface{addrs: []net.Addr{addr4}, err: nil},
|
|
ipv: IPVersion4,
|
|
want: []net.IP{ip4},
|
|
wantErr: nil,
|
|
}, {
|
|
name: "ipv4_success_with_ipv6",
|
|
iface: &fakeIface{addrs: []net.Addr{addr6, addr4}, err: nil},
|
|
ipv: IPVersion4,
|
|
want: []net.IP{ip4},
|
|
wantErr: nil,
|
|
}, {
|
|
name: "ipv4_error",
|
|
iface: &fakeIface{addrs: []net.Addr{addr4}, err: errTest},
|
|
ipv: IPVersion4,
|
|
want: nil,
|
|
wantErr: errTest,
|
|
}, {
|
|
name: "ipv6_success",
|
|
iface: &fakeIface{addrs: []net.Addr{addr6}, err: nil},
|
|
ipv: IPVersion6,
|
|
want: []net.IP{ip6},
|
|
wantErr: nil,
|
|
}, {
|
|
name: "ipv6_success_with_ipv4",
|
|
iface: &fakeIface{addrs: []net.Addr{addr6, addr4}, err: nil},
|
|
ipv: IPVersion6,
|
|
want: []net.IP{ip6},
|
|
wantErr: nil,
|
|
}, {
|
|
name: "ipv6_error",
|
|
iface: &fakeIface{addrs: []net.Addr{addr6}, err: errTest},
|
|
ipv: IPVersion6,
|
|
want: nil,
|
|
wantErr: errTest,
|
|
}}
|
|
|
|
for _, tc := range testCases {
|
|
t.Run(tc.name, func(t *testing.T) {
|
|
got, gotErr := IfaceIPAddrs(tc.iface, tc.ipv)
|
|
require.True(t, errors.Is(gotErr, tc.wantErr))
|
|
assert.Equal(t, tc.want, got)
|
|
})
|
|
}
|
|
}
|
|
|
|
type waitingFakeIface struct {
|
|
addrs []net.Addr
|
|
err error
|
|
n int
|
|
}
|
|
|
|
// Addrs implements the NetIface interface for *waitingFakeIface.
|
|
func (iface *waitingFakeIface) Addrs() (addrs []net.Addr, err error) {
|
|
if iface.err != nil {
|
|
return nil, iface.err
|
|
}
|
|
|
|
if iface.n == 0 {
|
|
return iface.addrs, nil
|
|
}
|
|
|
|
iface.n--
|
|
|
|
return nil, nil
|
|
}
|
|
|
|
func TestIfaceDNSIPAddrs(t *testing.T) {
|
|
const errTest errors.Error = "test error"
|
|
|
|
ip4 := net.IP{1, 2, 3, 4}
|
|
addr4 := &net.IPNet{IP: ip4}
|
|
|
|
ip6 := net.IP{1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6}
|
|
addr6 := &net.IPNet{IP: ip6}
|
|
|
|
testCases := []struct {
|
|
name string
|
|
iface NetIface
|
|
ipv IPVersion
|
|
want []net.IP
|
|
wantErr error
|
|
}{{
|
|
name: "ipv4_success",
|
|
iface: &fakeIface{addrs: []net.Addr{addr4}, err: nil},
|
|
ipv: IPVersion4,
|
|
want: []net.IP{ip4, ip4},
|
|
wantErr: nil,
|
|
}, {
|
|
name: "ipv4_success_with_ipv6",
|
|
iface: &fakeIface{addrs: []net.Addr{addr6, addr4}, err: nil},
|
|
ipv: IPVersion4,
|
|
want: []net.IP{ip4, ip4},
|
|
wantErr: nil,
|
|
}, {
|
|
name: "ipv4_error",
|
|
iface: &fakeIface{addrs: []net.Addr{addr4}, err: errTest},
|
|
ipv: IPVersion4,
|
|
want: nil,
|
|
wantErr: errTest,
|
|
}, {
|
|
name: "ipv4_wait",
|
|
iface: &waitingFakeIface{addrs: []net.Addr{addr4}, err: nil, n: 1},
|
|
ipv: IPVersion4,
|
|
want: []net.IP{ip4, ip4},
|
|
wantErr: nil,
|
|
}, {
|
|
name: "ipv6_success",
|
|
iface: &fakeIface{addrs: []net.Addr{addr6}, err: nil},
|
|
ipv: IPVersion6,
|
|
want: []net.IP{ip6, ip6},
|
|
wantErr: nil,
|
|
}, {
|
|
name: "ipv6_success_with_ipv4",
|
|
iface: &fakeIface{addrs: []net.Addr{addr6, addr4}, err: nil},
|
|
ipv: IPVersion6,
|
|
want: []net.IP{ip6, ip6},
|
|
wantErr: nil,
|
|
}, {
|
|
name: "ipv6_error",
|
|
iface: &fakeIface{addrs: []net.Addr{addr6}, err: errTest},
|
|
ipv: IPVersion6,
|
|
want: nil,
|
|
wantErr: errTest,
|
|
}, {
|
|
name: "ipv6_wait",
|
|
iface: &waitingFakeIface{addrs: []net.Addr{addr6}, err: nil, n: 1},
|
|
ipv: IPVersion6,
|
|
want: []net.IP{ip6, ip6},
|
|
wantErr: nil,
|
|
}}
|
|
|
|
for _, tc := range testCases {
|
|
t.Run(tc.name, func(t *testing.T) {
|
|
got, gotErr := IfaceDNSIPAddrs(tc.iface, tc.ipv, 2, 0)
|
|
require.True(t, errors.Is(gotErr, tc.wantErr))
|
|
assert.Equal(t, tc.want, got)
|
|
})
|
|
}
|
|
}
|