github.com/daaku/docker@v1.5.0/daemon/networkdriver/portmapper/mapper_test.go (about)

     1  package portmapper
     2  
     3  import (
     4  	"net"
     5  	"testing"
     6  
     7  	"github.com/docker/docker/daemon/networkdriver/portallocator"
     8  	"github.com/docker/docker/pkg/iptables"
     9  )
    10  
    11  func init() {
    12  	// override this func to mock out the proxy server
    13  	NewProxy = NewMockProxyCommand
    14  }
    15  
    16  func reset() {
    17  	chain = nil
    18  	currentMappings = make(map[string]*mapping)
    19  }
    20  
    21  func TestSetIptablesChain(t *testing.T) {
    22  	defer reset()
    23  
    24  	c := &iptables.Chain{
    25  		Name:   "TEST",
    26  		Bridge: "192.168.1.1",
    27  	}
    28  
    29  	if chain != nil {
    30  		t.Fatal("chain should be nil at init")
    31  	}
    32  
    33  	SetIptablesChain(c)
    34  	if chain == nil {
    35  		t.Fatal("chain should not be nil after set")
    36  	}
    37  }
    38  
    39  func TestMapPorts(t *testing.T) {
    40  	dstIp1 := net.ParseIP("192.168.0.1")
    41  	dstIp2 := net.ParseIP("192.168.0.2")
    42  	dstAddr1 := &net.TCPAddr{IP: dstIp1, Port: 80}
    43  	dstAddr2 := &net.TCPAddr{IP: dstIp2, Port: 80}
    44  
    45  	srcAddr1 := &net.TCPAddr{Port: 1080, IP: net.ParseIP("172.16.0.1")}
    46  	srcAddr2 := &net.TCPAddr{Port: 1080, IP: net.ParseIP("172.16.0.2")}
    47  
    48  	addrEqual := func(addr1, addr2 net.Addr) bool {
    49  		return (addr1.Network() == addr2.Network()) && (addr1.String() == addr2.String())
    50  	}
    51  
    52  	if host, err := Map(srcAddr1, dstIp1, 80); err != nil {
    53  		t.Fatalf("Failed to allocate port: %s", err)
    54  	} else if !addrEqual(dstAddr1, host) {
    55  		t.Fatalf("Incorrect mapping result: expected %s:%s, got %s:%s",
    56  			dstAddr1.String(), dstAddr1.Network(), host.String(), host.Network())
    57  	}
    58  
    59  	if _, err := Map(srcAddr1, dstIp1, 80); err == nil {
    60  		t.Fatalf("Port is in use - mapping should have failed")
    61  	}
    62  
    63  	if _, err := Map(srcAddr2, dstIp1, 80); err == nil {
    64  		t.Fatalf("Port is in use - mapping should have failed")
    65  	}
    66  
    67  	if _, err := Map(srcAddr2, dstIp2, 80); err != nil {
    68  		t.Fatalf("Failed to allocate port: %s", err)
    69  	}
    70  
    71  	if Unmap(dstAddr1) != nil {
    72  		t.Fatalf("Failed to release port")
    73  	}
    74  
    75  	if Unmap(dstAddr2) != nil {
    76  		t.Fatalf("Failed to release port")
    77  	}
    78  
    79  	if Unmap(dstAddr2) == nil {
    80  		t.Fatalf("Port already released, but no error reported")
    81  	}
    82  }
    83  
    84  func TestGetUDPKey(t *testing.T) {
    85  	addr := &net.UDPAddr{IP: net.ParseIP("192.168.1.5"), Port: 53}
    86  
    87  	key := getKey(addr)
    88  
    89  	if expected := "192.168.1.5:53/udp"; key != expected {
    90  		t.Fatalf("expected key %s got %s", expected, key)
    91  	}
    92  }
    93  
    94  func TestGetTCPKey(t *testing.T) {
    95  	addr := &net.TCPAddr{IP: net.ParseIP("192.168.1.5"), Port: 80}
    96  
    97  	key := getKey(addr)
    98  
    99  	if expected := "192.168.1.5:80/tcp"; key != expected {
   100  		t.Fatalf("expected key %s got %s", expected, key)
   101  	}
   102  }
   103  
   104  func TestGetUDPIPAndPort(t *testing.T) {
   105  	addr := &net.UDPAddr{IP: net.ParseIP("192.168.1.5"), Port: 53}
   106  
   107  	ip, port := getIPAndPort(addr)
   108  	if expected := "192.168.1.5"; ip.String() != expected {
   109  		t.Fatalf("expected ip %s got %s", expected, ip)
   110  	}
   111  
   112  	if ep := 53; port != ep {
   113  		t.Fatalf("expected port %d got %d", ep, port)
   114  	}
   115  }
   116  
   117  func TestMapAllPortsSingleInterface(t *testing.T) {
   118  	dstIp1 := net.ParseIP("0.0.0.0")
   119  	srcAddr1 := &net.TCPAddr{Port: 1080, IP: net.ParseIP("172.16.0.1")}
   120  
   121  	hosts := []net.Addr{}
   122  	var host net.Addr
   123  	var err error
   124  
   125  	defer func() {
   126  		for _, val := range hosts {
   127  			Unmap(val)
   128  		}
   129  	}()
   130  
   131  	for i := 0; i < 10; i++ {
   132  		for i := portallocator.BeginPortRange; i < portallocator.EndPortRange; i++ {
   133  			if host, err = Map(srcAddr1, dstIp1, 0); err != nil {
   134  				t.Fatal(err)
   135  			}
   136  
   137  			hosts = append(hosts, host)
   138  		}
   139  
   140  		if _, err := Map(srcAddr1, dstIp1, portallocator.BeginPortRange); err == nil {
   141  			t.Fatalf("Port %d should be bound but is not", portallocator.BeginPortRange)
   142  		}
   143  
   144  		for _, val := range hosts {
   145  			if err := Unmap(val); err != nil {
   146  				t.Fatal(err)
   147  			}
   148  		}
   149  
   150  		hosts = []net.Addr{}
   151  	}
   152  }