mirror of
https://github.com/moby/moby.git
synced 2022-11-09 12:21:53 -05:00
cc02894a50
This way we won't vendor test related functions in docker anymore. It also moves netns related functions to a new ns package to be able to call the ns init function in tests. I think this also helps with the overall package isolation. Signed-off-by: David Calavera <david.calavera@gmail.com>
122 lines
3 KiB
Go
122 lines
3 KiB
Go
package client
|
|
|
|
import (
|
|
"bytes"
|
|
"testing"
|
|
|
|
_ "github.com/docker/libnetwork/testutils"
|
|
)
|
|
|
|
func TestClientServiceInvalidCommand(t *testing.T) {
|
|
var out, errOut bytes.Buffer
|
|
cli := NewNetworkCli(&out, &errOut, callbackFunc)
|
|
|
|
err := cli.Cmd("docker", "service", "invalid")
|
|
if err == nil {
|
|
t.Fatalf("Passing invalid commands must fail")
|
|
}
|
|
}
|
|
|
|
func TestClientServiceCreate(t *testing.T) {
|
|
var out, errOut bytes.Buffer
|
|
cli := NewNetworkCli(&out, &errOut, callbackFunc)
|
|
|
|
err := cli.Cmd("docker", "service", "publish", mockServiceName+"."+mockNwName)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
}
|
|
|
|
func TestClientServiceRm(t *testing.T) {
|
|
var out, errOut bytes.Buffer
|
|
cli := NewNetworkCli(&out, &errOut, callbackFunc)
|
|
|
|
err := cli.Cmd("docker", "service", "unpublish", mockServiceName+"."+mockNwName)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
}
|
|
|
|
func TestClientServiceLs(t *testing.T) {
|
|
var out, errOut bytes.Buffer
|
|
cli := NewNetworkCli(&out, &errOut, callbackFunc)
|
|
|
|
err := cli.Cmd("docker", "service", "ls")
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
}
|
|
|
|
func TestClientServiceInfo(t *testing.T) {
|
|
var out, errOut bytes.Buffer
|
|
cli := NewNetworkCli(&out, &errOut, callbackFunc)
|
|
|
|
err := cli.Cmd("docker", "service", "info", mockServiceName+"."+mockNwName)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
}
|
|
|
|
func TestClientServiceInfoById(t *testing.T) {
|
|
var out, errOut bytes.Buffer
|
|
cli := NewNetworkCli(&out, &errOut, callbackFunc)
|
|
|
|
err := cli.Cmd("docker", "service", "info", mockServiceID+"."+mockNwName)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
}
|
|
|
|
func TestClientServiceJoin(t *testing.T) {
|
|
var out, errOut bytes.Buffer
|
|
cli := NewNetworkCli(&out, &errOut, callbackFunc)
|
|
|
|
err := cli.Cmd("docker", "service", "attach", mockContainerID, mockServiceName+"."+mockNwName)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
}
|
|
|
|
func TestClientServiceLeave(t *testing.T) {
|
|
var out, errOut bytes.Buffer
|
|
cli := NewNetworkCli(&out, &errOut, callbackFunc)
|
|
|
|
err := cli.Cmd("docker", "service", "detach", mockContainerID, mockServiceName+"."+mockNwName)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
}
|
|
|
|
// Docker Flag processing in flag.go uses os.Exit() frequently, even for --help
|
|
// TODO : Handle the --help test-case in the IT when CLI is available
|
|
/*
|
|
func TestClientNetworkServiceCreateHelp(t *testing.T) {
|
|
var out, errOut bytes.Buffer
|
|
cFunc := func(method, path string, data interface{}, headers map[string][]string) (io.ReadCloser, int, error) {
|
|
return nil, 0, nil
|
|
}
|
|
cli := NewNetworkCli(&out, &errOut, callbackFunc)
|
|
|
|
err := cli.Cmd("docker", "network", "create", "--help")
|
|
if err != nil {
|
|
t.Fatalf(err.Error())
|
|
}
|
|
}
|
|
*/
|
|
|
|
// Docker flag processing in flag.go uses os.Exit(1) for incorrect parameter case.
|
|
// TODO : Handle the missing argument case in the IT when CLI is available
|
|
/*
|
|
func TestClientNetworkServiceCreateMissingArgument(t *testing.T) {
|
|
var out, errOut bytes.Buffer
|
|
cFunc := func(method, path string, data interface{}, headers map[string][]string) (io.ReadCloser, int, error) {
|
|
return nil, 0, nil
|
|
}
|
|
cli := NewNetworkCli(&out, &errOut, callbackFunc)
|
|
|
|
err := cli.Cmd("docker", "network", "create")
|
|
if err != nil {
|
|
t.Fatal(err.Error())
|
|
}
|
|
}
|
|
*/
|