18c9b6c6 |
package main
import (
"io/ioutil"
"net/http"
"net/http/httptest"
"os"
"path/filepath" |
543cf79f |
"runtime" |
18c9b6c6 |
|
e98e4a71 |
"github.com/docker/docker/api" |
8054a303 |
"github.com/docker/docker/dockerversion" |
33968e6c |
"github.com/docker/docker/integration-cli/checker" |
18c9b6c6 |
"github.com/docker/docker/pkg/homedir" |
303b1d20 |
icmd "github.com/docker/docker/pkg/testutil/cmd" |
dc944ea7 |
"github.com/go-check/check" |
18c9b6c6 |
)
|
7fb7a477 |
func (s *DockerSuite) TestConfigHTTPHeader(c *check.C) { |
dc944ea7 |
testRequires(c, UnixCli) // Can't set/unset HOME on windows right now |
18c9b6c6 |
// We either need a level of Go that supports Unsetenv (for cases
// when HOME/USERPROFILE isn't set), or we need to be able to use
// os/user but user.Current() only works if we aren't statically compiling
var headers map[string][]string
server := httptest.NewServer(http.HandlerFunc(
func(w http.ResponseWriter, r *http.Request) { |
e98e4a71 |
w.Header().Set("API-Version", api.DefaultVersion) |
18c9b6c6 |
headers = r.Header
}))
defer server.Close()
homeKey := homedir.Key()
homeVal := homedir.Get() |
51e721ab |
tmpDir, err := ioutil.TempDir("", "fake-home") |
d1ed5f62 |
c.Assert(err, checker.IsNil) |
18c9b6c6 |
defer os.RemoveAll(tmpDir)
dotDocker := filepath.Join(tmpDir, ".docker")
os.Mkdir(dotDocker, 0600)
tmpCfg := filepath.Join(dotDocker, "config.json")
defer func() { os.Setenv(homeKey, homeVal) }()
os.Setenv(homeKey, tmpDir)
data := `{
"HttpHeaders": { "MyHeader": "MyValue" }
}`
|
51e721ab |
err = ioutil.WriteFile(tmpCfg, []byte(data), 0600) |
d1ed5f62 |
c.Assert(err, checker.IsNil) |
18c9b6c6 |
|
87e3fcfe |
result := icmd.RunCommand(dockerBinary, "-H="+server.URL[7:], "ps") |
303b1d20 |
result.Assert(c, icmd.Expected{
ExitCode: 1,
Error: "exit status 1",
}) |
18c9b6c6 |
|
d1ed5f62 |
c.Assert(headers["User-Agent"], checker.NotNil, check.Commentf("Missing User-Agent")) |
543cf79f |
|
87e3fcfe |
c.Assert(headers["User-Agent"][0], checker.Equals, "Docker-Client/"+dockerversion.Version+" ("+runtime.GOOS+")", check.Commentf("Badly formatted User-Agent,out:%v", result.Combined())) |
d1ed5f62 |
c.Assert(headers["Myheader"], checker.NotNil) |
87e3fcfe |
c.Assert(headers["Myheader"][0], checker.Equals, "MyValue", check.Commentf("Missing/bad header,out:%v", result.Combined())) |
543cf79f |
|
18c9b6c6 |
} |
daced1d3 |
func (s *DockerSuite) TestConfigDir(c *check.C) { |
51e721ab |
cDir, err := ioutil.TempDir("", "fake-home") |
d1ed5f62 |
c.Assert(err, checker.IsNil) |
51e721ab |
defer os.RemoveAll(cDir) |
daced1d3 |
// First make sure pointing to empty dir doesn't generate an error |
d1ed5f62 |
dockerCmd(c, "--config", cDir, "ps") |
daced1d3 |
// Test with env var too |
303b1d20 |
icmd.RunCmd(icmd.Cmd{ |
87e3fcfe |
Command: []string{dockerBinary, "ps"}, |
303b1d20 |
Env: appendBaseEnv(true, "DOCKER_CONFIG="+cDir), |
87e3fcfe |
}).Assert(c, icmd.Success) |
daced1d3 |
// Start a server so we can check to see if the config file was
// loaded properly
var headers map[string][]string
server := httptest.NewServer(http.HandlerFunc(
func(w http.ResponseWriter, r *http.Request) {
headers = r.Header
}))
defer server.Close()
// Create a dummy config file in our new config dir
data := `{
"HttpHeaders": { "MyHeader": "MyValue" }
}`
tmpCfg := filepath.Join(cDir, "config.json")
err = ioutil.WriteFile(tmpCfg, []byte(data), 0600) |
d1ed5f62 |
c.Assert(err, checker.IsNil, check.Commentf("Err creating file")) |
daced1d3 |
|
f4a1e3db |
env := appendBaseEnv(false)
|
87e3fcfe |
icmd.RunCmd(icmd.Cmd{ |
303b1d20 |
Command: []string{dockerBinary, "--config", cDir, "-H=" + server.URL[7:], "ps"},
Env: env,
}).Assert(c, icmd.Expected{
ExitCode: 1,
Error: "exit status 1", |
87e3fcfe |
}) |
d1ed5f62 |
c.Assert(headers["Myheader"], checker.NotNil) |
303b1d20 |
c.Assert(headers["Myheader"][0], checker.Equals, "MyValue", check.Commentf("ps3 - Missing header")) |
daced1d3 |
// Reset headers and try again using env var this time
headers = map[string][]string{} |
87e3fcfe |
icmd.RunCmd(icmd.Cmd{ |
303b1d20 |
Command: []string{dockerBinary, "--config", cDir, "-H=" + server.URL[7:], "ps"},
Env: append(env, "DOCKER_CONFIG="+cDir),
}).Assert(c, icmd.Expected{
ExitCode: 1, |
87e3fcfe |
}) |
d1ed5f62 |
c.Assert(headers["Myheader"], checker.NotNil) |
303b1d20 |
c.Assert(headers["Myheader"][0], checker.Equals, "MyValue", check.Commentf("ps4 - Missing header")) |
daced1d3 |
|
87e3fcfe |
// FIXME(vdemeester) should be a unit test |
daced1d3 |
// Reset headers and make sure flag overrides the env var
headers = map[string][]string{} |
87e3fcfe |
icmd.RunCmd(icmd.Cmd{ |
303b1d20 |
Command: []string{dockerBinary, "--config", cDir, "-H=" + server.URL[7:], "ps"},
Env: append(env, "DOCKER_CONFIG=MissingDir"),
}).Assert(c, icmd.Expected{
ExitCode: 1, |
87e3fcfe |
}) |
d1ed5f62 |
c.Assert(headers["Myheader"], checker.NotNil) |
303b1d20 |
c.Assert(headers["Myheader"][0], checker.Equals, "MyValue", check.Commentf("ps5 - Missing header")) |
daced1d3 |
|
87e3fcfe |
// FIXME(vdemeester) should be a unit test |
daced1d3 |
// Reset headers and make sure flag overrides the env var.
// Almost same as previous but make sure the "MissingDir" isn't
// ignore - we don't want to default back to the env var.
headers = map[string][]string{} |
87e3fcfe |
icmd.RunCmd(icmd.Cmd{ |
303b1d20 |
Command: []string{dockerBinary, "--config", "MissingDir", "-H=" + server.URL[7:], "ps"},
Env: append(env, "DOCKER_CONFIG="+cDir),
}).Assert(c, icmd.Expected{
ExitCode: 1,
Error: "exit status 1", |
87e3fcfe |
}) |
daced1d3 |
|
303b1d20 |
c.Assert(headers["Myheader"], checker.IsNil, check.Commentf("ps6 - Headers shouldn't be the expected value")) |
daced1d3 |
} |