2015-05-14 06:42:16 +08:00
|
|
|
// +build linux
|
|
|
|
|
2014-05-28 08:01:08 +08:00
|
|
|
package fs
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"testing"
|
|
|
|
|
2015-06-22 10:29:59 +08:00
|
|
|
"github.com/opencontainers/runc/libcontainer/cgroups"
|
2017-07-19 22:28:59 +08:00
|
|
|
|
|
|
|
"github.com/sirupsen/logrus"
|
2014-05-28 08:01:08 +08:00
|
|
|
)
|
|
|
|
|
|
|
|
func blkioStatEntryEquals(expected, actual []cgroups.BlkioStatEntry) error {
|
|
|
|
if len(expected) != len(actual) {
|
|
|
|
return fmt.Errorf("blkioStatEntries length do not match")
|
|
|
|
}
|
|
|
|
for i, expValue := range expected {
|
|
|
|
actValue := actual[i]
|
|
|
|
if expValue != actValue {
|
|
|
|
return fmt.Errorf("Expected blkio stat entry %v but found %v", expValue, actValue)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func expectBlkioStatsEquals(t *testing.T, expected, actual cgroups.BlkioStats) {
|
|
|
|
if err := blkioStatEntryEquals(expected.IoServiceBytesRecursive, actual.IoServiceBytesRecursive); err != nil {
|
2015-05-06 21:14:04 +08:00
|
|
|
logrus.Printf("blkio IoServiceBytesRecursive do not match - %s\n", err)
|
2014-05-28 08:01:08 +08:00
|
|
|
t.Fail()
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := blkioStatEntryEquals(expected.IoServicedRecursive, actual.IoServicedRecursive); err != nil {
|
2015-05-06 21:14:04 +08:00
|
|
|
logrus.Printf("blkio IoServicedRecursive do not match - %s\n", err)
|
2014-05-28 08:01:08 +08:00
|
|
|
t.Fail()
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := blkioStatEntryEquals(expected.IoQueuedRecursive, actual.IoQueuedRecursive); err != nil {
|
2015-05-06 21:14:04 +08:00
|
|
|
logrus.Printf("blkio IoQueuedRecursive do not match - %s\n", err)
|
2014-05-28 08:01:08 +08:00
|
|
|
t.Fail()
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := blkioStatEntryEquals(expected.SectorsRecursive, actual.SectorsRecursive); err != nil {
|
2015-05-06 21:14:04 +08:00
|
|
|
logrus.Printf("blkio SectorsRecursive do not match - %s\n", err)
|
2014-05-28 08:01:08 +08:00
|
|
|
t.Fail()
|
|
|
|
}
|
2014-10-20 17:25:03 +08:00
|
|
|
|
|
|
|
if err := blkioStatEntryEquals(expected.IoServiceTimeRecursive, actual.IoServiceTimeRecursive); err != nil {
|
2015-05-06 21:14:04 +08:00
|
|
|
logrus.Printf("blkio IoServiceTimeRecursive do not match - %s\n", err)
|
2014-10-20 17:25:03 +08:00
|
|
|
t.Fail()
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := blkioStatEntryEquals(expected.IoWaitTimeRecursive, actual.IoWaitTimeRecursive); err != nil {
|
2015-05-06 21:14:04 +08:00
|
|
|
logrus.Printf("blkio IoWaitTimeRecursive do not match - %s\n", err)
|
2014-10-20 17:25:03 +08:00
|
|
|
t.Fail()
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := blkioStatEntryEquals(expected.IoMergedRecursive, actual.IoMergedRecursive); err != nil {
|
2015-05-06 21:14:04 +08:00
|
|
|
logrus.Printf("blkio IoMergedRecursive do not match - %v vs %v\n", expected.IoMergedRecursive, actual.IoMergedRecursive)
|
2014-10-20 17:25:03 +08:00
|
|
|
t.Fail()
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := blkioStatEntryEquals(expected.IoTimeRecursive, actual.IoTimeRecursive); err != nil {
|
2015-05-06 21:14:04 +08:00
|
|
|
logrus.Printf("blkio IoTimeRecursive do not match - %s\n", err)
|
2014-10-20 17:25:03 +08:00
|
|
|
t.Fail()
|
|
|
|
}
|
2014-05-28 08:01:08 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
func expectThrottlingDataEquals(t *testing.T, expected, actual cgroups.ThrottlingData) {
|
|
|
|
if expected != actual {
|
2015-05-06 21:14:04 +08:00
|
|
|
logrus.Printf("Expected throttling data %v but found %v\n", expected, actual)
|
2014-05-28 08:01:08 +08:00
|
|
|
t.Fail()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-04-27 16:34:36 +08:00
|
|
|
func expectHugetlbStatEquals(t *testing.T, expected, actual cgroups.HugetlbStats) {
|
|
|
|
if expected != actual {
|
|
|
|
logrus.Printf("Expected hugetlb stats %v but found %v\n", expected, actual)
|
|
|
|
t.Fail()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-05-28 08:01:08 +08:00
|
|
|
func expectMemoryStatEquals(t *testing.T, expected, actual cgroups.MemoryStats) {
|
2015-05-15 17:37:58 +08:00
|
|
|
expectMemoryDataEquals(t, expected.Usage, actual.Usage)
|
|
|
|
expectMemoryDataEquals(t, expected.SwapUsage, actual.SwapUsage)
|
|
|
|
expectMemoryDataEquals(t, expected.KernelUsage, actual.KernelUsage)
|
|
|
|
|
2017-03-21 04:16:00 +08:00
|
|
|
if expected.UseHierarchy != actual.UseHierarchy {
|
|
|
|
logrus.Printf("Expected memory use hiearchy %v, but found %v\n", expected.UseHierarchy, actual.UseHierarchy)
|
|
|
|
t.Fail()
|
|
|
|
}
|
|
|
|
|
2014-05-28 08:01:08 +08:00
|
|
|
for key, expValue := range expected.Stats {
|
|
|
|
actValue, ok := actual.Stats[key]
|
|
|
|
if !ok {
|
2015-05-06 21:14:04 +08:00
|
|
|
logrus.Printf("Expected memory stat key %s not found\n", key)
|
2014-05-28 08:01:08 +08:00
|
|
|
t.Fail()
|
|
|
|
}
|
|
|
|
if expValue != actValue {
|
2015-05-06 21:14:04 +08:00
|
|
|
logrus.Printf("Expected memory stat value %d but found %d\n", expValue, actValue)
|
2014-05-28 08:01:08 +08:00
|
|
|
t.Fail()
|
|
|
|
}
|
|
|
|
}
|
2015-05-15 17:37:58 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
func expectMemoryDataEquals(t *testing.T, expected, actual cgroups.MemoryData) {
|
|
|
|
if expected.Usage != actual.Usage {
|
|
|
|
logrus.Printf("Expected memory usage %d but found %d\n", expected.Usage, actual.Usage)
|
|
|
|
t.Fail()
|
|
|
|
}
|
|
|
|
if expected.MaxUsage != actual.MaxUsage {
|
|
|
|
logrus.Printf("Expected memory max usage %d but found %d\n", expected.MaxUsage, actual.MaxUsage)
|
|
|
|
t.Fail()
|
|
|
|
}
|
2014-12-12 08:27:06 +08:00
|
|
|
if expected.Failcnt != actual.Failcnt {
|
2015-05-06 21:14:04 +08:00
|
|
|
logrus.Printf("Expected memory failcnt %d but found %d\n", expected.Failcnt, actual.Failcnt)
|
2014-12-12 08:27:06 +08:00
|
|
|
t.Fail()
|
|
|
|
}
|
2016-02-04 03:00:48 +08:00
|
|
|
if expected.Limit != actual.Limit {
|
|
|
|
logrus.Printf("Expected memory limit %d but found %d\n", expected.Limit, actual.Limit)
|
|
|
|
t.Fail()
|
|
|
|
}
|
2014-05-28 08:01:08 +08:00
|
|
|
}
|