Add Docker task list test

Signed-off-by: Emile Vauge <emile@vauge.com>
This commit is contained in:
Emile Vauge 2017-03-20 12:12:25 +01:00
parent 5c2d91ab84
commit a456d36cc6
No known key found for this signature in database
GPG key ID: D808B4C167352E59

View file

@ -6,11 +6,15 @@ import (
"testing" "testing"
"github.com/containous/traefik/types" "github.com/containous/traefik/types"
"github.com/davecgh/go-spew/spew"
dockerclient "github.com/docker/engine-api/client"
docker "github.com/docker/engine-api/types" docker "github.com/docker/engine-api/types"
dockertypes "github.com/docker/engine-api/types"
"github.com/docker/engine-api/types/container" "github.com/docker/engine-api/types/container"
"github.com/docker/engine-api/types/network" "github.com/docker/engine-api/types/network"
"github.com/docker/engine-api/types/swarm" "github.com/docker/engine-api/types/swarm"
"github.com/docker/go-connections/nat" "github.com/docker/go-connections/nat"
"golang.org/x/net/context"
) )
func TestDockerGetFrontendName(t *testing.T) { func TestDockerGetFrontendName(t *testing.T) {
@ -2230,7 +2234,7 @@ func TestSwarmTaskParsing(t *testing.T) {
cases := []struct { cases := []struct {
service swarm.Service service swarm.Service
tasks []swarm.Task tasks []swarm.Task
isGlobalSvc bool isGlobalSVC bool
expectedNames map[string]string expectedNames map[string]string
networks map[string]*docker.NetworkResource networks map[string]*docker.NetworkResource
}{ }{
@ -2256,7 +2260,7 @@ func TestSwarmTaskParsing(t *testing.T) {
Slot: 3, Slot: 3,
}, },
}, },
isGlobalSvc: false, isGlobalSVC: false,
expectedNames: map[string]string{ expectedNames: map[string]string{
"id1": "container.1", "id1": "container.1",
"id2": "container.2", "id2": "container.2",
@ -2287,7 +2291,7 @@ func TestSwarmTaskParsing(t *testing.T) {
ID: "id3", ID: "id3",
}, },
}, },
isGlobalSvc: true, isGlobalSVC: true,
expectedNames: map[string]string{ expectedNames: map[string]string{
"id1": "container.id1", "id1": "container.id1",
"id2": "container.id2", "id2": "container.id2",
@ -2305,7 +2309,7 @@ func TestSwarmTaskParsing(t *testing.T) {
dockerData := parseService(e.service, e.networks) dockerData := parseService(e.service, e.networks)
for _, task := range e.tasks { for _, task := range e.tasks {
taskDockerData := parseTasks(task, dockerData, map[string]*docker.NetworkResource{}, e.isGlobalSvc) taskDockerData := parseTasks(task, dockerData, map[string]*docker.NetworkResource{}, e.isGlobalSVC)
if !reflect.DeepEqual(taskDockerData.Name, e.expectedNames[task.ID]) { if !reflect.DeepEqual(taskDockerData.Name, e.expectedNames[task.ID]) {
t.Fatalf("expect %v, got %v", e.expectedNames[task.ID], taskDockerData.Name) t.Fatalf("expect %v, got %v", e.expectedNames[task.ID], taskDockerData.Name)
} }
@ -2313,6 +2317,96 @@ func TestSwarmTaskParsing(t *testing.T) {
} }
} }
type fakeTasksClient struct {
dockerclient.APIClient
tasks []swarm.Task
err error
}
func (c *fakeTasksClient) TaskList(ctx context.Context, options dockertypes.TaskListOptions) ([]swarm.Task, error) {
return c.tasks, c.err
}
func TestListTasks(t *testing.T) {
cases := []struct {
service swarm.Service
tasks []swarm.Task
isGlobalSVC bool
expectedTasks []string
networks map[string]*docker.NetworkResource
}{
{
service: swarm.Service{
Spec: swarm.ServiceSpec{
Annotations: swarm.Annotations{
Name: "container",
},
},
},
tasks: []swarm.Task{
{
ID: "id1",
Slot: 1,
Status: swarm.TaskStatus{
State: swarm.TaskStateRunning,
},
},
{
ID: "id2",
Slot: 2,
Status: swarm.TaskStatus{
State: swarm.TaskStatePending,
},
},
{
ID: "id3",
Slot: 3,
},
{
ID: "id4",
Slot: 4,
Status: swarm.TaskStatus{
State: swarm.TaskStateRunning,
},
},
{
ID: "id5",
Slot: 5,
Status: swarm.TaskStatus{
State: swarm.TaskStateFailed,
},
},
},
isGlobalSVC: false,
expectedTasks: []string{
"container.1",
"container.4",
},
networks: map[string]*docker.NetworkResource{
"1": {
Name: "foo",
},
},
},
}
for _, e := range cases {
dockerData := parseService(e.service, e.networks)
dockerClient := &fakeTasksClient{tasks: e.tasks}
taskDockerData, _ := listTasks(context.Background(), dockerClient, e.service.ID, dockerData, map[string]*docker.NetworkResource{}, e.isGlobalSVC)
if len(e.expectedTasks) != len(taskDockerData) {
t.Fatalf("expected tasks %v, got %v", spew.Sprint(e.expectedTasks), spew.Sprint(taskDockerData))
}
for i, taskID := range e.expectedTasks {
if taskDockerData[i].Name != taskID {
t.Fatalf("expect task id %v, got %v", taskID, taskDockerData[i].Name)
}
}
}
}
func TestDockerGetServiceProtocol(t *testing.T) { func TestDockerGetServiceProtocol(t *testing.T) {
provider := &Docker{} provider := &Docker{}