1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65
|
// Copyright 2018-present the CoreDHCP Authors. All rights reserved
// This source code is licensed under the MIT license found in the
// LICENSE file in the root directory of this source tree.
package netmask
import (
"net"
"testing"
"github.com/insomniacslk/dhcp/dhcpv4"
"github.com/stretchr/testify/assert"
)
func TestCheckValidNetmask(t *testing.T) {
assert.True(t, checkValidNetmask(net.IPv4Mask(255, 255, 255, 0)))
assert.True(t, checkValidNetmask(net.IPv4Mask(255, 255, 0, 0)))
assert.True(t, checkValidNetmask(net.IPv4Mask(255, 0, 0, 0)))
assert.True(t, checkValidNetmask(net.IPv4Mask(0, 0, 0, 0)))
assert.False(t, checkValidNetmask(net.IPv4Mask(0, 255, 255, 255)))
assert.False(t, checkValidNetmask(net.IPv4Mask(0, 0, 255, 255)))
assert.False(t, checkValidNetmask(net.IPv4Mask(0, 0, 0, 255)))
}
func TestHandler4(t *testing.T) {
// set plugin netmask
netmask = net.IPv4Mask(255, 255, 255, 0)
// prepare DHCPv4 request
req := &dhcpv4.DHCPv4{}
resp := &dhcpv4.DHCPv4{
Options: dhcpv4.Options{},
}
// if we handle this DHCP request, the netmask should be one of the options
// of the result
result, stop := Handler4(req, resp)
assert.Same(t, result, resp)
assert.False(t, stop)
assert.EqualValues(t, netmask, resp.Options.Get(dhcpv4.OptionSubnetMask))
}
func TestSetup4(t *testing.T) {
// valid configuration
_, err := setup4("255.255.255.0")
assert.NoError(t, err)
assert.EqualValues(t, netmask, net.IPv4Mask(255, 255, 255, 0))
// no configuration
_, err = setup4()
assert.Error(t, err)
// unspecified netmask
_, err = setup4("0.0.0.0")
assert.Error(t, err)
// ipv6 prefix
_, err = setup4("ff02::/64")
assert.Error(t, err)
// invalid netmask
_, err = setup4("0.0.0.255")
assert.Error(t, err)
}
|