integration-cli/docker_cli_config_test.go
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
 }