summaryrefslogtreecommitdiff
path: root/client/network_connect_test.go
diff options
context:
space:
mode:
authorMichael Crosby <crosbymichael@gmail.com>2016-09-06 11:46:37 -0700
committerMichael Crosby <crosbymichael@gmail.com>2016-09-07 11:05:58 -0700
commit7c36a1af031b510cd990cf488ee5998a3efb450f (patch)
tree477f7c37b71fbc6dc641d7b294b68e17d6c869ec /client/network_connect_test.go
parent91e197d614547f0202e6ae9b8a24d88ee131d950 (diff)
downloaddocker-7c36a1af031b510cd990cf488ee5998a3efb450f.tar.gz
Move engine-api client package
This moves the engine-api client package to `/docker/docker/client`. Signed-off-by: Michael Crosby <crosbymichael@gmail.com>
Diffstat (limited to 'client/network_connect_test.go')
-rw-r--r--client/network_connect_test.go107
1 files changed, 107 insertions, 0 deletions
diff --git a/client/network_connect_test.go b/client/network_connect_test.go
new file mode 100644
index 0000000000..95b149e685
--- /dev/null
+++ b/client/network_connect_test.go
@@ -0,0 +1,107 @@
+package client
+
+import (
+ "bytes"
+ "encoding/json"
+ "fmt"
+ "io/ioutil"
+ "net/http"
+ "strings"
+ "testing"
+
+ "golang.org/x/net/context"
+
+ "github.com/docker/docker/api/types"
+ "github.com/docker/docker/api/types/network"
+)
+
+func TestNetworkConnectError(t *testing.T) {
+ client := &Client{
+ transport: newMockClient(nil, errorMock(http.StatusInternalServerError, "Server error")),
+ }
+
+ err := client.NetworkConnect(context.Background(), "network_id", "container_id", nil)
+ if err == nil || err.Error() != "Error response from daemon: Server error" {
+ t.Fatalf("expected a Server Error, got %v", err)
+ }
+}
+
+func TestNetworkConnectEmptyNilEndpointSettings(t *testing.T) {
+ expectedURL := "/networks/network_id/connect"
+
+ client := &Client{
+ transport: newMockClient(nil, func(req *http.Request) (*http.Response, error) {
+ if !strings.HasPrefix(req.URL.Path, expectedURL) {
+ return nil, fmt.Errorf("Expected URL '%s', got '%s'", expectedURL, req.URL)
+ }
+
+ if req.Method != "POST" {
+ return nil, fmt.Errorf("expected POST method, got %s", req.Method)
+ }
+
+ var connect types.NetworkConnect
+ if err := json.NewDecoder(req.Body).Decode(&connect); err != nil {
+ return nil, err
+ }
+
+ if connect.Container != "container_id" {
+ return nil, fmt.Errorf("expected 'container_id', got %s", connect.Container)
+ }
+
+ if connect.EndpointConfig != nil {
+ return nil, fmt.Errorf("expected connect.EndpointConfig to be nil, got %v", connect.EndpointConfig)
+ }
+
+ return &http.Response{
+ StatusCode: http.StatusOK,
+ Body: ioutil.NopCloser(bytes.NewReader([]byte(""))),
+ }, nil
+ }),
+ }
+
+ err := client.NetworkConnect(context.Background(), "network_id", "container_id", nil)
+ if err != nil {
+ t.Fatal(err)
+ }
+}
+
+func TestNetworkConnect(t *testing.T) {
+ expectedURL := "/networks/network_id/connect"
+
+ client := &Client{
+ transport: newMockClient(nil, func(req *http.Request) (*http.Response, error) {
+ if !strings.HasPrefix(req.URL.Path, expectedURL) {
+ return nil, fmt.Errorf("Expected URL '%s', got '%s'", expectedURL, req.URL)
+ }
+
+ if req.Method != "POST" {
+ return nil, fmt.Errorf("expected POST method, got %s", req.Method)
+ }
+
+ var connect types.NetworkConnect
+ if err := json.NewDecoder(req.Body).Decode(&connect); err != nil {
+ return nil, err
+ }
+
+ if connect.Container != "container_id" {
+ return nil, fmt.Errorf("expected 'container_id', got %s", connect.Container)
+ }
+
+ if connect.EndpointConfig.NetworkID != "NetworkID" {
+ return nil, fmt.Errorf("expected 'NetworkID', got %s", connect.EndpointConfig.NetworkID)
+ }
+
+ return &http.Response{
+ StatusCode: http.StatusOK,
+ Body: ioutil.NopCloser(bytes.NewReader([]byte(""))),
+ }, nil
+ }),
+ }
+
+ err := client.NetworkConnect(context.Background(), "network_id", "container_id", &network.EndpointSettings{
+ NetworkID: "NetworkID",
+ })
+ if err != nil {
+ t.Fatal(err)
+ }
+}