docker_cli_v2_only_test.go 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120
  1. package main
  2. import (
  3. "fmt"
  4. "io/ioutil"
  5. "net/http"
  6. "os"
  7. "github.com/docker/docker/integration-cli/registry"
  8. "github.com/go-check/check"
  9. )
  10. func makefile(path string, contents string) (string, error) {
  11. f, err := ioutil.TempFile(path, "tmp")
  12. if err != nil {
  13. return "", err
  14. }
  15. err = ioutil.WriteFile(f.Name(), []byte(contents), os.ModePerm)
  16. if err != nil {
  17. return "", err
  18. }
  19. return f.Name(), nil
  20. }
  21. // TestV2Only ensures that a daemon by default does not
  22. // attempt to contact any v1 registry endpoints.
  23. func (s *DockerRegistrySuite) TestV2Only(c *check.C) {
  24. reg, err := registry.NewMock(c)
  25. defer reg.Close()
  26. c.Assert(err, check.IsNil)
  27. reg.RegisterHandler("/v2/", func(w http.ResponseWriter, r *http.Request) {
  28. w.WriteHeader(404)
  29. })
  30. reg.RegisterHandler("/v1/.*", func(w http.ResponseWriter, r *http.Request) {
  31. c.Fatal("V1 registry contacted")
  32. })
  33. repoName := fmt.Sprintf("%s/busybox", reg.URL())
  34. s.d.Start(c, "--insecure-registry", reg.URL())
  35. tmp, err := ioutil.TempDir("", "integration-cli-")
  36. c.Assert(err, check.IsNil)
  37. defer os.RemoveAll(tmp)
  38. dockerfileName, err := makefile(tmp, fmt.Sprintf("FROM %s/busybox", reg.URL()))
  39. c.Assert(err, check.IsNil, check.Commentf("Unable to create test dockerfile"))
  40. s.d.Cmd("build", "--file", dockerfileName, tmp)
  41. s.d.Cmd("run", repoName)
  42. s.d.Cmd("login", "-u", "richard", "-p", "testtest", reg.URL())
  43. s.d.Cmd("tag", "busybox", repoName)
  44. s.d.Cmd("push", repoName)
  45. s.d.Cmd("pull", repoName)
  46. }
  47. // TestV1 starts a daemon with legacy registries enabled
  48. // and ensure v1 endpoints are hit for the following operations:
  49. // login, push, pull, build & run
  50. func (s *DockerRegistrySuite) TestV1(c *check.C) {
  51. reg, err := registry.NewMock(c)
  52. defer reg.Close()
  53. c.Assert(err, check.IsNil)
  54. v2Pings := 0
  55. reg.RegisterHandler("/v2/", func(w http.ResponseWriter, r *http.Request) {
  56. v2Pings++
  57. // V2 ping 404 causes fallback to v1
  58. w.WriteHeader(404)
  59. })
  60. v1Pings := 0
  61. reg.RegisterHandler("/v1/_ping", func(w http.ResponseWriter, r *http.Request) {
  62. v1Pings++
  63. })
  64. v1Logins := 0
  65. reg.RegisterHandler("/v1/users/", func(w http.ResponseWriter, r *http.Request) {
  66. v1Logins++
  67. })
  68. v1Repo := 0
  69. reg.RegisterHandler("/v1/repositories/busybox/", func(w http.ResponseWriter, r *http.Request) {
  70. v1Repo++
  71. })
  72. reg.RegisterHandler("/v1/repositories/busybox/images", func(w http.ResponseWriter, r *http.Request) {
  73. v1Repo++
  74. })
  75. s.d.Start(c, "--insecure-registry", reg.URL(), "--disable-legacy-registry=false")
  76. tmp, err := ioutil.TempDir("", "integration-cli-")
  77. c.Assert(err, check.IsNil)
  78. defer os.RemoveAll(tmp)
  79. dockerfileName, err := makefile(tmp, fmt.Sprintf("FROM %s/busybox", reg.URL()))
  80. c.Assert(err, check.IsNil, check.Commentf("Unable to create test dockerfile"))
  81. s.d.Cmd("build", "--file", dockerfileName, tmp)
  82. c.Assert(v1Repo, check.Equals, 1, check.Commentf("Expected v1 repository access after build"))
  83. repoName := fmt.Sprintf("%s/busybox", reg.URL())
  84. s.d.Cmd("run", repoName)
  85. c.Assert(v1Repo, check.Equals, 2, check.Commentf("Expected v1 repository access after run"))
  86. s.d.Cmd("login", "-u", "richard", "-p", "testtest", reg.URL())
  87. c.Assert(v1Logins, check.Equals, 1, check.Commentf("Expected v1 login attempt"))
  88. s.d.Cmd("tag", "busybox", repoName)
  89. s.d.Cmd("push", repoName)
  90. c.Assert(v1Repo, check.Equals, 2)
  91. s.d.Cmd("pull", repoName)
  92. c.Assert(v1Repo, check.Equals, 3, check.Commentf("Expected v1 repository access after pull"))
  93. }