Merge pull request #13645 from calavera/fix_stats_flaky_test

Fix stats flaky test.
This commit is contained in:
David Calavera 2015-06-03 12:05:43 -07:00
Родитель 521926f6c4 4fde1cb695
Коммит c962f53a3e
1 изменённых файлов: 16 добавлений и 31 удалений

Просмотреть файл

@ -3,46 +3,31 @@ package main
import ( import (
"encoding/json" "encoding/json"
"fmt" "fmt"
"strings"
"github.com/docker/docker/api/types" "github.com/docker/docker/api/types"
"github.com/go-check/check" "github.com/go-check/check"
"strings"
"time"
) )
func (s *DockerSuite) TestCliStatsNoStreamGetCpu(c *check.C) { func (s *DockerSuite) TestCliStatsNoStreamGetCpu(c *check.C) {
out, _ := dockerCmd(c, "run", "-d", "--cpu-quota=2000", "busybox", "/bin/sh", "-c", "while true;do echo 'Hello';done") out, _ := dockerCmd(c, "run", "-d", "--cpu-quota=2000", "busybox", "/bin/sh", "-c", "while true;do echo 'Hello';done")
id := strings.TrimSpace(out) id := strings.TrimSpace(out)
if err := waitRun(id); err != nil { err := waitRun(id)
c.Fatal(err) c.Assert(err, check.IsNil)
}
ch := make(chan error) _, body, err := sockRequestRaw("GET", fmt.Sprintf("/containers/%s/stats?stream=false", id), nil, "")
c.Assert(err, check.IsNil)
var v *types.Stats var v *types.Stats
go func() { err = json.NewDecoder(body).Decode(&v)
_, body, err := sockRequestRaw("GET", fmt.Sprintf("/containers/%s/stats?stream=1", id), nil, "") c.Assert(err, check.IsNil)
if err != nil {
ch <- err
}
dec := json.NewDecoder(body)
if err := dec.Decode(&v); err != nil {
ch <- err
}
ch <- nil
}()
select {
case e := <-ch:
if e == nil {
var cpuPercent = 0.0
cpuDelta := float64(v.CpuStats.CpuUsage.TotalUsage - v.PreCpuStats.CpuUsage.TotalUsage)
systemDelta := float64(v.CpuStats.SystemUsage - v.PreCpuStats.SystemUsage)
cpuPercent = (cpuDelta / systemDelta) * float64(len(v.CpuStats.CpuUsage.PercpuUsage)) * 100.0
if cpuPercent < 1.8 || cpuPercent > 2.2 {
c.Fatal("docker stats with no-stream get cpu usage failed")
}
} var cpuPercent = 0.0
case <-time.After(4 * time.Second): cpuDelta := float64(v.CpuStats.CpuUsage.TotalUsage - v.PreCpuStats.CpuUsage.TotalUsage)
c.Fatal("docker stats with no-stream timeout") systemDelta := float64(v.CpuStats.SystemUsage - v.PreCpuStats.SystemUsage)
cpuPercent = (cpuDelta / systemDelta) * float64(len(v.CpuStats.CpuUsage.PercpuUsage)) * 100.0
if cpuPercent == 0 {
c.Fatalf("docker stats with no-stream get cpu usage failed: was %v", cpuPercent)
} }
} }