docker_cli_import_test.go 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150
  1. package main
  2. import (
  3. "bufio"
  4. "compress/gzip"
  5. "io/ioutil"
  6. "os"
  7. "os/exec"
  8. "regexp"
  9. "strings"
  10. "github.com/docker/docker/pkg/integration/checker"
  11. icmd "github.com/docker/docker/pkg/integration/cmd"
  12. "github.com/go-check/check"
  13. )
  14. func (s *DockerSuite) TestImportDisplay(c *check.C) {
  15. testRequires(c, DaemonIsLinux)
  16. out, _ := dockerCmd(c, "run", "-d", "busybox", "true")
  17. cleanedContainerID := strings.TrimSpace(out)
  18. out, _, err := runCommandPipelineWithOutput(
  19. exec.Command(dockerBinary, "export", cleanedContainerID),
  20. exec.Command(dockerBinary, "import", "-"),
  21. )
  22. c.Assert(err, checker.IsNil)
  23. c.Assert(out, checker.Count, "\n", 1, check.Commentf("display is expected 1 '\\n' but didn't"))
  24. image := strings.TrimSpace(out)
  25. out, _ = dockerCmd(c, "run", "--rm", image, "true")
  26. c.Assert(out, checker.Equals, "", check.Commentf("command output should've been nothing."))
  27. }
  28. func (s *DockerSuite) TestImportBadURL(c *check.C) {
  29. out, _, err := dockerCmdWithError("import", "http://nourl/bad")
  30. c.Assert(err, checker.NotNil, check.Commentf("import was supposed to fail but didn't"))
  31. // Depending on your system you can get either of these errors
  32. if !strings.Contains(out, "dial tcp") &&
  33. !strings.Contains(out, "ApplyLayer exit status 1 stdout: stderr: archive/tar: invalid tar header") &&
  34. !strings.Contains(out, "Error processing tar file") {
  35. c.Fatalf("expected an error msg but didn't get one.\nErr: %v\nOut: %v", err, out)
  36. }
  37. }
  38. func (s *DockerSuite) TestImportFile(c *check.C) {
  39. testRequires(c, DaemonIsLinux)
  40. dockerCmd(c, "run", "--name", "test-import", "busybox", "true")
  41. temporaryFile, err := ioutil.TempFile("", "exportImportTest")
  42. c.Assert(err, checker.IsNil, check.Commentf("failed to create temporary file"))
  43. defer os.Remove(temporaryFile.Name())
  44. runCmd := exec.Command(dockerBinary, "export", "test-import")
  45. runCmd.Stdout = bufio.NewWriter(temporaryFile)
  46. _, err = runCommand(runCmd)
  47. c.Assert(err, checker.IsNil, check.Commentf("failed to export a container"))
  48. out, _ := dockerCmd(c, "import", temporaryFile.Name())
  49. c.Assert(out, checker.Count, "\n", 1, check.Commentf("display is expected 1 '\\n' but didn't"))
  50. image := strings.TrimSpace(out)
  51. out, _ = dockerCmd(c, "run", "--rm", image, "true")
  52. c.Assert(out, checker.Equals, "", check.Commentf("command output should've been nothing."))
  53. }
  54. func (s *DockerSuite) TestImportGzipped(c *check.C) {
  55. testRequires(c, DaemonIsLinux)
  56. dockerCmd(c, "run", "--name", "test-import", "busybox", "true")
  57. temporaryFile, err := ioutil.TempFile("", "exportImportTest")
  58. c.Assert(err, checker.IsNil, check.Commentf("failed to create temporary file"))
  59. defer os.Remove(temporaryFile.Name())
  60. runCmd := exec.Command(dockerBinary, "export", "test-import")
  61. w := gzip.NewWriter(temporaryFile)
  62. runCmd.Stdout = w
  63. _, err = runCommand(runCmd)
  64. c.Assert(err, checker.IsNil, check.Commentf("failed to export a container"))
  65. err = w.Close()
  66. c.Assert(err, checker.IsNil, check.Commentf("failed to close gzip writer"))
  67. temporaryFile.Close()
  68. out, _ := dockerCmd(c, "import", temporaryFile.Name())
  69. c.Assert(out, checker.Count, "\n", 1, check.Commentf("display is expected 1 '\\n' but didn't"))
  70. image := strings.TrimSpace(out)
  71. out, _ = dockerCmd(c, "run", "--rm", image, "true")
  72. c.Assert(out, checker.Equals, "", check.Commentf("command output should've been nothing."))
  73. }
  74. func (s *DockerSuite) TestImportFileWithMessage(c *check.C) {
  75. testRequires(c, DaemonIsLinux)
  76. dockerCmd(c, "run", "--name", "test-import", "busybox", "true")
  77. temporaryFile, err := ioutil.TempFile("", "exportImportTest")
  78. c.Assert(err, checker.IsNil, check.Commentf("failed to create temporary file"))
  79. defer os.Remove(temporaryFile.Name())
  80. runCmd := exec.Command(dockerBinary, "export", "test-import")
  81. runCmd.Stdout = bufio.NewWriter(temporaryFile)
  82. _, err = runCommand(runCmd)
  83. c.Assert(err, checker.IsNil, check.Commentf("failed to export a container"))
  84. message := "Testing commit message"
  85. out, _ := dockerCmd(c, "import", "-m", message, temporaryFile.Name())
  86. c.Assert(out, checker.Count, "\n", 1, check.Commentf("display is expected 1 '\\n' but didn't"))
  87. image := strings.TrimSpace(out)
  88. out, _ = dockerCmd(c, "history", image)
  89. split := strings.Split(out, "\n")
  90. c.Assert(split, checker.HasLen, 3, check.Commentf("expected 3 lines from image history"))
  91. r := regexp.MustCompile("[\\s]{2,}")
  92. split = r.Split(split[1], -1)
  93. c.Assert(message, checker.Equals, split[3], check.Commentf("didn't get expected value in commit message"))
  94. out, _ = dockerCmd(c, "run", "--rm", image, "true")
  95. c.Assert(out, checker.Equals, "", check.Commentf("command output should've been nothing"))
  96. }
  97. func (s *DockerSuite) TestImportFileNonExistentFile(c *check.C) {
  98. _, _, err := dockerCmdWithError("import", "example.com/myImage.tar")
  99. c.Assert(err, checker.NotNil, check.Commentf("import non-existing file must failed"))
  100. }
  101. func (s *DockerSuite) TestImportWithQuotedChanges(c *check.C) {
  102. testRequires(c, DaemonIsLinux)
  103. dockerCmd(c, "run", "--name", "test-import", "busybox", "true")
  104. temporaryFile, err := ioutil.TempFile("", "exportImportTest")
  105. c.Assert(err, checker.IsNil, check.Commentf("failed to create temporary file"))
  106. defer os.Remove(temporaryFile.Name())
  107. result := icmd.RunCmd(icmd.Cmd{
  108. Command: binaryWithArgs("export", "test-import"),
  109. Stdout: bufio.NewWriter(temporaryFile),
  110. })
  111. c.Assert(result, icmd.Matches, icmd.Success)
  112. result = dockerCmdWithResult("import", "-c", `ENTRYPOINT ["/bin/sh", "-c"]`, temporaryFile.Name())
  113. c.Assert(result, icmd.Matches, icmd.Success)
  114. image := strings.TrimSpace(result.Stdout())
  115. result = dockerCmdWithResult("run", "--rm", image, "true")
  116. c.Assert(result, icmd.Matches, icmd.Expected{Out: icmd.None})
  117. }