2015-04-26 03:19:01 -04:00
|
|
|
package client
|
|
|
|
|
|
|
|
import (
|
|
|
|
"bytes"
|
2015-05-21 06:58:30 -04:00
|
|
|
"encoding/json"
|
2015-05-22 10:54:23 -04:00
|
|
|
"fmt"
|
2015-04-26 03:19:01 -04:00
|
|
|
"io"
|
2015-05-21 06:58:30 -04:00
|
|
|
"os"
|
|
|
|
"strings"
|
2015-04-26 03:19:01 -04:00
|
|
|
"testing"
|
2015-05-12 19:39:30 -04:00
|
|
|
|
|
|
|
_ "github.com/docker/libnetwork/netutils"
|
2015-04-26 03:19:01 -04:00
|
|
|
)
|
|
|
|
|
|
|
|
// nopCloser is used to provide a dummy CallFunc for Cmd()
|
|
|
|
type nopCloser struct {
|
|
|
|
io.Reader
|
|
|
|
}
|
|
|
|
|
|
|
|
func (nopCloser) Close() error { return nil }
|
|
|
|
|
2015-05-21 06:58:30 -04:00
|
|
|
func TestMain(m *testing.M) {
|
|
|
|
setupMockHTTPCallback()
|
|
|
|
os.Exit(m.Run())
|
|
|
|
}
|
|
|
|
|
|
|
|
var callbackFunc func(method, path string, data interface{}, headers map[string][]string) (io.ReadCloser, int, error)
|
2015-05-22 10:54:23 -04:00
|
|
|
var mockNwJSON, mockNwListJSON, mockServiceJSON, mockServiceListJSON []byte
|
2015-05-21 06:58:30 -04:00
|
|
|
var mockNwName = "test"
|
|
|
|
var mockNwID = "23456789"
|
2015-05-22 10:54:23 -04:00
|
|
|
var mockServiceName = "testSrv"
|
|
|
|
var mockServiceID = "23456789"
|
|
|
|
var mockContainerID = "23456789"
|
2015-05-21 06:58:30 -04:00
|
|
|
|
|
|
|
func setupMockHTTPCallback() {
|
|
|
|
var list []networkResource
|
|
|
|
nw := networkResource{Name: mockNwName, ID: mockNwID}
|
|
|
|
mockNwJSON, _ = json.Marshal(nw)
|
|
|
|
list = append(list, nw)
|
|
|
|
mockNwListJSON, _ = json.Marshal(list)
|
2015-05-22 10:54:23 -04:00
|
|
|
|
|
|
|
var srvList []endpointResource
|
|
|
|
ep := endpointResource{Name: mockServiceName, ID: mockServiceID, Network: mockNwName}
|
|
|
|
mockServiceJSON, _ = json.Marshal(ep)
|
|
|
|
srvList = append(srvList, ep)
|
|
|
|
mockServiceListJSON, _ = json.Marshal(srvList)
|
|
|
|
|
2015-05-21 06:58:30 -04:00
|
|
|
callbackFunc = func(method, path string, data interface{}, headers map[string][]string) (io.ReadCloser, int, error) {
|
|
|
|
var rsp string
|
|
|
|
switch method {
|
|
|
|
case "GET":
|
2015-05-22 10:54:23 -04:00
|
|
|
if strings.Contains(path, fmt.Sprintf("networks?name=%s", mockNwName)) {
|
|
|
|
rsp = string(mockNwListJSON)
|
|
|
|
} else if strings.Contains(path, "networks?name=") {
|
|
|
|
rsp = "[]"
|
|
|
|
} else if strings.Contains(path, fmt.Sprintf("networks?partial-id=%s", mockNwID)) {
|
2015-05-21 06:58:30 -04:00
|
|
|
rsp = string(mockNwListJSON)
|
2015-05-22 10:54:23 -04:00
|
|
|
} else if strings.Contains(path, "networks?partial-id=") {
|
|
|
|
rsp = "[]"
|
2015-05-21 06:58:30 -04:00
|
|
|
} else if strings.HasSuffix(path, "networks") {
|
|
|
|
rsp = string(mockNwListJSON)
|
|
|
|
} else if strings.HasSuffix(path, "networks/"+mockNwID) {
|
|
|
|
rsp = string(mockNwJSON)
|
2015-05-22 10:54:23 -04:00
|
|
|
} else if strings.Contains(path, fmt.Sprintf("endpoints?name=%s", mockServiceName)) {
|
|
|
|
rsp = string(mockServiceListJSON)
|
|
|
|
} else if strings.Contains(path, "endpoints?name=") {
|
|
|
|
rsp = "[]"
|
|
|
|
} else if strings.Contains(path, fmt.Sprintf("endpoints?partial-id=%s", mockServiceID)) {
|
|
|
|
rsp = string(mockServiceListJSON)
|
|
|
|
} else if strings.Contains(path, "endpoints?partial-id=") {
|
|
|
|
rsp = "[]"
|
|
|
|
} else if strings.HasSuffix(path, "endpoints") {
|
|
|
|
rsp = string(mockServiceListJSON)
|
|
|
|
} else if strings.HasSuffix(path, "endpoints/"+mockServiceID) {
|
|
|
|
rsp = string(mockServiceJSON)
|
2015-05-21 06:58:30 -04:00
|
|
|
}
|
|
|
|
case "POST":
|
2015-05-22 10:54:23 -04:00
|
|
|
if strings.HasSuffix(path, "networks") {
|
|
|
|
rsp = mockNwID
|
|
|
|
} else if strings.HasSuffix(path, "endpoints") {
|
|
|
|
rsp = mockServiceID
|
|
|
|
} else if strings.HasSuffix(path, "containers") {
|
|
|
|
rsp = mockContainerID
|
|
|
|
}
|
2015-05-21 06:58:30 -04:00
|
|
|
case "PUT":
|
|
|
|
case "DELETE":
|
|
|
|
rsp = ""
|
|
|
|
}
|
|
|
|
return nopCloser{bytes.NewBufferString(rsp)}, 200, nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-04-26 03:19:01 -04:00
|
|
|
func TestClientDummyCommand(t *testing.T) {
|
|
|
|
var out, errOut bytes.Buffer
|
2015-05-21 06:58:30 -04:00
|
|
|
cli := NewNetworkCli(&out, &errOut, callbackFunc)
|
2015-04-26 03:19:01 -04:00
|
|
|
|
|
|
|
err := cli.Cmd("docker", "dummy")
|
|
|
|
if err == nil {
|
|
|
|
t.Fatalf("Incorrect Command must fail")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-05-17 10:07:09 -04:00
|
|
|
func TestClientNetworkInvalidCommand(t *testing.T) {
|
2015-04-26 03:19:01 -04:00
|
|
|
var out, errOut bytes.Buffer
|
2015-05-21 06:58:30 -04:00
|
|
|
cli := NewNetworkCli(&out, &errOut, callbackFunc)
|
2015-04-26 03:19:01 -04:00
|
|
|
|
2015-05-17 10:07:09 -04:00
|
|
|
err := cli.Cmd("docker", "network", "invalid")
|
2015-04-26 03:19:01 -04:00
|
|
|
if err == nil {
|
2015-05-17 10:07:09 -04:00
|
|
|
t.Fatalf("Passing invalid commands must fail")
|
2015-04-26 03:19:01 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestClientNetworkCreate(t *testing.T) {
|
|
|
|
var out, errOut bytes.Buffer
|
2015-05-21 06:58:30 -04:00
|
|
|
cli := NewNetworkCli(&out, &errOut, callbackFunc)
|
2015-04-26 03:19:01 -04:00
|
|
|
|
2015-05-21 06:58:30 -04:00
|
|
|
err := cli.Cmd("docker", "network", "create", mockNwName)
|
2015-04-26 03:19:01 -04:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err.Error())
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestClientNetworkCreateWithDriver(t *testing.T) {
|
|
|
|
var out, errOut bytes.Buffer
|
2015-05-21 06:58:30 -04:00
|
|
|
cli := NewNetworkCli(&out, &errOut, callbackFunc)
|
2015-04-26 03:19:01 -04:00
|
|
|
|
2015-05-21 06:58:30 -04:00
|
|
|
err := cli.Cmd("docker", "network", "create", "-f=dummy", mockNwName)
|
2015-04-26 03:19:01 -04:00
|
|
|
if err == nil {
|
|
|
|
t.Fatalf("Passing incorrect flags to the create command must fail")
|
|
|
|
}
|
|
|
|
|
2015-05-21 06:58:30 -04:00
|
|
|
err = cli.Cmd("docker", "network", "create", "-d=dummy", mockNwName)
|
2015-04-26 03:19:01 -04:00
|
|
|
if err != nil {
|
|
|
|
t.Fatalf(err.Error())
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestClientNetworkRm(t *testing.T) {
|
|
|
|
var out, errOut bytes.Buffer
|
2015-05-21 06:58:30 -04:00
|
|
|
cli := NewNetworkCli(&out, &errOut, callbackFunc)
|
2015-04-26 03:19:01 -04:00
|
|
|
|
2015-05-21 06:58:30 -04:00
|
|
|
err := cli.Cmd("docker", "network", "rm", mockNwName)
|
2015-04-26 03:19:01 -04:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err.Error())
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestClientNetworkLs(t *testing.T) {
|
|
|
|
var out, errOut bytes.Buffer
|
2015-05-21 06:58:30 -04:00
|
|
|
cli := NewNetworkCli(&out, &errOut, callbackFunc)
|
2015-04-26 03:19:01 -04:00
|
|
|
|
|
|
|
err := cli.Cmd("docker", "network", "ls")
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err.Error())
|
|
|
|
}
|
2015-05-21 06:58:30 -04:00
|
|
|
if out.String() != string(mockNwListJSON) {
|
|
|
|
t.Fatal("Network List command fail to return the expected list")
|
2015-04-26 03:19:01 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestClientNetworkInfo(t *testing.T) {
|
|
|
|
var out, errOut bytes.Buffer
|
2015-05-21 06:58:30 -04:00
|
|
|
cli := NewNetworkCli(&out, &errOut, callbackFunc)
|
|
|
|
|
|
|
|
err := cli.Cmd("docker", "network", "info", mockNwName)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err.Error())
|
|
|
|
}
|
|
|
|
if out.String() != string(mockNwJSON) {
|
|
|
|
t.Fatal("Network info command fail to return the expected object")
|
2015-04-26 03:19:01 -04:00
|
|
|
}
|
2015-05-21 06:58:30 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
func TestClientNetworkInfoById(t *testing.T) {
|
|
|
|
var out, errOut bytes.Buffer
|
|
|
|
cli := NewNetworkCli(&out, &errOut, callbackFunc)
|
2015-04-26 03:19:01 -04:00
|
|
|
|
2015-05-21 06:58:30 -04:00
|
|
|
err := cli.Cmd("docker", "network", "info", mockNwID)
|
2015-04-26 03:19:01 -04:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err.Error())
|
|
|
|
}
|
2015-05-21 06:58:30 -04:00
|
|
|
if out.String() != string(mockNwJSON) {
|
|
|
|
t.Fatal("Network info command fail to return the expected object")
|
2015-04-26 03:19:01 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-05-22 10:54:23 -04:00
|
|
|
func TestClientNetworkServiceInvalidCommand(t *testing.T) {
|
|
|
|
var out, errOut bytes.Buffer
|
|
|
|
cli := NewNetworkCli(&out, &errOut, callbackFunc)
|
|
|
|
|
|
|
|
err := cli.Cmd("docker", "network", "service", "invalid")
|
|
|
|
if err == nil {
|
|
|
|
t.Fatalf("Passing invalid commands must fail")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestClientNetworkServiceCreate(t *testing.T) {
|
|
|
|
var out, errOut bytes.Buffer
|
|
|
|
cli := NewNetworkCli(&out, &errOut, callbackFunc)
|
|
|
|
|
|
|
|
err := cli.Cmd("docker", "network", "service", "create", mockServiceName, mockNwName)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err.Error())
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestClientNetworkServiceRm(t *testing.T) {
|
|
|
|
var out, errOut bytes.Buffer
|
|
|
|
cli := NewNetworkCli(&out, &errOut, callbackFunc)
|
|
|
|
|
|
|
|
err := cli.Cmd("docker", "network", "service", "rm", mockServiceName, mockNwName)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err.Error())
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestClientNetworkServiceLs(t *testing.T) {
|
|
|
|
var out, errOut bytes.Buffer
|
|
|
|
cli := NewNetworkCli(&out, &errOut, callbackFunc)
|
|
|
|
|
|
|
|
err := cli.Cmd("docker", "network", "service", "ls", mockNwName)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err.Error())
|
|
|
|
}
|
|
|
|
if out.String() != string(mockServiceListJSON) {
|
|
|
|
t.Fatal("Network service ls command fail to return the expected list")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestClientNetworkServiceInfo(t *testing.T) {
|
|
|
|
var out, errOut bytes.Buffer
|
|
|
|
cli := NewNetworkCli(&out, &errOut, callbackFunc)
|
|
|
|
|
|
|
|
err := cli.Cmd("docker", "network", "service", "info", mockServiceName, mockNwName)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err.Error())
|
|
|
|
}
|
|
|
|
if out.String() != string(mockServiceJSON) {
|
|
|
|
t.Fatal("Network info command fail to return the expected object")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestClientNetworkServiceInfoById(t *testing.T) {
|
|
|
|
var out, errOut bytes.Buffer
|
|
|
|
cli := NewNetworkCli(&out, &errOut, callbackFunc)
|
|
|
|
|
|
|
|
err := cli.Cmd("docker", "network", "service", "info", mockServiceID, mockNwID)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err.Error())
|
|
|
|
}
|
|
|
|
if out.String() != string(mockServiceJSON) {
|
|
|
|
t.Fatal("Network info command fail to return the expected object")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestClientNetworkServiceJoin(t *testing.T) {
|
|
|
|
var out, errOut bytes.Buffer
|
|
|
|
cli := NewNetworkCli(&out, &errOut, callbackFunc)
|
|
|
|
|
|
|
|
err := cli.Cmd("docker", "network", "service", "join", mockContainerID, mockServiceName, mockNwName)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err.Error())
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestClientNetworkServiceLeave(t *testing.T) {
|
|
|
|
var out, errOut bytes.Buffer
|
|
|
|
cli := NewNetworkCli(&out, &errOut, callbackFunc)
|
|
|
|
|
|
|
|
err := cli.Cmd("docker", "network", "service", "leave", mockContainerID, mockServiceName, mockNwName)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err.Error())
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-05-17 10:07:09 -04:00
|
|
|
// Docker Flag processing in flag.go uses os.Exit() frequently, even for --help
|
2015-04-26 03:19:01 -04:00
|
|
|
// TODO : Handle the --help test-case in the IT when CLI is available
|
|
|
|
/*
|
2015-05-22 10:54:23 -04:00
|
|
|
func TestClientNetworkServiceCreateHelp(t *testing.T) {
|
2015-04-26 03:19:01 -04:00
|
|
|
var out, errOut bytes.Buffer
|
|
|
|
cFunc := func(method, path string, data interface{}, headers map[string][]string) (io.ReadCloser, int, error) {
|
|
|
|
return nil, 0, nil
|
|
|
|
}
|
2015-05-21 06:58:30 -04:00
|
|
|
cli := NewNetworkCli(&out, &errOut, callbackFunc)
|
2015-04-26 03:19:01 -04:00
|
|
|
|
|
|
|
err := cli.Cmd("docker", "network", "create", "--help")
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf(err.Error())
|
|
|
|
}
|
|
|
|
}
|
|
|
|
*/
|
|
|
|
|
2015-05-04 05:54:19 -04:00
|
|
|
// Docker flag processing in flag.go uses os.Exit(1) for incorrect parameter case.
|
2015-04-26 03:19:01 -04:00
|
|
|
// TODO : Handle the missing argument case in the IT when CLI is available
|
|
|
|
/*
|
2015-05-22 10:54:23 -04:00
|
|
|
func TestClientNetworkServiceCreateMissingArgument(t *testing.T) {
|
2015-04-26 03:19:01 -04:00
|
|
|
var out, errOut bytes.Buffer
|
|
|
|
cFunc := func(method, path string, data interface{}, headers map[string][]string) (io.ReadCloser, int, error) {
|
|
|
|
return nil, 0, nil
|
|
|
|
}
|
2015-05-21 06:58:30 -04:00
|
|
|
cli := NewNetworkCli(&out, &errOut, callbackFunc)
|
2015-04-26 03:19:01 -04:00
|
|
|
|
|
|
|
err := cli.Cmd("docker", "network", "create")
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err.Error())
|
|
|
|
}
|
|
|
|
}
|
|
|
|
*/
|