docker_api_volumes_test.go 2.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. package main
  2. import (
  3. "encoding/json"
  4. "net/http"
  5. "path"
  6. "github.com/docker/docker/api/types"
  7. "github.com/go-check/check"
  8. )
  9. func (s *DockerSuite) TestVolumesApiList(c *check.C) {
  10. testRequires(c, DaemonIsLinux)
  11. dockerCmd(c, "run", "-d", "-v", "/foo", "busybox")
  12. status, b, err := sockRequest("GET", "/volumes", nil)
  13. c.Assert(err, check.IsNil)
  14. c.Assert(status, check.Equals, http.StatusOK)
  15. var volumes types.VolumesListResponse
  16. c.Assert(json.Unmarshal(b, &volumes), check.IsNil)
  17. c.Assert(len(volumes.Volumes), check.Equals, 1, check.Commentf("\n%v", volumes.Volumes))
  18. }
  19. func (s *DockerSuite) TestVolumesApiCreate(c *check.C) {
  20. testRequires(c, DaemonIsLinux)
  21. config := types.VolumeCreateRequest{
  22. Name: "test",
  23. }
  24. status, b, err := sockRequest("POST", "/volumes", config)
  25. c.Assert(err, check.IsNil)
  26. c.Assert(status, check.Equals, http.StatusCreated, check.Commentf(string(b)))
  27. var vol types.Volume
  28. err = json.Unmarshal(b, &vol)
  29. c.Assert(err, check.IsNil)
  30. c.Assert(path.Base(path.Dir(vol.Mountpoint)), check.Equals, config.Name)
  31. }
  32. func (s *DockerSuite) TestVolumesApiRemove(c *check.C) {
  33. testRequires(c, DaemonIsLinux)
  34. dockerCmd(c, "run", "-d", "-v", "/foo", "--name=test", "busybox")
  35. status, b, err := sockRequest("GET", "/volumes", nil)
  36. c.Assert(err, check.IsNil)
  37. c.Assert(status, check.Equals, http.StatusOK)
  38. var volumes types.VolumesListResponse
  39. c.Assert(json.Unmarshal(b, &volumes), check.IsNil)
  40. c.Assert(len(volumes.Volumes), check.Equals, 1, check.Commentf("\n%v", volumes.Volumes))
  41. v := volumes.Volumes[0]
  42. status, _, err = sockRequest("DELETE", "/volumes/"+v.Name, nil)
  43. c.Assert(err, check.IsNil)
  44. c.Assert(status, check.Equals, http.StatusConflict, check.Commentf("Should not be able to remove a volume that is in use"))
  45. dockerCmd(c, "rm", "-f", "test")
  46. status, data, err := sockRequest("DELETE", "/volumes/"+v.Name, nil)
  47. c.Assert(err, check.IsNil)
  48. c.Assert(status, check.Equals, http.StatusNoContent, check.Commentf(string(data)))
  49. }
  50. func (s *DockerSuite) TestVolumesApiInspect(c *check.C) {
  51. testRequires(c, DaemonIsLinux)
  52. config := types.VolumeCreateRequest{
  53. Name: "test",
  54. }
  55. status, b, err := sockRequest("POST", "/volumes", config)
  56. c.Assert(err, check.IsNil)
  57. c.Assert(status, check.Equals, http.StatusCreated, check.Commentf(string(b)))
  58. status, b, err = sockRequest("GET", "/volumes", nil)
  59. c.Assert(err, check.IsNil)
  60. c.Assert(status, check.Equals, http.StatusOK, check.Commentf(string(b)))
  61. var volumes types.VolumesListResponse
  62. c.Assert(json.Unmarshal(b, &volumes), check.IsNil)
  63. c.Assert(len(volumes.Volumes), check.Equals, 1, check.Commentf("\n%v", volumes.Volumes))
  64. var vol types.Volume
  65. status, b, err = sockRequest("GET", "/volumes/"+config.Name, nil)
  66. c.Assert(err, check.IsNil)
  67. c.Assert(status, check.Equals, http.StatusOK, check.Commentf(string(b)))
  68. c.Assert(json.Unmarshal(b, &vol), check.IsNil)
  69. c.Assert(vol.Name, check.Equals, config.Name)
  70. }