mirror of
				https://github.com/moby/moby.git
				synced 2022-11-09 12:21:53 -05:00 
			
		
		
		
	In file `api/types/client.go`, some of the "*Options{}" structs own a
`Filters` field while some else have the name of `Filter`, this commit
will rename all `Filter` to `Filters` for consistency. Also `Filters`
is consistent with API with format `/xxx?filters=xxx`, that's why
`Filters` is the right name.
Signed-off-by: Zhang Wei <zhangwei555@huawei.com>
		
	
			
		
			
				
	
	
		
			94 lines
		
	
	
	
		
			2.2 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			94 lines
		
	
	
	
		
			2.2 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
package client
 | 
						|
 | 
						|
import (
 | 
						|
	"bytes"
 | 
						|
	"encoding/json"
 | 
						|
	"fmt"
 | 
						|
	"io/ioutil"
 | 
						|
	"net/http"
 | 
						|
	"strings"
 | 
						|
	"testing"
 | 
						|
 | 
						|
	"github.com/docker/docker/api/types"
 | 
						|
	"github.com/docker/docker/api/types/filters"
 | 
						|
	"github.com/docker/docker/api/types/swarm"
 | 
						|
	"golang.org/x/net/context"
 | 
						|
)
 | 
						|
 | 
						|
func TestServiceListError(t *testing.T) {
 | 
						|
	client := &Client{
 | 
						|
		client: newMockClient(errorMock(http.StatusInternalServerError, "Server error")),
 | 
						|
	}
 | 
						|
 | 
						|
	_, err := client.ServiceList(context.Background(), types.ServiceListOptions{})
 | 
						|
	if err == nil || err.Error() != "Error response from daemon: Server error" {
 | 
						|
		t.Fatalf("expected a Server Error, got %v", err)
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
func TestServiceList(t *testing.T) {
 | 
						|
	expectedURL := "/services"
 | 
						|
 | 
						|
	filters := filters.NewArgs()
 | 
						|
	filters.Add("label", "label1")
 | 
						|
	filters.Add("label", "label2")
 | 
						|
 | 
						|
	listCases := []struct {
 | 
						|
		options             types.ServiceListOptions
 | 
						|
		expectedQueryParams map[string]string
 | 
						|
	}{
 | 
						|
		{
 | 
						|
			options: types.ServiceListOptions{},
 | 
						|
			expectedQueryParams: map[string]string{
 | 
						|
				"filters": "",
 | 
						|
			},
 | 
						|
		},
 | 
						|
		{
 | 
						|
			options: types.ServiceListOptions{
 | 
						|
				Filters: filters,
 | 
						|
			},
 | 
						|
			expectedQueryParams: map[string]string{
 | 
						|
				"filters": `{"label":{"label1":true,"label2":true}}`,
 | 
						|
			},
 | 
						|
		},
 | 
						|
	}
 | 
						|
	for _, listCase := range listCases {
 | 
						|
		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)
 | 
						|
				}
 | 
						|
				query := req.URL.Query()
 | 
						|
				for key, expected := range listCase.expectedQueryParams {
 | 
						|
					actual := query.Get(key)
 | 
						|
					if actual != expected {
 | 
						|
						return nil, fmt.Errorf("%s not set in URL query properly. Expected '%s', got %s", key, expected, actual)
 | 
						|
					}
 | 
						|
				}
 | 
						|
				content, err := json.Marshal([]swarm.Service{
 | 
						|
					{
 | 
						|
						ID: "service_id1",
 | 
						|
					},
 | 
						|
					{
 | 
						|
						ID: "service_id2",
 | 
						|
					},
 | 
						|
				})
 | 
						|
				if err != nil {
 | 
						|
					return nil, err
 | 
						|
				}
 | 
						|
				return &http.Response{
 | 
						|
					StatusCode: http.StatusOK,
 | 
						|
					Body:       ioutil.NopCloser(bytes.NewReader(content)),
 | 
						|
				}, nil
 | 
						|
			}),
 | 
						|
		}
 | 
						|
 | 
						|
		services, err := client.ServiceList(context.Background(), listCase.options)
 | 
						|
		if err != nil {
 | 
						|
			t.Fatal(err)
 | 
						|
		}
 | 
						|
		if len(services) != 2 {
 | 
						|
			t.Fatalf("expected 2 services, got %v", services)
 | 
						|
		}
 | 
						|
	}
 | 
						|
}
 |