docker_cli_config_test.go 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140
  1. package main
  2. import (
  3. "io/ioutil"
  4. "net/http"
  5. "net/http/httptest"
  6. "os"
  7. "os/exec"
  8. "path/filepath"
  9. "runtime"
  10. "github.com/docker/docker/api"
  11. "github.com/docker/docker/dockerversion"
  12. "github.com/docker/docker/pkg/homedir"
  13. "github.com/docker/docker/pkg/integration/checker"
  14. "github.com/go-check/check"
  15. )
  16. func (s *DockerSuite) TestConfigHTTPHeader(c *check.C) {
  17. testRequires(c, UnixCli) // Can't set/unset HOME on windows right now
  18. // We either need a level of Go that supports Unsetenv (for cases
  19. // when HOME/USERPROFILE isn't set), or we need to be able to use
  20. // os/user but user.Current() only works if we aren't statically compiling
  21. var headers map[string][]string
  22. server := httptest.NewServer(http.HandlerFunc(
  23. func(w http.ResponseWriter, r *http.Request) {
  24. w.Header().Set("API-Version", api.DefaultVersion)
  25. headers = r.Header
  26. }))
  27. defer server.Close()
  28. homeKey := homedir.Key()
  29. homeVal := homedir.Get()
  30. tmpDir, err := ioutil.TempDir("", "fake-home")
  31. c.Assert(err, checker.IsNil)
  32. defer os.RemoveAll(tmpDir)
  33. dotDocker := filepath.Join(tmpDir, ".docker")
  34. os.Mkdir(dotDocker, 0600)
  35. tmpCfg := filepath.Join(dotDocker, "config.json")
  36. defer func() { os.Setenv(homeKey, homeVal) }()
  37. os.Setenv(homeKey, tmpDir)
  38. data := `{
  39. "HttpHeaders": { "MyHeader": "MyValue" }
  40. }`
  41. err = ioutil.WriteFile(tmpCfg, []byte(data), 0600)
  42. c.Assert(err, checker.IsNil)
  43. cmd := exec.Command(dockerBinary, "-H="+server.URL[7:], "ps")
  44. out, _, _ := runCommandWithOutput(cmd)
  45. c.Assert(headers["User-Agent"], checker.NotNil, check.Commentf("Missing User-Agent"))
  46. c.Assert(headers["User-Agent"][0], checker.Equals, "Docker-Client/"+dockerversion.Version+" ("+runtime.GOOS+")", check.Commentf("Badly formatted User-Agent,out:%v", out))
  47. c.Assert(headers["Myheader"], checker.NotNil)
  48. c.Assert(headers["Myheader"][0], checker.Equals, "MyValue", check.Commentf("Missing/bad header,out:%v", out))
  49. }
  50. func (s *DockerSuite) TestConfigDir(c *check.C) {
  51. cDir, err := ioutil.TempDir("", "fake-home")
  52. c.Assert(err, checker.IsNil)
  53. defer os.RemoveAll(cDir)
  54. // First make sure pointing to empty dir doesn't generate an error
  55. dockerCmd(c, "--config", cDir, "ps")
  56. // Test with env var too
  57. cmd := exec.Command(dockerBinary, "ps")
  58. cmd.Env = appendBaseEnv(true, "DOCKER_CONFIG="+cDir)
  59. out, _, err := runCommandWithOutput(cmd)
  60. c.Assert(err, checker.IsNil, check.Commentf("ps2 didn't work,out:%v", out))
  61. // Start a server so we can check to see if the config file was
  62. // loaded properly
  63. var headers map[string][]string
  64. server := httptest.NewServer(http.HandlerFunc(
  65. func(w http.ResponseWriter, r *http.Request) {
  66. headers = r.Header
  67. }))
  68. defer server.Close()
  69. // Create a dummy config file in our new config dir
  70. data := `{
  71. "HttpHeaders": { "MyHeader": "MyValue" }
  72. }`
  73. tmpCfg := filepath.Join(cDir, "config.json")
  74. err = ioutil.WriteFile(tmpCfg, []byte(data), 0600)
  75. c.Assert(err, checker.IsNil, check.Commentf("Err creating file"))
  76. env := appendBaseEnv(false)
  77. cmd = exec.Command(dockerBinary, "--config", cDir, "-H="+server.URL[7:], "ps")
  78. cmd.Env = env
  79. out, _, err = runCommandWithOutput(cmd)
  80. c.Assert(err, checker.NotNil, check.Commentf("out:%v", out))
  81. c.Assert(headers["Myheader"], checker.NotNil)
  82. c.Assert(headers["Myheader"][0], checker.Equals, "MyValue", check.Commentf("ps3 - Missing header,out:%v", out))
  83. // Reset headers and try again using env var this time
  84. headers = map[string][]string{}
  85. cmd = exec.Command(dockerBinary, "-H="+server.URL[7:], "ps")
  86. cmd.Env = append(env, "DOCKER_CONFIG="+cDir)
  87. out, _, err = runCommandWithOutput(cmd)
  88. c.Assert(err, checker.NotNil, check.Commentf("%v", out))
  89. c.Assert(headers["Myheader"], checker.NotNil)
  90. c.Assert(headers["Myheader"][0], checker.Equals, "MyValue", check.Commentf("ps4 - Missing header,out:%v", out))
  91. // Reset headers and make sure flag overrides the env var
  92. headers = map[string][]string{}
  93. cmd = exec.Command(dockerBinary, "--config", cDir, "-H="+server.URL[7:], "ps")
  94. cmd.Env = append(env, "DOCKER_CONFIG=MissingDir")
  95. out, _, err = runCommandWithOutput(cmd)
  96. c.Assert(err, checker.NotNil, check.Commentf("out:%v", out))
  97. c.Assert(headers["Myheader"], checker.NotNil)
  98. c.Assert(headers["Myheader"][0], checker.Equals, "MyValue", check.Commentf("ps5 - Missing header,out:%v", out))
  99. // Reset headers and make sure flag overrides the env var.
  100. // Almost same as previous but make sure the "MissingDir" isn't
  101. // ignore - we don't want to default back to the env var.
  102. headers = map[string][]string{}
  103. cmd = exec.Command(dockerBinary, "--config", "MissingDir", "-H="+server.URL[7:], "ps")
  104. cmd.Env = append(env, "DOCKER_CONFIG="+cDir)
  105. out, _, err = runCommandWithOutput(cmd)
  106. c.Assert(err, checker.NotNil, check.Commentf("out:%v", out))
  107. c.Assert(headers["Myheader"], checker.IsNil, check.Commentf("ps6 - Headers shouldn't be the expected value,out:%v", out))
  108. }