Browse code

Migrate some of the nat tests in integration-cli to api tests

This fix migrates nat tests in docker_cli_nat_test.go
to api tests.

Signed-off-by: Yong Tang <yong.tang.github@outlook.com>

Yong Tang authored on 2018/02/03 07:52:18
Showing 1 changed files
1 1
new file mode 100644
... ...
@@ -0,0 +1,147 @@
0
+package container
1
+
2
+import (
3
+	"bytes"
4
+	"context"
5
+	"fmt"
6
+	"io"
7
+	"io/ioutil"
8
+	"net"
9
+	"strings"
10
+	"testing"
11
+	"time"
12
+
13
+	"github.com/docker/docker/api/types"
14
+	"github.com/docker/docker/api/types/container"
15
+	"github.com/docker/docker/api/types/network"
16
+	"github.com/docker/docker/integration/util/request"
17
+	"github.com/docker/go-connections/nat"
18
+	"github.com/gotestyourself/gotestyourself/poll"
19
+	"github.com/gotestyourself/gotestyourself/skip"
20
+	"github.com/stretchr/testify/assert"
21
+	"github.com/stretchr/testify/require"
22
+)
23
+
24
+func TestNetworkNat(t *testing.T) {
25
+	skip.If(t, !testEnv.IsLocalDaemon())
26
+
27
+	defer setupTest(t)()
28
+
29
+	msg := "it works"
30
+	startServerContainer(t, msg, 8080)
31
+
32
+	endpoint := getExternalAddress(t)
33
+	conn, err := net.Dial("tcp", fmt.Sprintf("%s:%d", endpoint.String(), 8080))
34
+	require.NoError(t, err)
35
+	defer conn.Close()
36
+
37
+	data, err := ioutil.ReadAll(conn)
38
+	require.NoError(t, err)
39
+	assert.Equal(t, strings.TrimSpace(string(data)), msg)
40
+}
41
+
42
+func TestNetworkLocalhostTCPNat(t *testing.T) {
43
+	skip.If(t, !testEnv.IsLocalDaemon())
44
+
45
+	defer setupTest(t)()
46
+
47
+	msg := "hi yall"
48
+	startServerContainer(t, msg, 8081)
49
+
50
+	conn, err := net.Dial("tcp", "localhost:8081")
51
+	require.NoError(t, err)
52
+	defer conn.Close()
53
+
54
+	data, err := ioutil.ReadAll(conn)
55
+	require.NoError(t, err)
56
+	assert.Equal(t, strings.TrimSpace(string(data)), msg)
57
+}
58
+
59
+func TestNetworkLoopbackNat(t *testing.T) {
60
+	skip.If(t, !testEnv.IsLocalDaemon())
61
+
62
+	msg := "it works"
63
+	startServerContainer(t, msg, 8080)
64
+
65
+	endpoint := getExternalAddress(t)
66
+
67
+	client := request.NewAPIClient(t)
68
+	ctx := context.Background()
69
+	c, err := client.ContainerCreate(ctx,
70
+		&container.Config{
71
+			Image: "busybox",
72
+			Cmd:   []string{"sh", "-c", fmt.Sprintf("stty raw && nc -w 5 %s 8080", endpoint.String())},
73
+			Tty:   true,
74
+		},
75
+		&container.HostConfig{
76
+			NetworkMode: "container:server",
77
+		},
78
+		nil,
79
+		"")
80
+	require.NoError(t, err)
81
+
82
+	err = client.ContainerStart(ctx, c.ID, types.ContainerStartOptions{})
83
+	require.NoError(t, err)
84
+
85
+	poll.WaitOn(t, containerIsStopped(ctx, client, c.ID), poll.WithDelay(100*time.Millisecond))
86
+
87
+	body, err := client.ContainerLogs(ctx, c.ID, types.ContainerLogsOptions{
88
+		ShowStdout: true,
89
+	})
90
+	require.NoError(t, err)
91
+	defer body.Close()
92
+
93
+	var b bytes.Buffer
94
+	_, err = io.Copy(&b, body)
95
+	require.NoError(t, err)
96
+
97
+	assert.Equal(t, strings.TrimSpace(b.String()), msg)
98
+}
99
+
100
+func startServerContainer(t *testing.T, msg string, port int) string {
101
+	client := request.NewAPIClient(t)
102
+	ctx := context.Background()
103
+
104
+	c, err := client.ContainerCreate(ctx,
105
+		&container.Config{
106
+			Image: "busybox",
107
+			Cmd:   []string{"sh", "-c", fmt.Sprintf("echo %q | nc -lp %d", msg, port)},
108
+			ExposedPorts: map[nat.Port]struct{}{
109
+				nat.Port(fmt.Sprintf("%d/tcp", port)): {},
110
+			},
111
+		},
112
+		&container.HostConfig{
113
+			PortBindings: nat.PortMap{
114
+				nat.Port(fmt.Sprintf("%d/tcp", port)): []nat.PortBinding{
115
+					{
116
+						HostPort: fmt.Sprintf("%d", port),
117
+					},
118
+				},
119
+			},
120
+		},
121
+		&network.NetworkingConfig{},
122
+		"server",
123
+	)
124
+	require.NoError(t, err)
125
+
126
+	err = client.ContainerStart(ctx, c.ID, types.ContainerStartOptions{})
127
+	require.NoError(t, err)
128
+
129
+	poll.WaitOn(t, containerIsInState(ctx, client, c.ID, "running"), poll.WithDelay(100*time.Millisecond))
130
+
131
+	return c.ID
132
+}
133
+
134
+func getExternalAddress(t *testing.T) net.IP {
135
+	iface, err := net.InterfaceByName("eth0")
136
+	skip.If(t, err != nil, "Test not running with `make test-integration`. Interface eth0 not found: %s", err)
137
+
138
+	ifaceAddrs, err := iface.Addrs()
139
+	require.NoError(t, err)
140
+	assert.NotEqual(t, len(ifaceAddrs), 0)
141
+
142
+	ifaceIP, _, err := net.ParseCIDR(ifaceAddrs[0].String())
143
+	require.NoError(t, err)
144
+
145
+	return ifaceIP
146
+}