mirror of
https://github.com/moby/moby.git
synced 2022-11-09 12:21:53 -05:00
59e55dcdd0
goimports -w \ -- "./integration-cli/daemon" "./pkg/discovery" "./pkg/discovery/file" "./pkg/discovery/kv" "./pkg/discovery/memory" "./pkg/discovery/nodes" "./integration-cli" \ && \ gofmt -w -s \ -- "./integration-cli/daemon" "./pkg/discovery" "./pkg/discovery/file" "./pkg/discovery/kv" "./pkg/discovery/memory" "./pkg/discovery/nodes" "./integration-cli" Signed-off-by: Tibor Vass <tibor@docker.com>
45 lines
1.2 KiB
Go
45 lines
1.2 KiB
Go
package main
|
|
|
|
import (
|
|
"fmt"
|
|
"io/ioutil"
|
|
"log"
|
|
"net/http"
|
|
"net/http/httptest"
|
|
"net/url"
|
|
"os/exec"
|
|
"strings"
|
|
"testing"
|
|
|
|
"gotest.tools/assert"
|
|
)
|
|
|
|
func (s *DockerSuite) TestClientSetsTLSServerName(c *testing.T) {
|
|
c.Skip("Flakey test")
|
|
// there may be more than one hit to the server for each registry request
|
|
var serverNameReceived []string
|
|
var serverName string
|
|
|
|
virtualHostServer := httptest.NewTLSServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
|
serverNameReceived = append(serverNameReceived, r.TLS.ServerName)
|
|
}))
|
|
defer virtualHostServer.Close()
|
|
// discard TLS handshake errors written by default to os.Stderr
|
|
virtualHostServer.Config.ErrorLog = log.New(ioutil.Discard, "", 0)
|
|
|
|
u, err := url.Parse(virtualHostServer.URL)
|
|
assert.NilError(c, err)
|
|
hostPort := u.Host
|
|
serverName = strings.Split(hostPort, ":")[0]
|
|
|
|
repoName := fmt.Sprintf("%v/dockercli/image:latest", hostPort)
|
|
cmd := exec.Command(dockerBinary, "pull", repoName)
|
|
cmd.Run()
|
|
|
|
// check that the fake server was hit at least once
|
|
assert.Assert(c, len(serverNameReceived) > 0)
|
|
// check that for each hit the right server name was received
|
|
for _, item := range serverNameReceived {
|
|
assert.Check(c, item == serverName)
|
|
}
|
|
}
|