docker_cli_sni_test.go 1.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243
  1. package main
  2. import (
  3. "fmt"
  4. "io/ioutil"
  5. "log"
  6. "net/http"
  7. "net/http/httptest"
  8. "net/url"
  9. "os/exec"
  10. "strings"
  11. "github.com/go-check/check"
  12. )
  13. func (s *DockerSuite) TestClientSetsTLSServerName(c *check.C) {
  14. // there may be more than one hit to the server for each registry request
  15. serverNameReceived := []string{}
  16. var serverName string
  17. virtualHostServer := httptest.NewTLSServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
  18. serverNameReceived = append(serverNameReceived, r.TLS.ServerName)
  19. }))
  20. defer virtualHostServer.Close()
  21. // discard TLS handshake errors written by default to os.Stderr
  22. virtualHostServer.Config.ErrorLog = log.New(ioutil.Discard, "", 0)
  23. u, err := url.Parse(virtualHostServer.URL)
  24. c.Assert(err, check.IsNil)
  25. hostPort := u.Host
  26. serverName = strings.Split(hostPort, ":")[0]
  27. repoName := fmt.Sprintf("%v/dockercli/image:latest", hostPort)
  28. cmd := exec.Command(dockerBinary, "pull", repoName)
  29. cmd.Run()
  30. // check that the fake server was hit at least once
  31. c.Assert(len(serverNameReceived) > 0, check.Equals, true)
  32. // check that for each hit the right server name was received
  33. for _, item := range serverNameReceived {
  34. c.Check(item, check.Equals, serverName)
  35. }
  36. }