2015-04-01 16:34:32 +00:00
|
|
|
package system
|
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
|
|
|
|
2015-04-06 16:32:10 +00:00
|
|
|
"github.com/influxdb/tivan/plugins/system/ps/cpu"
|
2015-04-06 17:34:55 +00:00
|
|
|
"github.com/influxdb/tivan/plugins/system/ps/disk"
|
2015-04-04 00:22:31 +00:00
|
|
|
"github.com/influxdb/tivan/plugins/system/ps/load"
|
2015-04-06 21:53:43 +00:00
|
|
|
"github.com/influxdb/tivan/plugins/system/ps/mem"
|
2015-04-06 17:44:32 +00:00
|
|
|
"github.com/influxdb/tivan/plugins/system/ps/net"
|
2015-04-06 16:32:10 +00:00
|
|
|
"github.com/influxdb/tivan/testutil"
|
2015-04-01 16:34:32 +00:00
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
)
|
|
|
|
|
2015-04-06 16:32:10 +00:00
|
|
|
func TestSystemStats_GenerateStats(t *testing.T) {
|
2015-04-01 16:34:32 +00:00
|
|
|
var mps MockPS
|
|
|
|
|
2015-04-04 00:22:31 +00:00
|
|
|
defer mps.AssertExpectations(t)
|
2015-04-01 16:34:32 +00:00
|
|
|
|
2015-04-06 16:32:10 +00:00
|
|
|
var acc testutil.Accumulator
|
|
|
|
|
2015-04-04 00:22:31 +00:00
|
|
|
ss := &SystemStats{ps: &mps}
|
2015-04-01 16:34:32 +00:00
|
|
|
|
2015-04-04 00:22:31 +00:00
|
|
|
lv := &load.LoadAvgStat{
|
|
|
|
Load1: 0.3,
|
|
|
|
Load5: 1.5,
|
|
|
|
Load15: 0.8,
|
|
|
|
}
|
2015-04-01 16:34:32 +00:00
|
|
|
|
2015-04-04 00:22:31 +00:00
|
|
|
mps.On("LoadAvg").Return(lv, nil)
|
2015-04-01 16:34:32 +00:00
|
|
|
|
2015-04-06 16:32:10 +00:00
|
|
|
cts := cpu.CPUTimesStat{
|
|
|
|
CPU: "all",
|
|
|
|
User: 3.1,
|
|
|
|
System: 8.2,
|
|
|
|
Idle: 80.1,
|
|
|
|
Nice: 1.3,
|
|
|
|
Iowait: 0.2,
|
|
|
|
Irq: 0.1,
|
|
|
|
Softirq: 0.11,
|
|
|
|
Steal: 0.0001,
|
|
|
|
Guest: 8.1,
|
|
|
|
GuestNice: 0.324,
|
|
|
|
Stolen: 0.051,
|
2015-04-04 00:22:31 +00:00
|
|
|
}
|
2015-04-01 16:34:32 +00:00
|
|
|
|
2015-04-06 16:32:10 +00:00
|
|
|
mps.On("CPUTimes").Return([]cpu.CPUTimesStat{cts}, nil)
|
2015-04-01 16:34:32 +00:00
|
|
|
|
2015-04-06 17:34:55 +00:00
|
|
|
du := &disk.DiskUsageStat{
|
|
|
|
Path: "/",
|
|
|
|
Total: 128,
|
|
|
|
Free: 23,
|
|
|
|
InodesTotal: 1234,
|
|
|
|
InodesFree: 234,
|
|
|
|
}
|
|
|
|
|
|
|
|
mps.On("DiskUsage").Return([]*disk.DiskUsageStat{du}, nil)
|
|
|
|
|
2015-04-06 17:59:05 +00:00
|
|
|
diskio := disk.DiskIOCountersStat{
|
|
|
|
ReadCount: 888,
|
|
|
|
WriteCount: 5341,
|
|
|
|
ReadBytes: 100000,
|
|
|
|
WriteBytes: 200000,
|
|
|
|
ReadTime: 7123,
|
|
|
|
WriteTime: 9087,
|
|
|
|
Name: "sda1",
|
|
|
|
IoTime: 123552,
|
|
|
|
SerialNumber: "ab-123-ad",
|
|
|
|
}
|
|
|
|
|
|
|
|
mps.On("DiskIO").Return(map[string]disk.DiskIOCountersStat{"sda1": diskio}, nil)
|
|
|
|
|
2015-04-06 17:44:32 +00:00
|
|
|
netio := net.NetIOCountersStat{
|
|
|
|
Name: "eth0",
|
|
|
|
BytesSent: 1123,
|
|
|
|
BytesRecv: 8734422,
|
|
|
|
PacketsSent: 781,
|
|
|
|
PacketsRecv: 23456,
|
|
|
|
Errin: 832,
|
|
|
|
Errout: 8,
|
|
|
|
Dropin: 7,
|
|
|
|
Dropout: 1,
|
|
|
|
}
|
|
|
|
|
|
|
|
mps.On("NetIO").Return([]net.NetIOCountersStat{netio}, nil)
|
|
|
|
|
2015-04-06 21:53:43 +00:00
|
|
|
vms := &mem.VirtualMemoryStat{
|
|
|
|
Total: 12400,
|
|
|
|
Available: 7600,
|
|
|
|
Used: 5000,
|
|
|
|
UsedPercent: 47.1,
|
|
|
|
Free: 1235,
|
|
|
|
Active: 8134,
|
|
|
|
Inactive: 1124,
|
|
|
|
Buffers: 771,
|
|
|
|
Cached: 4312,
|
|
|
|
Wired: 134,
|
|
|
|
Shared: 2142,
|
|
|
|
}
|
|
|
|
|
|
|
|
mps.On("VMStat").Return(vms, nil)
|
|
|
|
|
|
|
|
sms := &mem.SwapMemoryStat{
|
|
|
|
Total: 8123,
|
|
|
|
Used: 1232,
|
|
|
|
Free: 6412,
|
|
|
|
UsedPercent: 12.2,
|
|
|
|
Sin: 7,
|
|
|
|
Sout: 830,
|
|
|
|
}
|
|
|
|
|
|
|
|
mps.On("SwapStat").Return(sms, nil)
|
|
|
|
|
2015-04-06 16:32:10 +00:00
|
|
|
err := ss.Gather(&acc)
|
2015-04-04 00:22:31 +00:00
|
|
|
require.NoError(t, err)
|
2015-04-01 16:34:32 +00:00
|
|
|
|
2015-04-06 16:32:10 +00:00
|
|
|
assert.True(t, acc.CheckValue("load1", 0.3))
|
|
|
|
assert.True(t, acc.CheckValue("load5", 1.5))
|
|
|
|
assert.True(t, acc.CheckValue("load15", 0.8))
|
|
|
|
|
|
|
|
assert.True(t, acc.CheckValue("all.user", 3.1))
|
|
|
|
assert.True(t, acc.CheckValue("all.system", 8.2))
|
|
|
|
assert.True(t, acc.CheckValue("all.idle", 80.1))
|
|
|
|
assert.True(t, acc.CheckValue("all.nice", 1.3))
|
|
|
|
assert.True(t, acc.CheckValue("all.iowait", 0.2))
|
|
|
|
assert.True(t, acc.CheckValue("all.irq", 0.1))
|
|
|
|
assert.True(t, acc.CheckValue("all.softirq", 0.11))
|
|
|
|
assert.True(t, acc.CheckValue("all.steal", 0.0001))
|
|
|
|
assert.True(t, acc.CheckValue("all.guest", 8.1))
|
|
|
|
assert.True(t, acc.CheckValue("all.guestNice", 0.324))
|
|
|
|
assert.True(t, acc.CheckValue("all.stolen", 0.051))
|
2015-04-06 17:34:55 +00:00
|
|
|
|
|
|
|
tags := map[string]string{
|
|
|
|
"path": "/",
|
|
|
|
}
|
|
|
|
|
|
|
|
assert.True(t, acc.CheckTaggedValue("total", uint64(128), tags))
|
|
|
|
assert.True(t, acc.CheckTaggedValue("used", uint64(105), tags))
|
|
|
|
assert.True(t, acc.CheckTaggedValue("free", uint64(23), tags))
|
|
|
|
assert.True(t, acc.CheckTaggedValue("inodes_total", uint64(1234), tags))
|
|
|
|
assert.True(t, acc.CheckTaggedValue("inodes_free", uint64(234), tags))
|
|
|
|
assert.True(t, acc.CheckTaggedValue("inodes_used", uint64(1000), tags))
|
2015-04-06 17:44:32 +00:00
|
|
|
|
|
|
|
ntags := map[string]string{
|
|
|
|
"interface": "eth0",
|
|
|
|
}
|
|
|
|
|
|
|
|
assert.True(t, acc.CheckTaggedValue("bytes_sent", uint64(1123), ntags))
|
|
|
|
assert.True(t, acc.CheckTaggedValue("bytes_recv", uint64(8734422), ntags))
|
|
|
|
assert.True(t, acc.CheckTaggedValue("packets_sent", uint64(781), ntags))
|
|
|
|
assert.True(t, acc.CheckTaggedValue("packets_recv", uint64(23456), ntags))
|
|
|
|
assert.True(t, acc.CheckTaggedValue("err_in", uint64(832), ntags))
|
|
|
|
assert.True(t, acc.CheckTaggedValue("err_out", uint64(8), ntags))
|
|
|
|
assert.True(t, acc.CheckTaggedValue("drop_in", uint64(7), ntags))
|
|
|
|
assert.True(t, acc.CheckTaggedValue("drop_out", uint64(1), ntags))
|
2015-04-06 17:59:05 +00:00
|
|
|
|
|
|
|
dtags := map[string]string{
|
|
|
|
"name": "sda1",
|
|
|
|
"serial": "ab-123-ad",
|
|
|
|
}
|
|
|
|
|
|
|
|
assert.True(t, acc.CheckTaggedValue("reads", uint64(888), dtags))
|
|
|
|
assert.True(t, acc.CheckTaggedValue("writes", uint64(5341), dtags))
|
|
|
|
assert.True(t, acc.CheckTaggedValue("read_bytes", uint64(100000), dtags))
|
|
|
|
assert.True(t, acc.CheckTaggedValue("write_bytes", uint64(200000), dtags))
|
|
|
|
assert.True(t, acc.CheckTaggedValue("read_time", uint64(7123), dtags))
|
|
|
|
assert.True(t, acc.CheckTaggedValue("write_time", uint64(9087), dtags))
|
|
|
|
assert.True(t, acc.CheckTaggedValue("io_time", uint64(123552), dtags))
|
2015-04-06 21:53:43 +00:00
|
|
|
|
|
|
|
vmtags := map[string]string{
|
|
|
|
"memory": "virtual",
|
|
|
|
}
|
|
|
|
|
|
|
|
assert.NoError(t, acc.ValidateTaggedValue("total", uint64(12400), vmtags))
|
|
|
|
assert.True(t, acc.CheckTaggedValue("total", uint64(12400), vmtags))
|
|
|
|
assert.True(t, acc.CheckTaggedValue("available", uint64(7600), vmtags))
|
|
|
|
assert.True(t, acc.CheckTaggedValue("used", uint64(5000), vmtags))
|
|
|
|
assert.True(t, acc.CheckTaggedValue("used_prec", float64(47.1), vmtags))
|
|
|
|
assert.True(t, acc.CheckTaggedValue("free", uint64(1235), vmtags))
|
|
|
|
assert.True(t, acc.CheckTaggedValue("active", uint64(8134), vmtags))
|
|
|
|
assert.True(t, acc.CheckTaggedValue("inactive", uint64(1124), vmtags))
|
|
|
|
assert.True(t, acc.CheckTaggedValue("buffers", uint64(771), vmtags))
|
|
|
|
assert.True(t, acc.CheckTaggedValue("cached", uint64(4312), vmtags))
|
|
|
|
assert.True(t, acc.CheckTaggedValue("wired", uint64(134), vmtags))
|
|
|
|
assert.True(t, acc.CheckTaggedValue("shared", uint64(2142), vmtags))
|
|
|
|
|
|
|
|
swaptags := map[string]string{
|
|
|
|
"memory": "swap",
|
|
|
|
}
|
|
|
|
|
|
|
|
assert.True(t, acc.CheckTaggedValue("total", uint64(8123), swaptags))
|
|
|
|
assert.True(t, acc.CheckTaggedValue("used", uint64(1232), swaptags))
|
|
|
|
assert.True(t, acc.CheckTaggedValue("used_perc", float64(12.2), swaptags))
|
|
|
|
assert.True(t, acc.CheckTaggedValue("free", uint64(6412), swaptags))
|
|
|
|
assert.True(t, acc.CheckTaggedValue("swap_in", uint64(7), swaptags))
|
|
|
|
assert.True(t, acc.CheckTaggedValue("swap_out", uint64(830), swaptags))
|
2015-04-01 16:34:32 +00:00
|
|
|
}
|