docker_cli_stats_test.go 830 B

123456789101112131415161718192021222324252627282930313233343536
  1. package main
  2. import (
  3. "os/exec"
  4. "strings"
  5. "time"
  6. "github.com/go-check/check"
  7. )
  8. func (s *DockerSuite) TestCliStatsNoStream(c *check.C) {
  9. out, _, err := runCommandWithOutput(exec.Command(dockerBinary, "run", "-d", "busybox", "top"))
  10. if err != nil {
  11. c.Fatalf("Error on container creation: %v, output: %s", err, out)
  12. }
  13. id := strings.TrimSpace(out)
  14. if err := waitRun(id); err != nil {
  15. c.Fatalf("error waiting for container to start: %v", err)
  16. }
  17. statsCmd := exec.Command(dockerBinary, "stats", "--no-stream", id)
  18. chErr := make(chan error)
  19. go func() {
  20. chErr <- statsCmd.Run()
  21. }()
  22. select {
  23. case err := <-chErr:
  24. if err != nil {
  25. c.Fatalf("Error running stats: %v", err)
  26. }
  27. case <-time.After(2 * time.Second):
  28. statsCmd.Process.Kill()
  29. c.Fatalf("stats did not return immediately when not streaming")
  30. }
  31. }