docker_cli_v2_only_test.go 3.3 KB

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