github.com/rita33cool1/iot-system-gateway@v0.0.0-20200911033302-e65bde238cc5/docker-engine/integration/network/inspect_test.go (about)

     1  package network // import "github.com/docker/docker/integration/network"
     2  
     3  import (
     4  	"testing"
     5  	"time"
     6  
     7  	"github.com/docker/docker/api/types"
     8  	"github.com/docker/docker/api/types/filters"
     9  	swarmtypes "github.com/docker/docker/api/types/swarm"
    10  	"github.com/docker/docker/client"
    11  	"github.com/docker/docker/integration/internal/swarm"
    12  	"github.com/gotestyourself/gotestyourself/assert"
    13  	"github.com/gotestyourself/gotestyourself/poll"
    14  	"golang.org/x/net/context"
    15  )
    16  
    17  const defaultSwarmPort = 2477
    18  
    19  func TestInspectNetwork(t *testing.T) {
    20  	defer setupTest(t)()
    21  	d := swarm.NewSwarm(t, testEnv)
    22  	defer d.Stop(t)
    23  	client := d.NewClientT(t)
    24  	defer client.Close()
    25  
    26  	overlayName := "overlay1"
    27  	networkCreate := types.NetworkCreate{
    28  		CheckDuplicate: true,
    29  		Driver:         "overlay",
    30  	}
    31  
    32  	netResp, err := client.NetworkCreate(context.Background(), overlayName, networkCreate)
    33  	assert.NilError(t, err)
    34  	overlayID := netResp.ID
    35  
    36  	var instances uint64 = 4
    37  	serviceName := "TestService"
    38  	// FIXME(vdemeester) consolidate with swarm.CreateService
    39  	serviceSpec := swarmServiceSpec(serviceName, instances)
    40  	serviceSpec.TaskTemplate.Networks = append(serviceSpec.TaskTemplate.Networks, swarmtypes.NetworkAttachmentConfig{Target: overlayName})
    41  
    42  	serviceResp, err := client.ServiceCreate(context.Background(), serviceSpec, types.ServiceCreateOptions{
    43  		QueryRegistry: false,
    44  	})
    45  	assert.NilError(t, err)
    46  
    47  	serviceID := serviceResp.ID
    48  	poll.WaitOn(t, serviceRunningTasksCount(client, serviceID, instances), swarm.ServicePoll)
    49  
    50  	_, _, err = client.ServiceInspectWithRaw(context.Background(), serviceID, types.ServiceInspectOptions{})
    51  	assert.NilError(t, err)
    52  
    53  	// Test inspect verbose with full NetworkID
    54  	networkVerbose, err := client.NetworkInspect(context.Background(), overlayID, types.NetworkInspectOptions{
    55  		Verbose: true,
    56  	})
    57  	assert.NilError(t, err)
    58  	assert.Assert(t, validNetworkVerbose(networkVerbose, serviceName, instances))
    59  
    60  	// Test inspect verbose with partial NetworkID
    61  	networkVerbose, err = client.NetworkInspect(context.Background(), overlayID[0:11], types.NetworkInspectOptions{
    62  		Verbose: true,
    63  	})
    64  	assert.NilError(t, err)
    65  	assert.Assert(t, validNetworkVerbose(networkVerbose, serviceName, instances))
    66  
    67  	// Test inspect verbose with Network name and swarm scope
    68  	networkVerbose, err = client.NetworkInspect(context.Background(), overlayName, types.NetworkInspectOptions{
    69  		Verbose: true,
    70  		Scope:   "swarm",
    71  	})
    72  	assert.NilError(t, err)
    73  	assert.Assert(t, validNetworkVerbose(networkVerbose, serviceName, instances))
    74  
    75  	err = client.ServiceRemove(context.Background(), serviceID)
    76  	assert.NilError(t, err)
    77  
    78  	poll.WaitOn(t, serviceIsRemoved(client, serviceID), swarm.ServicePoll)
    79  	poll.WaitOn(t, noTasks(client), swarm.ServicePoll)
    80  
    81  	serviceResp, err = client.ServiceCreate(context.Background(), serviceSpec, types.ServiceCreateOptions{
    82  		QueryRegistry: false,
    83  	})
    84  	assert.NilError(t, err)
    85  
    86  	serviceID2 := serviceResp.ID
    87  	poll.WaitOn(t, serviceRunningTasksCount(client, serviceID2, instances), swarm.ServicePoll)
    88  
    89  	err = client.ServiceRemove(context.Background(), serviceID2)
    90  	assert.NilError(t, err)
    91  
    92  	poll.WaitOn(t, serviceIsRemoved(client, serviceID2), swarm.ServicePoll)
    93  	poll.WaitOn(t, noTasks(client), swarm.ServicePoll)
    94  
    95  	err = client.NetworkRemove(context.Background(), overlayID)
    96  	assert.NilError(t, err)
    97  
    98  	poll.WaitOn(t, networkIsRemoved(client, overlayID), poll.WithTimeout(1*time.Minute), poll.WithDelay(10*time.Second))
    99  }
   100  
   101  func swarmServiceSpec(name string, replicas uint64) swarmtypes.ServiceSpec {
   102  	return swarmtypes.ServiceSpec{
   103  		Annotations: swarmtypes.Annotations{
   104  			Name: name,
   105  		},
   106  		TaskTemplate: swarmtypes.TaskSpec{
   107  			ContainerSpec: &swarmtypes.ContainerSpec{
   108  				Image:   "busybox:latest",
   109  				Command: []string{"/bin/top"},
   110  			},
   111  		},
   112  		Mode: swarmtypes.ServiceMode{
   113  			Replicated: &swarmtypes.ReplicatedService{
   114  				Replicas: &replicas,
   115  			},
   116  		},
   117  	}
   118  }
   119  
   120  func serviceRunningTasksCount(client client.ServiceAPIClient, serviceID string, instances uint64) func(log poll.LogT) poll.Result {
   121  	return func(log poll.LogT) poll.Result {
   122  		filter := filters.NewArgs()
   123  		filter.Add("service", serviceID)
   124  		tasks, err := client.TaskList(context.Background(), types.TaskListOptions{
   125  			Filters: filter,
   126  		})
   127  		switch {
   128  		case err != nil:
   129  			return poll.Error(err)
   130  		case len(tasks) == int(instances):
   131  			for _, task := range tasks {
   132  				if task.Status.State != swarmtypes.TaskStateRunning {
   133  					return poll.Continue("waiting for tasks to enter run state")
   134  				}
   135  			}
   136  			return poll.Success()
   137  		default:
   138  			return poll.Continue("task count at %d waiting for %d", len(tasks), instances)
   139  		}
   140  	}
   141  }
   142  
   143  func networkIsRemoved(client client.NetworkAPIClient, networkID string) func(log poll.LogT) poll.Result {
   144  	return func(log poll.LogT) poll.Result {
   145  		_, err := client.NetworkInspect(context.Background(), networkID, types.NetworkInspectOptions{})
   146  		if err == nil {
   147  			return poll.Continue("waiting for network %s to be removed", networkID)
   148  		}
   149  		return poll.Success()
   150  	}
   151  }
   152  
   153  func serviceIsRemoved(client client.ServiceAPIClient, serviceID string) func(log poll.LogT) poll.Result {
   154  	return func(log poll.LogT) poll.Result {
   155  		filter := filters.NewArgs()
   156  		filter.Add("service", serviceID)
   157  		_, err := client.TaskList(context.Background(), types.TaskListOptions{
   158  			Filters: filter,
   159  		})
   160  		if err == nil {
   161  			return poll.Continue("waiting for service %s to be deleted", serviceID)
   162  		}
   163  		return poll.Success()
   164  	}
   165  }
   166  
   167  func noTasks(client client.ServiceAPIClient) func(log poll.LogT) poll.Result {
   168  	return func(log poll.LogT) poll.Result {
   169  		filter := filters.NewArgs()
   170  		tasks, err := client.TaskList(context.Background(), types.TaskListOptions{
   171  			Filters: filter,
   172  		})
   173  		switch {
   174  		case err != nil:
   175  			return poll.Error(err)
   176  		case len(tasks) == 0:
   177  			return poll.Success()
   178  		default:
   179  			return poll.Continue("task count at %d waiting for 0", len(tasks))
   180  		}
   181  	}
   182  }
   183  
   184  // Check to see if Service and Tasks info are part of the inspect verbose response
   185  func validNetworkVerbose(network types.NetworkResource, service string, instances uint64) bool {
   186  	if service, ok := network.Services[service]; ok {
   187  		if len(service.Tasks) == int(instances) {
   188  			return true
   189  		}
   190  	}
   191  	return false
   192  }