Test coverage
Signed-off-by: Arnaud Porterie <arnaud.porterie@docker.com>
This commit is contained in:
parent
94e8db8774
commit
cb96e4149d
4 changed files with 59 additions and 2 deletions
|
@ -11,5 +11,6 @@ func (b *bridgeNetwork) Type() string {
|
|||
}
|
||||
|
||||
func (b *bridgeNetwork) Link(name string) ([]*libnetwork.Interface, error) {
|
||||
// TODO
|
||||
return nil, nil
|
||||
}
|
||||
|
|
|
@ -47,7 +47,11 @@ func SetupBridgeIPv4(i *Interface) error {
|
|||
}
|
||||
|
||||
log.Debugf("Creating bridge interface %q with network %s", i.Config.BridgeName, bridgeIPv4)
|
||||
return netlink.AddrAdd(i.Link, &netlink.Addr{bridgeIPv4, ""})
|
||||
if err := netlink.AddrAdd(i.Link, &netlink.Addr{bridgeIPv4, ""}); err != nil {
|
||||
return fmt.Errorf("Failed to add IPv4 address %s to bridge: %v", bridgeIPv4, err)
|
||||
}
|
||||
|
||||
return nil
|
||||
}
|
||||
|
||||
func electBridgeIPv4(config *Configuration) (*net.IPNet, error) {
|
||||
|
|
|
@ -28,5 +28,10 @@ func SetupBridgeIPv6(i *Interface) error {
|
|||
if err := ioutil.WriteFile(procFile, []byte{'0', '\n'}, 0644); err != nil {
|
||||
return fmt.Errorf("Unable to enable IPv6 addresses on bridge: %v", err)
|
||||
}
|
||||
return netlink.AddrAdd(i.Link, &netlink.Addr{BridgeIPv6, ""})
|
||||
|
||||
if err := netlink.AddrAdd(i.Link, &netlink.Addr{BridgeIPv6, ""}); err != nil {
|
||||
return fmt.Errorf("Failed to add IPv6 address %s to bridge: %v", BridgeIPv6, err)
|
||||
}
|
||||
|
||||
return nil
|
||||
}
|
||||
|
|
47
libnetwork/drivers/bridge/setup_ipv6_test.go
Normal file
47
libnetwork/drivers/bridge/setup_ipv6_test.go
Normal file
|
@ -0,0 +1,47 @@
|
|||
package bridge
|
||||
|
||||
import (
|
||||
"bytes"
|
||||
"fmt"
|
||||
"io/ioutil"
|
||||
"testing"
|
||||
|
||||
"github.com/docker/libnetwork"
|
||||
"github.com/vishvananda/netlink"
|
||||
)
|
||||
|
||||
func TestSetupIPv6(t *testing.T) {
|
||||
defer libnetwork.SetupTestNetNS(t)()
|
||||
|
||||
br := setupTestInterface(t)
|
||||
if err := SetupBridgeIPv6(br); err != nil {
|
||||
t.Fatalf("Failed to setup bridge IPv6: %v", err)
|
||||
}
|
||||
|
||||
procSetting, err := ioutil.ReadFile(fmt.Sprintf("/proc/sys/net/ipv6/conf/%s/disable_ipv6", br.Config.BridgeName))
|
||||
if err != nil {
|
||||
t.Fatalf("Failed to read disable_ipv6 kernel setting: %v", err)
|
||||
}
|
||||
|
||||
if expected := []byte("0\n"); bytes.Compare(expected, procSetting) != 0 {
|
||||
t.Fatalf("Invalid kernel setting disable_ipv6: expected %q, got %q", string(expected), string(procSetting))
|
||||
}
|
||||
|
||||
addrsv6, err := netlink.AddrList(br.Link, netlink.FAMILY_V6)
|
||||
if err != nil {
|
||||
t.Fatalf("Failed to list device IPv6 addresses: %v", err)
|
||||
}
|
||||
|
||||
var found bool
|
||||
for _, addr := range addrsv6 {
|
||||
if BridgeIPv6Str == addr.IPNet.String() {
|
||||
found = true
|
||||
break
|
||||
}
|
||||
}
|
||||
|
||||
if !found {
|
||||
t.Fatalf("Bridge device does not have requested IPv6 address %v", BridgeIPv6Str)
|
||||
}
|
||||
|
||||
}
|
Loading…
Add table
Reference in a new issue