docker_cli_v2_only_test.go 3.4 KB

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