docker_cli_pause_test.go 2.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. package main
  2. import (
  3. "fmt"
  4. "strings"
  5. "github.com/go-check/check"
  6. )
  7. func (s *DockerSuite) TestPause(c *check.C) {
  8. testRequires(c, DaemonIsLinux)
  9. defer unpauseAllContainers()
  10. name := "testeventpause"
  11. dockerCmd(c, "run", "-d", "--name", name, "busybox", "top")
  12. dockerCmd(c, "pause", name)
  13. pausedContainers, err := getSliceOfPausedContainers()
  14. if err != nil {
  15. c.Fatalf("error thrown while checking if containers were paused: %v", err)
  16. }
  17. if len(pausedContainers) != 1 {
  18. c.Fatalf("there should be one paused container and not %d", len(pausedContainers))
  19. }
  20. dockerCmd(c, "unpause", name)
  21. out, _ := dockerCmd(c, "events", "--since=0", fmt.Sprintf("--until=%d", daemonTime(c).Unix()))
  22. events := strings.Split(out, "\n")
  23. if len(events) <= 1 {
  24. c.Fatalf("Missing expected event")
  25. }
  26. pauseEvent := strings.Fields(events[len(events)-3])
  27. unpauseEvent := strings.Fields(events[len(events)-2])
  28. if pauseEvent[len(pauseEvent)-1] != "pause" {
  29. c.Fatalf("event should be pause, not %#v", pauseEvent)
  30. }
  31. if unpauseEvent[len(unpauseEvent)-1] != "unpause" {
  32. c.Fatalf("event should be unpause, not %#v", unpauseEvent)
  33. }
  34. }
  35. func (s *DockerSuite) TestPauseMultipleContainers(c *check.C) {
  36. testRequires(c, DaemonIsLinux)
  37. defer unpauseAllContainers()
  38. containers := []string{
  39. "testpausewithmorecontainers1",
  40. "testpausewithmorecontainers2",
  41. }
  42. for _, name := range containers {
  43. dockerCmd(c, "run", "-d", "--name", name, "busybox", "top")
  44. }
  45. dockerCmd(c, append([]string{"pause"}, containers...)...)
  46. pausedContainers, err := getSliceOfPausedContainers()
  47. if err != nil {
  48. c.Fatalf("error thrown while checking if containers were paused: %v", err)
  49. }
  50. if len(pausedContainers) != len(containers) {
  51. c.Fatalf("there should be %d paused container and not %d", len(containers), len(pausedContainers))
  52. }
  53. dockerCmd(c, append([]string{"unpause"}, containers...)...)
  54. out, _ := dockerCmd(c, "events", "--since=0", fmt.Sprintf("--until=%d", daemonTime(c).Unix()))
  55. events := strings.Split(out, "\n")
  56. if len(events) <= len(containers)*3-2 {
  57. c.Fatalf("Missing expected event")
  58. }
  59. pauseEvents := make([][]string, len(containers))
  60. unpauseEvents := make([][]string, len(containers))
  61. for i := range containers {
  62. pauseEvents[i] = strings.Fields(events[len(events)-len(containers)*2-1+i])
  63. unpauseEvents[i] = strings.Fields(events[len(events)-len(containers)-1+i])
  64. }
  65. for _, pauseEvent := range pauseEvents {
  66. if pauseEvent[len(pauseEvent)-1] != "pause" {
  67. c.Fatalf("event should be pause, not %#v", pauseEvent)
  68. }
  69. }
  70. for _, unpauseEvent := range unpauseEvents {
  71. if unpauseEvent[len(unpauseEvent)-1] != "unpause" {
  72. c.Fatalf("event should be unpause, not %#v", unpauseEvent)
  73. }
  74. }
  75. }