docker_cli_volume_test.go 8.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193
  1. package main
  2. import (
  3. "os/exec"
  4. "strings"
  5. derr "github.com/docker/docker/errors"
  6. "github.com/docker/docker/pkg/integration/checker"
  7. "github.com/docker/docker/volume"
  8. "github.com/go-check/check"
  9. )
  10. func (s *DockerSuite) TestVolumeCliCreate(c *check.C) {
  11. dockerCmd(c, "volume", "create")
  12. _, err := runCommand(exec.Command(dockerBinary, "volume", "create", "-d", "nosuchdriver"))
  13. c.Assert(err, check.Not(check.IsNil))
  14. out, _ := dockerCmd(c, "volume", "create", "--name=test")
  15. name := strings.TrimSpace(out)
  16. c.Assert(name, check.Equals, "test")
  17. }
  18. func (s *DockerSuite) TestVolumeCliCreateOptionConflict(c *check.C) {
  19. dockerCmd(c, "volume", "create", "--name=test")
  20. out, _, err := dockerCmdWithError("volume", "create", "--name", "test", "--driver", "nosuchdriver")
  21. c.Assert(err, check.NotNil, check.Commentf("volume create exception name already in use with another driver"))
  22. stderr := derr.ErrorVolumeNameTaken.WithArgs("test", volume.DefaultDriverName).Error()
  23. c.Assert(strings.Contains(out, strings.TrimPrefix(stderr, "volume name taken: ")), check.Equals, true)
  24. out, _ = dockerCmd(c, "volume", "inspect", "--format='{{ .Driver }}'", "test")
  25. _, _, err = dockerCmdWithError("volume", "create", "--name", "test", "--driver", strings.TrimSpace(out))
  26. c.Assert(err, check.IsNil)
  27. }
  28. func (s *DockerSuite) TestVolumeCliInspect(c *check.C) {
  29. c.Assert(
  30. exec.Command(dockerBinary, "volume", "inspect", "doesntexist").Run(),
  31. check.Not(check.IsNil),
  32. check.Commentf("volume inspect should error on non-existent volume"),
  33. )
  34. out, _ := dockerCmd(c, "volume", "create")
  35. name := strings.TrimSpace(out)
  36. out, _ = dockerCmd(c, "volume", "inspect", "--format='{{ .Name }}'", name)
  37. c.Assert(strings.TrimSpace(out), check.Equals, name)
  38. dockerCmd(c, "volume", "create", "--name", "test")
  39. out, _ = dockerCmd(c, "volume", "inspect", "--format='{{ .Name }}'", "test")
  40. c.Assert(strings.TrimSpace(out), check.Equals, "test")
  41. }
  42. func (s *DockerSuite) TestVolumeCliInspectMulti(c *check.C) {
  43. dockerCmd(c, "volume", "create", "--name", "test1")
  44. dockerCmd(c, "volume", "create", "--name", "test2")
  45. dockerCmd(c, "volume", "create", "--name", "not-shown")
  46. out, _, err := dockerCmdWithError("volume", "inspect", "--format='{{ .Name }}'", "test1", "test2", "doesntexist", "not-shown")
  47. c.Assert(err, checker.NotNil)
  48. outArr := strings.Split(strings.TrimSpace(out), "\n")
  49. c.Assert(len(outArr), check.Equals, 3, check.Commentf("\n%s", out))
  50. c.Assert(out, checker.Contains, "test1")
  51. c.Assert(out, checker.Contains, "test2")
  52. c.Assert(out, checker.Contains, "Error: No such volume: doesntexist")
  53. c.Assert(out, checker.Not(checker.Contains), "not-shown")
  54. }
  55. func (s *DockerSuite) TestVolumeCliLs(c *check.C) {
  56. prefix := ""
  57. if daemonPlatform == "windows" {
  58. prefix = "c:"
  59. }
  60. out, _ := dockerCmd(c, "volume", "create")
  61. id := strings.TrimSpace(out)
  62. dockerCmd(c, "volume", "create", "--name", "test")
  63. dockerCmd(c, "run", "-v", prefix+"/foo", "busybox", "ls", "/")
  64. out, _ = dockerCmd(c, "volume", "ls")
  65. outArr := strings.Split(strings.TrimSpace(out), "\n")
  66. c.Assert(len(outArr), check.Equals, 4, check.Commentf("\n%s", out))
  67. // Since there is no guarantee of ordering of volumes, we just make sure the names are in the output
  68. c.Assert(strings.Contains(out, id+"\n"), check.Equals, true)
  69. c.Assert(strings.Contains(out, "test\n"), check.Equals, true)
  70. }
  71. func (s *DockerSuite) TestVolumeCliLsFilterDangling(c *check.C) {
  72. prefix := ""
  73. if daemonPlatform == "windows" {
  74. prefix = "c:"
  75. }
  76. dockerCmd(c, "volume", "create", "--name", "testnotinuse1")
  77. dockerCmd(c, "volume", "create", "--name", "testisinuse1")
  78. dockerCmd(c, "volume", "create", "--name", "testisinuse2")
  79. // Make sure both "created" (but not started), and started
  80. // containers are included in reference counting
  81. dockerCmd(c, "run", "--name", "volume-test1", "-v", "testisinuse1:"+prefix+"/foo", "busybox", "true")
  82. dockerCmd(c, "create", "--name", "volume-test2", "-v", "testisinuse2:"+prefix+"/foo", "busybox", "true")
  83. out, _ := dockerCmd(c, "volume", "ls")
  84. // No filter, all volumes should show
  85. c.Assert(out, checker.Contains, "testnotinuse1\n", check.Commentf("expected volume 'testnotinuse1' in output"))
  86. c.Assert(out, checker.Contains, "testisinuse1\n", check.Commentf("expected volume 'testisinuse1' in output"))
  87. c.Assert(out, checker.Contains, "testisinuse2\n", check.Commentf("expected volume 'testisinuse2' in output"))
  88. out, _ = dockerCmd(c, "volume", "ls", "--filter", "dangling=false")
  89. // Same as above, but explicitly disabling dangling
  90. c.Assert(out, checker.Contains, "testnotinuse1\n", check.Commentf("expected volume 'testnotinuse1' in output"))
  91. c.Assert(out, checker.Contains, "testisinuse1\n", check.Commentf("expected volume 'testisinuse1' in output"))
  92. c.Assert(out, checker.Contains, "testisinuse2\n", check.Commentf("expected volume 'testisinuse2' in output"))
  93. out, _ = dockerCmd(c, "volume", "ls", "--filter", "dangling=true")
  94. // Filter "dangling" volumes; only "dangling" (unused) volumes should be in the output
  95. c.Assert(out, checker.Contains, "testnotinuse1\n", check.Commentf("expected volume 'testnotinuse1' in output"))
  96. c.Assert(out, check.Not(checker.Contains), "testisinuse1\n", check.Commentf("volume 'testisinuse1' in output, but not expected"))
  97. c.Assert(out, check.Not(checker.Contains), "testisinuse2\n", check.Commentf("volume 'testisinuse2' in output, but not expected"))
  98. }
  99. func (s *DockerSuite) TestVolumeCliRm(c *check.C) {
  100. prefix := ""
  101. if daemonPlatform == "windows" {
  102. prefix = "c:"
  103. }
  104. out, _ := dockerCmd(c, "volume", "create")
  105. id := strings.TrimSpace(out)
  106. dockerCmd(c, "volume", "create", "--name", "test")
  107. dockerCmd(c, "volume", "rm", id)
  108. dockerCmd(c, "volume", "rm", "test")
  109. out, _ = dockerCmd(c, "volume", "ls")
  110. outArr := strings.Split(strings.TrimSpace(out), "\n")
  111. c.Assert(len(outArr), check.Equals, 1, check.Commentf("%s\n", out))
  112. volumeID := "testing"
  113. dockerCmd(c, "run", "-v", volumeID+":"+prefix+"/foo", "--name=test", "busybox", "sh", "-c", "echo hello > /foo/bar")
  114. out, _, err := runCommandWithOutput(exec.Command(dockerBinary, "volume", "rm", "testing"))
  115. c.Assert(
  116. err,
  117. check.Not(check.IsNil),
  118. check.Commentf("Should not be able to remove volume that is in use by a container\n%s", out))
  119. out, _ = dockerCmd(c, "run", "--volumes-from=test", "--name=test2", "busybox", "sh", "-c", "cat /foo/bar")
  120. c.Assert(strings.TrimSpace(out), check.Equals, "hello")
  121. dockerCmd(c, "rm", "-fv", "test2")
  122. dockerCmd(c, "volume", "inspect", volumeID)
  123. dockerCmd(c, "rm", "-f", "test")
  124. out, _ = dockerCmd(c, "run", "--name=test2", "-v", volumeID+":"+prefix+"/foo", "busybox", "sh", "-c", "cat /foo/bar")
  125. c.Assert(strings.TrimSpace(out), check.Equals, "hello", check.Commentf("volume data was removed"))
  126. dockerCmd(c, "rm", "test2")
  127. dockerCmd(c, "volume", "rm", volumeID)
  128. c.Assert(
  129. exec.Command("volume", "rm", "doesntexist").Run(),
  130. check.Not(check.IsNil),
  131. check.Commentf("volume rm should fail with non-existent volume"),
  132. )
  133. }
  134. func (s *DockerSuite) TestVolumeCliNoArgs(c *check.C) {
  135. out, _ := dockerCmd(c, "volume")
  136. // no args should produce the cmd usage output
  137. usage := "Usage: docker volume [OPTIONS] [COMMAND]"
  138. c.Assert(out, checker.Contains, usage)
  139. // invalid arg should error and show the command usage on stderr
  140. _, stderr, _, err := runCommandWithStdoutStderr(exec.Command(dockerBinary, "volume", "somearg"))
  141. c.Assert(err, check.NotNil, check.Commentf(stderr))
  142. c.Assert(stderr, checker.Contains, usage)
  143. // invalid flag should error and show the flag error and cmd usage
  144. _, stderr, _, err = runCommandWithStdoutStderr(exec.Command(dockerBinary, "volume", "--no-such-flag"))
  145. c.Assert(err, check.NotNil, check.Commentf(stderr))
  146. c.Assert(stderr, checker.Contains, usage)
  147. c.Assert(stderr, checker.Contains, "flag provided but not defined: --no-such-flag")
  148. }
  149. func (s *DockerSuite) TestVolumeCliInspectTmplError(c *check.C) {
  150. out, _ := dockerCmd(c, "volume", "create")
  151. name := strings.TrimSpace(out)
  152. out, exitCode, err := dockerCmdWithError("volume", "inspect", "--format='{{ .FooBar }}'", name)
  153. c.Assert(err, checker.NotNil, check.Commentf("Output: %s", out))
  154. c.Assert(exitCode, checker.Equals, 1, check.Commentf("Output: %s", out))
  155. c.Assert(out, checker.Contains, "Template parsing error")
  156. }