docker_cli_import_test.go 5.2 KB

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