docker_cli_config_test.go 4.8 KB

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