diff options
author | MikoĊaj Walczak <mikiwalczak+github@gmail.com> | 2018-07-12 10:51:38 +0100 |
---|---|---|
committer | insomniac <insomniacslk@users.noreply.github.com> | 2018-07-12 10:51:38 +0100 |
commit | 8e3bcdab237624421034ccc4eb16f260d4338aec (patch) | |
tree | 0cb93b736c59506f68df67ac1150e80047dc202c /dhcpv6/async_test.go | |
parent | 34154e71da6f5b4527809dc0babdefcbd262281c (diff) |
Asynchronous client for DHCPv6 (#80)
Diffstat (limited to 'dhcpv6/async_test.go')
-rw-r--r-- | dhcpv6/async_test.go | 54 |
1 files changed, 54 insertions, 0 deletions
diff --git a/dhcpv6/async_test.go b/dhcpv6/async_test.go new file mode 100644 index 0000000..4f5a750 --- /dev/null +++ b/dhcpv6/async_test.go @@ -0,0 +1,54 @@ +package dhcpv6 + +import ( + "net" + "testing" + "time" + + "github.com/stretchr/testify/require" +) + +func TestNewAsyncClient(t *testing.T) { + c := NewAsyncClient() + require.NotNil(t, c) + require.Equal(t, c.ReadTimeout, DefaultReadTimeout) + require.Equal(t, c.ReadTimeout, DefaultWriteTimeout) +} + +func TestOpenInvalidAddrFailes(t *testing.T) { + c := NewAsyncClient() + err := c.Open(512) + require.Error(t, err) +} + +// This test uses port 15438 so please make sure its not used before running +func TestOpenClose(t *testing.T) { + c := NewAsyncClient() + addr, err := net.ResolveUDPAddr("udp6", ":15438") + require.NoError(t, err) + c.LocalAddr = addr + err = c.Open(512) + require.NoError(t, err) + defer c.Close() +} + +// This test uses ports 15438 and 15439 so please make sure they are not used +// before running +func TestSendTimeout(t *testing.T) { + c := NewAsyncClient() + addr, err := net.ResolveUDPAddr("udp6", ":15438") + require.NoError(t, err) + remote, err := net.ResolveUDPAddr("udp6", ":15439") + require.NoError(t, err) + c.ReadTimeout = 50 * time.Millisecond + c.WriteTimeout = 50 * time.Millisecond + c.LocalAddr = addr + c.RemoteAddr = remote + err = c.Open(512) + require.NoError(t, err) + defer c.Close() + m, err := NewMessage() + require.NoError(t, err) + _, err = c.Send(m).WaitTimeout(200 * time.Millisecond) + require.Error(t, err) +} |