github.com/zhouyu0/docker-note@v0.0.0-20190722021225-b8d3825084db/client/secret_inspect_test.go (about)

     1  package client // import "github.com/docker/docker/client"
     2  
     3  import (
     4  	"bytes"
     5  	"context"
     6  	"encoding/json"
     7  	"fmt"
     8  	"io/ioutil"
     9  	"net/http"
    10  	"strings"
    11  	"testing"
    12  
    13  	"github.com/docker/docker/api/types/swarm"
    14  	"github.com/pkg/errors"
    15  	"gotest.tools/assert"
    16  	is "gotest.tools/assert/cmp"
    17  )
    18  
    19  func TestSecretInspectUnsupported(t *testing.T) {
    20  	client := &Client{
    21  		version: "1.24",
    22  		client:  &http.Client{},
    23  	}
    24  	_, _, err := client.SecretInspectWithRaw(context.Background(), "nothing")
    25  	assert.Check(t, is.Error(err, `"secret inspect" requires API version 1.25, but the Docker daemon API version is 1.24`))
    26  }
    27  
    28  func TestSecretInspectError(t *testing.T) {
    29  	client := &Client{
    30  		version: "1.25",
    31  		client:  newMockClient(errorMock(http.StatusInternalServerError, "Server error")),
    32  	}
    33  
    34  	_, _, err := client.SecretInspectWithRaw(context.Background(), "nothing")
    35  	if err == nil || err.Error() != "Error response from daemon: Server error" {
    36  		t.Fatalf("expected a Server Error, got %v", err)
    37  	}
    38  }
    39  
    40  func TestSecretInspectSecretNotFound(t *testing.T) {
    41  	client := &Client{
    42  		version: "1.25",
    43  		client:  newMockClient(errorMock(http.StatusNotFound, "Server error")),
    44  	}
    45  
    46  	_, _, err := client.SecretInspectWithRaw(context.Background(), "unknown")
    47  	if err == nil || !IsErrNotFound(err) {
    48  		t.Fatalf("expected a secretNotFoundError error, got %v", err)
    49  	}
    50  }
    51  
    52  func TestSecretInspectWithEmptyID(t *testing.T) {
    53  	client := &Client{
    54  		client: newMockClient(func(req *http.Request) (*http.Response, error) {
    55  			return nil, errors.New("should not make request")
    56  		}),
    57  	}
    58  	_, _, err := client.SecretInspectWithRaw(context.Background(), "")
    59  	if !IsErrNotFound(err) {
    60  		t.Fatalf("Expected NotFoundError, got %v", err)
    61  	}
    62  }
    63  
    64  func TestSecretInspect(t *testing.T) {
    65  	expectedURL := "/v1.25/secrets/secret_id"
    66  	client := &Client{
    67  		version: "1.25",
    68  		client: newMockClient(func(req *http.Request) (*http.Response, error) {
    69  			if !strings.HasPrefix(req.URL.Path, expectedURL) {
    70  				return nil, fmt.Errorf("Expected URL '%s', got '%s'", expectedURL, req.URL)
    71  			}
    72  			content, err := json.Marshal(swarm.Secret{
    73  				ID: "secret_id",
    74  			})
    75  			if err != nil {
    76  				return nil, err
    77  			}
    78  			return &http.Response{
    79  				StatusCode: http.StatusOK,
    80  				Body:       ioutil.NopCloser(bytes.NewReader(content)),
    81  			}, nil
    82  		}),
    83  	}
    84  
    85  	secretInspect, _, err := client.SecretInspectWithRaw(context.Background(), "secret_id")
    86  	if err != nil {
    87  		t.Fatal(err)
    88  	}
    89  	if secretInspect.ID != "secret_id" {
    90  		t.Fatalf("expected `secret_id`, got %s", secretInspect.ID)
    91  	}
    92  }