secret_inspect_test.go 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. package client
  2. import (
  3. "bytes"
  4. "encoding/json"
  5. "fmt"
  6. "io/ioutil"
  7. "net/http"
  8. "strings"
  9. "testing"
  10. "github.com/docker/docker/api/types/swarm"
  11. "github.com/stretchr/testify/assert"
  12. "golang.org/x/net/context"
  13. )
  14. func TestSecretInspectUnsupported(t *testing.T) {
  15. client := &Client{
  16. version: "1.24",
  17. client: &http.Client{},
  18. }
  19. _, _, err := client.SecretInspectWithRaw(context.Background(), "nothing")
  20. assert.EqualError(t, err, `"secret inspect" requires API version 1.25, but the Docker daemon API version is 1.24`)
  21. }
  22. func TestSecretInspectError(t *testing.T) {
  23. client := &Client{
  24. version: "1.25",
  25. client: newMockClient(errorMock(http.StatusInternalServerError, "Server error")),
  26. }
  27. _, _, err := client.SecretInspectWithRaw(context.Background(), "nothing")
  28. if err == nil || err.Error() != "Error response from daemon: Server error" {
  29. t.Fatalf("expected a Server Error, got %v", err)
  30. }
  31. }
  32. func TestSecretInspectSecretNotFound(t *testing.T) {
  33. client := &Client{
  34. version: "1.25",
  35. client: newMockClient(errorMock(http.StatusNotFound, "Server error")),
  36. }
  37. _, _, err := client.SecretInspectWithRaw(context.Background(), "unknown")
  38. if err == nil || !IsErrSecretNotFound(err) {
  39. t.Fatalf("expected a secretNotFoundError error, got %v", err)
  40. }
  41. }
  42. func TestSecretInspect(t *testing.T) {
  43. expectedURL := "/v1.25/secrets/secret_id"
  44. client := &Client{
  45. version: "1.25",
  46. client: newMockClient(func(req *http.Request) (*http.Response, error) {
  47. if !strings.HasPrefix(req.URL.Path, expectedURL) {
  48. return nil, fmt.Errorf("Expected URL '%s', got '%s'", expectedURL, req.URL)
  49. }
  50. content, err := json.Marshal(swarm.Secret{
  51. ID: "secret_id",
  52. })
  53. if err != nil {
  54. return nil, err
  55. }
  56. return &http.Response{
  57. StatusCode: http.StatusOK,
  58. Body: ioutil.NopCloser(bytes.NewReader(content)),
  59. }, nil
  60. }),
  61. }
  62. secretInspect, _, err := client.SecretInspectWithRaw(context.Background(), "secret_id")
  63. if err != nil {
  64. t.Fatal(err)
  65. }
  66. if secretInspect.ID != "secret_id" {
  67. t.Fatalf("expected `secret_id`, got %s", secretInspect.ID)
  68. }
  69. }