123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123 |
- package client
- import (
- "bytes"
- "encoding/json"
- "fmt"
- "io"
- "io/ioutil"
- "net/http"
- "strings"
- "testing"
- "github.com/docker/docker/api/types"
- registrytypes "github.com/docker/docker/api/types/registry"
- "github.com/docker/docker/api/types/swarm"
- "github.com/opencontainers/image-spec/specs-go/v1"
- "golang.org/x/net/context"
- )
- func TestServiceCreateError(t *testing.T) {
- client := &Client{
- client: newMockClient(errorMock(http.StatusInternalServerError, "Server error")),
- }
- _, err := client.ServiceCreate(context.Background(), swarm.ServiceSpec{}, types.ServiceCreateOptions{})
- if err == nil || err.Error() != "Error response from daemon: Server error" {
- t.Fatalf("expected a Server Error, got %v", err)
- }
- }
- func TestServiceCreate(t *testing.T) {
- expectedURL := "/services/create"
- client := &Client{
- client: newMockClient(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)
- }
- b, err := json.Marshal(types.ServiceCreateResponse{
- ID: "service_id",
- })
- if err != nil {
- return nil, err
- }
- return &http.Response{
- StatusCode: http.StatusOK,
- Body: ioutil.NopCloser(bytes.NewReader(b)),
- }, nil
- }),
- }
- r, err := client.ServiceCreate(context.Background(), swarm.ServiceSpec{}, types.ServiceCreateOptions{})
- if err != nil {
- t.Fatal(err)
- }
- if r.ID != "service_id" {
- t.Fatalf("expected `service_id`, got %s", r.ID)
- }
- }
- func TestServiceCreateCompatiblePlatforms(t *testing.T) {
- var (
- platforms []v1.Platform
- distributionInspectBody io.ReadCloser
- distributionInspect registrytypes.DistributionInspect
- )
- client := &Client{
- client: newMockClient(func(req *http.Request) (*http.Response, error) {
- if strings.HasPrefix(req.URL.Path, "/services/create") {
- // check if the /distribution endpoint returned correct output
- err := json.NewDecoder(distributionInspectBody).Decode(&distributionInspect)
- if err != nil {
- return nil, err
- }
- if len(distributionInspect.Platforms) == 0 || distributionInspect.Platforms[0].Architecture != platforms[0].Architecture || distributionInspect.Platforms[0].OS != platforms[0].OS {
- return nil, fmt.Errorf("received incorrect platform information from registry")
- }
- b, err := json.Marshal(types.ServiceCreateResponse{
- ID: "service_" + platforms[0].Architecture,
- })
- if err != nil {
- return nil, err
- }
- return &http.Response{
- StatusCode: http.StatusOK,
- Body: ioutil.NopCloser(bytes.NewReader(b)),
- }, nil
- } else if strings.HasPrefix(req.URL.Path, "/distribution/") {
- platforms = []v1.Platform{
- {
- Architecture: "amd64",
- OS: "linux",
- },
- }
- b, err := json.Marshal(registrytypes.DistributionInspect{
- Descriptor: v1.Descriptor{},
- Platforms: platforms,
- })
- if err != nil {
- return nil, err
- }
- distributionInspectBody = ioutil.NopCloser(bytes.NewReader(b))
- return &http.Response{
- StatusCode: http.StatusOK,
- Body: ioutil.NopCloser(bytes.NewReader(b)),
- }, nil
- } else {
- return nil, fmt.Errorf("unexpected URL '%s'", req.URL.Path)
- }
- }),
- }
- r, err := client.ServiceCreate(context.Background(), swarm.ServiceSpec{}, types.ServiceCreateOptions{QueryRegistry: true})
- if err != nil {
- t.Fatal(err)
- }
- if r.ID != "service_amd64" {
- t.Fatalf("expected `service_amd64`, got %s", r.ID)
- }
- }
|