2013-11-14 10:08:08 +04:00
|
|
|
package docker
|
|
|
|
|
|
|
|
import (
|
2014-02-12 04:48:44 +04:00
|
|
|
"github.com/dotcloud/docker/nat"
|
2013-11-14 10:08:08 +04:00
|
|
|
"testing"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestParseNetworkOptsPrivateOnly(t *testing.T) {
|
2014-02-12 04:48:44 +04:00
|
|
|
ports, bindings, err := nat.ParsePortSpecs([]string{"192.168.1.100::80"})
|
2013-11-14 10:08:08 +04:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
if len(ports) != 1 {
|
|
|
|
t.Logf("Expected 1 got %d", len(ports))
|
|
|
|
t.FailNow()
|
|
|
|
}
|
|
|
|
if len(bindings) != 1 {
|
|
|
|
t.Logf("Expected 1 got %d", len(bindings))
|
|
|
|
t.FailNow()
|
|
|
|
}
|
|
|
|
for k := range ports {
|
|
|
|
if k.Proto() != "tcp" {
|
|
|
|
t.Logf("Expected tcp got %s", k.Proto())
|
|
|
|
t.Fail()
|
|
|
|
}
|
|
|
|
if k.Port() != "80" {
|
|
|
|
t.Logf("Expected 80 got %s", k.Port())
|
|
|
|
t.Fail()
|
|
|
|
}
|
|
|
|
b, exists := bindings[k]
|
|
|
|
if !exists {
|
|
|
|
t.Log("Binding does not exist")
|
|
|
|
t.FailNow()
|
|
|
|
}
|
|
|
|
if len(b) != 1 {
|
|
|
|
t.Logf("Expected 1 got %d", len(b))
|
|
|
|
t.FailNow()
|
|
|
|
}
|
|
|
|
s := b[0]
|
|
|
|
if s.HostPort != "" {
|
|
|
|
t.Logf("Expected \"\" got %s", s.HostPort)
|
|
|
|
t.Fail()
|
|
|
|
}
|
|
|
|
if s.HostIp != "192.168.1.100" {
|
|
|
|
t.Fail()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestParseNetworkOptsPublic(t *testing.T) {
|
2014-02-12 04:48:44 +04:00
|
|
|
ports, bindings, err := nat.ParsePortSpecs([]string{"192.168.1.100:8080:80"})
|
2013-11-14 10:08:08 +04:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
if len(ports) != 1 {
|
|
|
|
t.Logf("Expected 1 got %d", len(ports))
|
|
|
|
t.FailNow()
|
|
|
|
}
|
|
|
|
if len(bindings) != 1 {
|
|
|
|
t.Logf("Expected 1 got %d", len(bindings))
|
|
|
|
t.FailNow()
|
|
|
|
}
|
|
|
|
for k := range ports {
|
|
|
|
if k.Proto() != "tcp" {
|
|
|
|
t.Logf("Expected tcp got %s", k.Proto())
|
|
|
|
t.Fail()
|
|
|
|
}
|
|
|
|
if k.Port() != "80" {
|
|
|
|
t.Logf("Expected 80 got %s", k.Port())
|
|
|
|
t.Fail()
|
|
|
|
}
|
|
|
|
b, exists := bindings[k]
|
|
|
|
if !exists {
|
|
|
|
t.Log("Binding does not exist")
|
|
|
|
t.FailNow()
|
|
|
|
}
|
|
|
|
if len(b) != 1 {
|
|
|
|
t.Logf("Expected 1 got %d", len(b))
|
|
|
|
t.FailNow()
|
|
|
|
}
|
|
|
|
s := b[0]
|
|
|
|
if s.HostPort != "8080" {
|
|
|
|
t.Logf("Expected 8080 got %s", s.HostPort)
|
|
|
|
t.Fail()
|
|
|
|
}
|
|
|
|
if s.HostIp != "192.168.1.100" {
|
|
|
|
t.Fail()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestParseNetworkOptsUdp(t *testing.T) {
|
2014-02-12 04:48:44 +04:00
|
|
|
ports, bindings, err := nat.ParsePortSpecs([]string{"192.168.1.100::6000/udp"})
|
2013-11-14 10:08:08 +04:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
if len(ports) != 1 {
|
|
|
|
t.Logf("Expected 1 got %d", len(ports))
|
|
|
|
t.FailNow()
|
|
|
|
}
|
|
|
|
if len(bindings) != 1 {
|
|
|
|
t.Logf("Expected 1 got %d", len(bindings))
|
|
|
|
t.FailNow()
|
|
|
|
}
|
|
|
|
for k := range ports {
|
|
|
|
if k.Proto() != "udp" {
|
|
|
|
t.Logf("Expected udp got %s", k.Proto())
|
|
|
|
t.Fail()
|
|
|
|
}
|
|
|
|
if k.Port() != "6000" {
|
|
|
|
t.Logf("Expected 6000 got %s", k.Port())
|
|
|
|
t.Fail()
|
|
|
|
}
|
|
|
|
b, exists := bindings[k]
|
|
|
|
if !exists {
|
|
|
|
t.Log("Binding does not exist")
|
|
|
|
t.FailNow()
|
|
|
|
}
|
|
|
|
if len(b) != 1 {
|
|
|
|
t.Logf("Expected 1 got %d", len(b))
|
|
|
|
t.FailNow()
|
|
|
|
}
|
|
|
|
s := b[0]
|
|
|
|
if s.HostPort != "" {
|
|
|
|
t.Logf("Expected \"\" got %s", s.HostPort)
|
|
|
|
t.Fail()
|
|
|
|
}
|
|
|
|
if s.HostIp != "192.168.1.100" {
|
|
|
|
t.Fail()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestGetFullName(t *testing.T) {
|
|
|
|
name, err := getFullName("testing")
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
if name != "/testing" {
|
|
|
|
t.Fatalf("Expected /testing got %s", name)
|
|
|
|
}
|
|
|
|
if _, err := getFullName(""); err == nil {
|
|
|
|
t.Fatal("Error should not be nil")
|
|
|
|
}
|
|
|
|
}
|