f6e697d2 |
package main
import (
"net"
"os/exec"
"strings" |
dc944ea7 |
|
14f43406 |
"github.com/docker/docker/pkg/integration/checker" |
dc944ea7 |
"github.com/go-check/check" |
f6e697d2 |
)
|
dc944ea7 |
func (s *DockerSuite) TestCliProxyDisableProxyUnixSock(c *check.C) { |
f9a3558a |
testRequires(c, DaemonIsLinux) |
dc944ea7 |
testRequires(c, SameHostDaemon) // test is valid when DOCKER_HOST=unix://.. |
f6f2bad7 |
|
f6e697d2 |
cmd := exec.Command(dockerBinary, "info") |
f4a1e3db |
cmd.Env = appendBaseEnv(false, "HTTP_PROXY=http://127.0.0.1:9999") |
f6e697d2 |
|
14f43406 |
out, _, err := runCommandWithOutput(cmd)
c.Assert(err, checker.IsNil, check.Commentf("%v", out)) |
f6e697d2 |
}
// Can't use localhost here since go has a special case to not use proxy if connecting to localhost |
ca37301d |
// See https://golang.org/pkg/net/http/#ProxyFromEnvironment |
57464c32 |
func (s *DockerDaemonSuite) TestCliProxyProxyTCPSock(c *check.C) { |
dc944ea7 |
testRequires(c, SameHostDaemon) |
f6e697d2 |
// get the IP to use to connect since we can't use localhost
addrs, err := net.InterfaceAddrs() |
14f43406 |
c.Assert(err, checker.IsNil) |
f6e697d2 |
var ip string
for _, addr := range addrs {
sAddr := addr.String()
if !strings.Contains(sAddr, "127.0.0.1") {
addrArr := strings.Split(sAddr, "/")
ip = addrArr[0]
break
}
}
|
1db16176 |
c.Assert(ip, checker.Not(checker.Equals), "")
|
14f43406 |
err = s.d.Start("-H", "tcp://"+ip+":2375")
c.Assert(err, checker.IsNil) |
f6e697d2 |
cmd := exec.Command(dockerBinary, "info")
cmd.Env = []string{"DOCKER_HOST=tcp://" + ip + ":2375", "HTTP_PROXY=127.0.0.1:9999"} |
14f43406 |
out, _, err := runCommandWithOutput(cmd)
c.Assert(err, checker.NotNil, check.Commentf("%v", out)) |
f6e697d2 |
// Test with no_proxy
cmd.Env = append(cmd.Env, "NO_PROXY="+ip) |
14f43406 |
out, _, err = runCommandWithOutput(exec.Command(dockerBinary, "info"))
c.Assert(err, checker.IsNil, check.Commentf("%v", out)) |
f6e697d2 |
} |