1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677 |
- package bridge
- import (
- "bytes"
- "net"
- "strings"
- "testing"
- "github.com/docker/libnetwork"
- "github.com/vishvananda/netlink"
- )
- func TestSetupNewBridge(t *testing.T) {
- defer libnetwork.SetupTestNetNS(t)()
- br := &Interface{
- Config: &Configuration{
- BridgeName: DefaultBridgeName,
- },
- }
- if err := SetupDevice(br); err != nil {
- t.Fatalf("Bridge creation failed: %v", err)
- }
- if br.Link == nil {
- t.Fatal("Interface link is nil (expected valid link)")
- }
- if _, err := netlink.LinkByName(DefaultBridgeName); err != nil {
- t.Fatalf("Failed to retrieve bridge device: %v", err)
- }
- if br.Link.Attrs().Flags&net.FlagUp == net.FlagUp {
- t.Fatalf("Interface should be created down")
- }
- }
- func TestSetupNewNonDefaultBridge(t *testing.T) {
- defer libnetwork.SetupTestNetNS(t)()
- br := &Interface{
- Config: &Configuration{
- BridgeName: "test0",
- },
- }
- if err := SetupDevice(br); err == nil || !strings.Contains(err.Error(), "non default name") {
- t.Fatalf("Expected bridge creation failure with \"non default name\", got: %v", err)
- }
- }
- func TestSetupDeviceUp(t *testing.T) {
- defer libnetwork.SetupTestNetNS(t)()
- br := &Interface{
- Config: &Configuration{
- BridgeName: DefaultBridgeName,
- },
- }
- if err := SetupDevice(br); err != nil {
- t.Fatalf("Bridge creation failed: %v", err)
- }
- if err := SetupDeviceUp(br); err != nil {
- t.Fatalf("Failed to up bridge device: %v", err)
- }
- lnk, _ := netlink.LinkByName(DefaultBridgeName)
- if lnk.Attrs().Flags&net.FlagUp != net.FlagUp {
- t.Fatalf("Interface should be up")
- }
- }
- func TestGenerateRandomMAC(t *testing.T) {
- defer libnetwork.SetupTestNetNS(t)()
- mac1 := generateRandomMAC()
- mac2 := generateRandomMAC()
- if bytes.Compare(mac1, mac2) == 0 {
- t.Fatalf("Generated twice the same MAC address %v", mac1)
- }
- }
|