forked from fsouza/go-dockerclient
-
Notifications
You must be signed in to change notification settings - Fork 1
/
integration_test.go
103 lines (97 loc) · 2.51 KB
/
integration_test.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
// Copyright 2015 go-dockerclient authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
// +build docker_integration
package docker
import (
"bytes"
"reflect"
"runtime"
"strings"
"testing"
)
func TestIntegrationPullCreateStartLogs(t *testing.T) {
imageName := pullImage(t)
client, err := NewClientFromEnv()
if err != nil {
t.Fatal(err)
}
hostConfig := HostConfig{PublishAllPorts: true}
createOpts := integrationCreateContainerOpts(imageName, &hostConfig)
container, err := client.CreateContainer(createOpts)
if err != nil {
t.Fatal(err)
}
err = client.StartContainer(container.ID, &hostConfig)
if err != nil {
t.Fatal(err)
}
status, err := client.WaitContainer(container.ID)
if err != nil {
t.Error(err)
}
if status != 0 {
t.Errorf("WaitContainer(%q): wrong status. Want 0. Got %d", container.ID, status)
}
var stdout, stderr bytes.Buffer
logsOpts := LogsOptions{
Container: container.ID,
OutputStream: &stdout,
ErrorStream: &stderr,
Stdout: true,
Stderr: true,
}
err = client.Logs(logsOpts)
if err != nil {
t.Error(err)
}
if stderr.String() != "" {
t.Errorf("Got unexpected stderr from logs: %q", stderr.String())
}
// split stdout by lines to make sure the test is the same on Windows
// and Linux. Life is hard.
expected := []string{
"Welcome to reality, wake up and rejoice",
"Welcome to reality, you've made the right choice",
"Welcome to reality, and let them hear your voice, shout it out!",
}
if stdoutLines := getLines(&stdout); !reflect.DeepEqual(stdoutLines, expected) {
t.Errorf("Got wrong stdout from logs.\nWant:\n%#v.\n\nGot:\n%#v.", expected, stdoutLines)
}
}
func getLines(buf *bytes.Buffer) []string {
var lines []string
for _, line := range strings.Split(buf.String(), "\n") {
line = strings.TrimSpace(line)
if line != "" {
lines = append(lines, line)
}
}
return lines
}
func pullImage(t *testing.T) string {
os := runtime.GOOS
platform := runtime.GOOS + "/" + runtime.GOARCH
if os != "windows" {
os = "linux"
} else {
platform = runtime.GOOS
}
imageName := "fsouza/go-dockerclient-integration:" + os
var buf bytes.Buffer
pullOpts := PullImageOptions{
Repository: imageName,
OutputStream: &buf,
Platform: platform,
}
client, err := NewClientFromEnv()
if err != nil {
t.Fatal(err)
}
err = client.PullImage(pullOpts, AuthConfiguration{})
if err != nil {
t.Logf("Pull output: %s", buf.String())
t.Fatal(err)
}
return imageName
}