automation-tests/common/libnetwork/internal/util/ip_test.go

76 lines
2.6 KiB
Go

package util
import (
"fmt"
"net"
"reflect"
"testing"
)
func parseCIDR(n string) *net.IPNet {
_, parsedNet, _ := net.ParseCIDR(n)
return parsedNet
}
func TestNextSubnet(t *testing.T) {
type args struct {
subnet *net.IPNet
}
tests := []struct {
name string
args args
want *net.IPNet
wantErr bool
}{
{"class a", args{subnet: parseCIDR("10.0.0.0/8")}, parseCIDR("11.0.0.0/8"), false},
{"class b", args{subnet: parseCIDR("192.168.0.0/16")}, parseCIDR("192.169.0.0/16"), false},
{"class c", args{subnet: parseCIDR("192.168.1.0/24")}, parseCIDR("192.168.2.0/24"), false},
{"custom cidr /23", args{subnet: parseCIDR("192.168.0.0/23")}, parseCIDR("192.168.2.0/23"), false},
{"custom cidr /23 2", args{subnet: parseCIDR("192.168.2.0/23")}, parseCIDR("192.168.4.0/23"), false},
{"custom cidr /23 with overflow", args{subnet: parseCIDR("192.168.254.0/23")}, parseCIDR("192.169.0.0/23"), false},
{"/9", args{subnet: parseCIDR("10.0.0.0/9")}, parseCIDR("10.128.0.0/9"), false},
{"/11", args{subnet: parseCIDR("10.0.0.0/11")}, parseCIDR("10.32.0.0/11"), false},
{"/11", args{subnet: parseCIDR("0.0.0.0/11")}, parseCIDR("0.32.0.0/11"), false},
{"only one subnet", args{subnet: parseCIDR("0.0.0.0/0")}, nil, true},
{"no more subnets", args{subnet: parseCIDR("255.255.255.0/24")}, nil, true},
{"no more subnets 2", args{subnet: parseCIDR("255.240.0.0/12")}, nil, true},
{"ipv6", args{subnet: parseCIDR("fdfd:d319:b145:fd4b::/64")}, parseCIDR("fdfd:d319:b145:fd4c::/64"), false},
{"ipv6 with overflow", args{subnet: parseCIDR("fdfd:d319:b145:ffff::/64")}, parseCIDR("fdfd:d319:b146:0::/64"), false},
}
for _, tt := range tests {
test := tt
t.Run(test.name, func(t *testing.T) {
got, err := NextSubnet(test.args.subnet)
if (err != nil) != test.wantErr {
t.Errorf("NextSubnet() error = %v, wantErr %v", err, test.wantErr)
return
}
if !reflect.DeepEqual(got, test.want) {
t.Errorf("NextSubnet() got = %v, want %v", got, test.want)
}
})
}
}
func TestGetRandomIPv6Subnet(t *testing.T) {
for i := range 1000 {
t.Run(fmt.Sprintf("GetRandomIPv6Subnet %d", i), func(t *testing.T) {
sub, err := getRandomIPv6Subnet()
if err != nil {
t.Errorf("GetRandomIPv6Subnet() error should be nil: %v", err)
return
}
if sub.IP.To4() != nil {
t.Errorf("ip %s is not an ipv6 address", sub.IP)
}
if sub.IP[0] != 0xfd {
t.Errorf("ipv6 %s does not start with fd", sub.IP)
}
ones, bytes := sub.Mask.Size()
if ones != 64 || bytes != 128 {
t.Errorf("wrong network mask %v, it should be /64", sub.Mask)
}
})
}
}