|
@@ -75,3 +75,43 @@ func TestDockerNetworkConnectAlias(t *testing.T) {
|
|
|
assert.Check(t, is.Equal(len(ng2.NetworkSettings.Networks[name].Aliases), 2))
|
|
|
assert.Check(t, is.Equal(ng2.NetworkSettings.Networks[name].Aliases[0], "bbb"))
|
|
|
}
|
|
|
+
|
|
|
+func TestDockerNetworkReConnect(t *testing.T) {
|
|
|
+ skip.If(t, testEnv.DaemonInfo.OSType == "windows")
|
|
|
+ defer setupTest(t)()
|
|
|
+ d := swarm.NewSwarm(t, testEnv)
|
|
|
+ defer d.Stop(t)
|
|
|
+ client := d.NewClientT(t)
|
|
|
+ defer client.Close()
|
|
|
+ ctx := context.Background()
|
|
|
+
|
|
|
+ name := t.Name() + "dummyNet"
|
|
|
+ net.CreateNoError(t, ctx, client, name,
|
|
|
+ net.WithDriver("overlay"),
|
|
|
+ net.WithAttachable(),
|
|
|
+ )
|
|
|
+
|
|
|
+ c1 := container.Create(t, ctx, client, func(c *container.TestContainerConfig) {
|
|
|
+ c.NetworkingConfig = &network.NetworkingConfig{
|
|
|
+ EndpointsConfig: map[string]*network.EndpointSettings{
|
|
|
+ name: {},
|
|
|
+ },
|
|
|
+ }
|
|
|
+ })
|
|
|
+
|
|
|
+ err := client.NetworkConnect(ctx, name, c1, &network.EndpointSettings{})
|
|
|
+ assert.NilError(t, err)
|
|
|
+
|
|
|
+ err = client.ContainerStart(ctx, c1, types.ContainerStartOptions{})
|
|
|
+ assert.NilError(t, err)
|
|
|
+
|
|
|
+ n1, err := client.ContainerInspect(ctx, c1)
|
|
|
+ assert.NilError(t, err)
|
|
|
+
|
|
|
+ err = client.NetworkConnect(ctx, name, c1, &network.EndpointSettings{})
|
|
|
+ assert.ErrorContains(t, err, "is already attached to network")
|
|
|
+
|
|
|
+ n2, err := client.ContainerInspect(ctx, c1)
|
|
|
+ assert.NilError(t, err)
|
|
|
+ assert.Check(t, is.DeepEqual(n1, n2))
|
|
|
+}
|