diff options
Diffstat (limited to 'dhcpv6/option_iapd_test.go')
-rw-r--r-- | dhcpv6/option_iapd_test.go | 111 |
1 files changed, 111 insertions, 0 deletions
diff --git a/dhcpv6/option_iapd_test.go b/dhcpv6/option_iapd_test.go new file mode 100644 index 0000000..babb5a7 --- /dev/null +++ b/dhcpv6/option_iapd_test.go @@ -0,0 +1,111 @@ +package dhcpv6 + +import ( + "net" + "testing" + "time" + + "github.com/stretchr/testify/require" +) + +func TestOptIAPDParseOptIAPD(t *testing.T) { + data := []byte{ + 1, 0, 0, 0, // IAID + 0, 0, 0, 1, // T1 + 0, 0, 0, 2, // T2 + 0, 26, 0, 25, // 26 = IAPrefix Option, 25 = length + 0xaa, 0xbb, 0xcc, 0xdd, // IAPrefix preferredLifetime + 0xee, 0xff, 0x00, 0x11, // IAPrefix validLifetime + 36, // IAPrefix prefixLength + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, // IAPrefix ipv6Prefix + } + opt, err := ParseOptIAPD(data) + require.NoError(t, err) + require.Equal(t, OptionIAPD, opt.Code()) + require.Equal(t, [4]byte{1, 0, 0, 0}, opt.IaId) + require.Equal(t, time.Second, opt.T1) + require.Equal(t, 2*time.Second, opt.T2) +} + +func TestOptIAPDParseOptIAPDInvalidLength(t *testing.T) { + data := []byte{ + 1, 0, 0, 0, // IAID + 0, 0, 0, 1, // T1 + // truncated from here + } + _, err := ParseOptIAPD(data) + require.Error(t, err) +} + +func TestOptIAPDParseOptIAPDInvalidOptions(t *testing.T) { + data := []byte{ + 1, 0, 0, 0, // IAID + 0, 0, 0, 1, // T1 + 0, 0, 0, 2, // T2 + 0, 26, 0, 25, // 26 = IAPrefix Option, 25 = length + 0xaa, 0xbb, 0xcc, 0xdd, // IAPrefix preferredLifetime + 0xee, 0xff, 0x00, 0x11, // IAPrefix validLifetime + 36, // IAPrefix prefixLength + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, // IAPrefix ipv6Prefix missing last byte + } + _, err := ParseOptIAPD(data) + require.Error(t, err) +} + +func TestOptIAPDToBytes(t *testing.T) { + oaddr := OptIAPrefix{} + oaddr.PreferredLifetime = 0xaabbccdd * time.Second + oaddr.ValidLifetime = 0xeeff0011 * time.Second + oaddr.SetPrefixLength(36) + oaddr.SetIPv6Prefix(net.IPv6loopback) + + opt := OptIAPD{} + opt.IaId = [4]byte{1, 2, 3, 4} + opt.T1 = 12345 * time.Second + opt.T2 = 54321 * time.Second + opt.Options = append(opt.Options, &oaddr) + + expected := []byte{ + 1, 2, 3, 4, // IA ID + 0, 0, 0x30, 0x39, // T1 = 12345 + 0, 0, 0xd4, 0x31, // T2 = 54321 + 0, 26, 0, 25, // 26 = IAPrefix Option, 25 = length + 0xaa, 0xbb, 0xcc, 0xdd, // IAPrefix preferredLifetime + 0xee, 0xff, 0x00, 0x11, // IAPrefix validLifetime + 36, // IAPrefix prefixLength + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, // IAPrefix ipv6Prefix + } + require.Equal(t, expected, opt.ToBytes()) +} + +func TestOptIAPDString(t *testing.T) { + data := []byte{ + 1, 0, 0, 0, // IAID + 0, 0, 0, 1, // T1 + 0, 0, 0, 2, // T2 + 0, 26, 0, 25, // 26 = IAPrefix Option, 25 = length + 0xaa, 0xbb, 0xcc, 0xdd, // IAPrefix preferredLifetime + 0xee, 0xff, 0x00, 0x11, // IAPrefix validLifetime + 36, // IAPrefix prefixLength + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, // IAPrefix ipv6Prefix + } + opt, err := ParseOptIAPD(data) + require.NoError(t, err) + + str := opt.String() + require.Contains( + t, str, + "IAID=[1 0 0 0]", + "String() should return the IAID", + ) + require.Contains( + t, str, + "t1=1s, t2=2s", + "String() should return the T1/T2 options", + ) + require.Contains( + t, str, + "options=[", + "String() should return a list of options", + ) +} |