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 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}, } 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 := 0; i < 1000; i++ { 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) } }) } }