client/container_wait_test.go
7c36a1af
 package client
 
 import (
 	"bytes"
 	"encoding/json"
 	"fmt"
 	"io/ioutil"
 	"log"
 	"net/http"
 	"strings"
 	"testing"
 	"time"
 
181562c2
 	"github.com/docker/docker/api/types/container"
7c36a1af
 
 	"golang.org/x/net/context"
 )
 
 func TestContainerWaitError(t *testing.T) {
 	client := &Client{
9a072adf
 		client: newMockClient(errorMock(http.StatusInternalServerError, "Server error")),
7c36a1af
 	}
49211715
 	resultC, errC := client.ContainerWait(context.Background(), "nothing", "")
 	select {
 	case result := <-resultC:
 		t.Fatalf("expected to not get a wait result, got %d", result.StatusCode)
 	case err := <-errC:
 		if err.Error() != "Error response from daemon: Server error" {
 			t.Fatalf("expected a Server Error, got %v", err)
 		}
7c36a1af
 	}
 }
 
 func TestContainerWait(t *testing.T) {
 	expectedURL := "/containers/container_id/wait"
 	client := &Client{
9a072adf
 		client: newMockClient(func(req *http.Request) (*http.Response, error) {
7c36a1af
 			if !strings.HasPrefix(req.URL.Path, expectedURL) {
 				return nil, fmt.Errorf("Expected URL '%s', got '%s'", expectedURL, req.URL)
 			}
181562c2
 			b, err := json.Marshal(container.ContainerWaitOKBody{
7c36a1af
 				StatusCode: 15,
 			})
 			if err != nil {
 				return nil, err
 			}
 			return &http.Response{
 				StatusCode: http.StatusOK,
 				Body:       ioutil.NopCloser(bytes.NewReader(b)),
 			}, nil
 		}),
 	}
 
49211715
 	resultC, errC := client.ContainerWait(context.Background(), "container_id", "")
 	select {
 	case err := <-errC:
7c36a1af
 		t.Fatal(err)
49211715
 	case result := <-resultC:
 		if result.StatusCode != 15 {
 			t.Fatalf("expected a status code equal to '15', got %d", result.StatusCode)
 		}
7c36a1af
 	}
 }
 
 func ExampleClient_ContainerWait_withTimeout() {
 	ctx, cancel := context.WithTimeout(context.Background(), 5*time.Second)
 	defer cancel()
 
 	client, _ := NewEnvClient()
49211715
 	_, errC := client.ContainerWait(ctx, "container_id", "")
 	if err := <-errC; err != nil {
7c36a1af
 		log.Fatal(err)
 	}
 }