162 lines
5.2 KiB
Go
162 lines
5.2 KiB
Go
package system
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/influxdb/telegraf/testutil"
|
|
"github.com/shirou/gopsutil/disk"
|
|
"github.com/stretchr/testify/assert"
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
func TestDiskStats(t *testing.T) {
|
|
var mps MockPS
|
|
defer mps.AssertExpectations(t)
|
|
var acc testutil.Accumulator
|
|
var err error
|
|
|
|
du := []*disk.DiskUsageStat{
|
|
{
|
|
Path: "/",
|
|
Fstype: "ext4",
|
|
Total: 128,
|
|
Free: 23,
|
|
InodesTotal: 1234,
|
|
InodesFree: 234,
|
|
},
|
|
{
|
|
Path: "/home",
|
|
Fstype: "ext4",
|
|
Total: 256,
|
|
Free: 46,
|
|
InodesTotal: 2468,
|
|
InodesFree: 468,
|
|
},
|
|
}
|
|
|
|
mps.On("DiskUsage").Return(du, nil)
|
|
|
|
err = (&DiskStats{ps: &mps}).Gather(&acc)
|
|
require.NoError(t, err)
|
|
|
|
numDiskPoints := len(acc.Points)
|
|
expectedAllDiskPoints := 12
|
|
assert.Equal(t, expectedAllDiskPoints, numDiskPoints)
|
|
|
|
tags1 := map[string]string{
|
|
"path": "/",
|
|
"fstype": "ext4",
|
|
}
|
|
tags2 := map[string]string{
|
|
"path": "/home",
|
|
"fstype": "ext4",
|
|
}
|
|
|
|
assert.True(t, acc.CheckTaggedValue("total", uint64(128), tags1))
|
|
assert.True(t, acc.CheckTaggedValue("used", uint64(105), tags1))
|
|
assert.True(t, acc.CheckTaggedValue("free", uint64(23), tags1))
|
|
assert.True(t, acc.CheckTaggedValue("inodes_total", uint64(1234), tags1))
|
|
assert.True(t, acc.CheckTaggedValue("inodes_free", uint64(234), tags1))
|
|
assert.True(t, acc.CheckTaggedValue("inodes_used", uint64(1000), tags1))
|
|
assert.True(t, acc.CheckTaggedValue("total", uint64(256), tags2))
|
|
assert.True(t, acc.CheckTaggedValue("used", uint64(210), tags2))
|
|
assert.True(t, acc.CheckTaggedValue("free", uint64(46), tags2))
|
|
assert.True(t, acc.CheckTaggedValue("inodes_total", uint64(2468), tags2))
|
|
assert.True(t, acc.CheckTaggedValue("inodes_free", uint64(468), tags2))
|
|
assert.True(t, acc.CheckTaggedValue("inodes_used", uint64(2000), tags2))
|
|
|
|
// We expect 6 more DiskPoints to show up with an explicit match on "/"
|
|
// and /home not matching the /dev in Mountpoints
|
|
err = (&DiskStats{ps: &mps, Mountpoints: []string{"/", "/dev"}}).Gather(&acc)
|
|
assert.Equal(t, expectedAllDiskPoints+6, len(acc.Points))
|
|
|
|
// We should see all the diskpoints as Mountpoints includes both
|
|
// / and /home
|
|
err = (&DiskStats{ps: &mps, Mountpoints: []string{"/", "/home"}}).Gather(&acc)
|
|
assert.Equal(t, 2*expectedAllDiskPoints+6, len(acc.Points))
|
|
|
|
}
|
|
|
|
func TestDiskIOStats(t *testing.T) {
|
|
var mps MockPS
|
|
defer mps.AssertExpectations(t)
|
|
var acc testutil.Accumulator
|
|
var err error
|
|
|
|
diskio1 := disk.DiskIOCountersStat{
|
|
|
|
ReadCount: 888,
|
|
WriteCount: 5341,
|
|
ReadBytes: 100000,
|
|
WriteBytes: 200000,
|
|
ReadTime: 7123,
|
|
WriteTime: 9087,
|
|
Name: "sda1",
|
|
IoTime: 123552,
|
|
SerialNumber: "ab-123-ad",
|
|
}
|
|
diskio2 := disk.DiskIOCountersStat{
|
|
ReadCount: 444,
|
|
WriteCount: 2341,
|
|
ReadBytes: 200000,
|
|
WriteBytes: 400000,
|
|
ReadTime: 3123,
|
|
WriteTime: 6087,
|
|
Name: "sdb1",
|
|
IoTime: 246552,
|
|
SerialNumber: "bb-123-ad",
|
|
}
|
|
|
|
mps.On("DiskIO").Return(
|
|
map[string]disk.DiskIOCountersStat{"sda1": diskio1, "sdb1": diskio2},
|
|
nil)
|
|
|
|
err = (&DiskIOStats{ps: &mps}).Gather(&acc)
|
|
require.NoError(t, err)
|
|
|
|
numDiskIOPoints := len(acc.Points)
|
|
expectedAllDiskIOPoints := 14
|
|
assert.Equal(t, expectedAllDiskIOPoints, numDiskIOPoints)
|
|
|
|
dtags1 := map[string]string{
|
|
"name": "sda1",
|
|
"serial": "ab-123-ad",
|
|
}
|
|
dtags2 := map[string]string{
|
|
"name": "sdb1",
|
|
"serial": "bb-123-ad",
|
|
}
|
|
|
|
assert.True(t, acc.CheckTaggedValue("reads", uint64(888), dtags1))
|
|
assert.True(t, acc.CheckTaggedValue("writes", uint64(5341), dtags1))
|
|
assert.True(t, acc.CheckTaggedValue("read_bytes", uint64(100000), dtags1))
|
|
assert.True(t, acc.CheckTaggedValue("write_bytes", uint64(200000), dtags1))
|
|
assert.True(t, acc.CheckTaggedValue("read_time", uint64(7123), dtags1))
|
|
assert.True(t, acc.CheckTaggedValue("write_time", uint64(9087), dtags1))
|
|
assert.True(t, acc.CheckTaggedValue("io_time", uint64(123552), dtags1))
|
|
assert.True(t, acc.CheckTaggedValue("reads", uint64(444), dtags2))
|
|
assert.True(t, acc.CheckTaggedValue("writes", uint64(2341), dtags2))
|
|
assert.True(t, acc.CheckTaggedValue("read_bytes", uint64(200000), dtags2))
|
|
assert.True(t, acc.CheckTaggedValue("write_bytes", uint64(400000), dtags2))
|
|
assert.True(t, acc.CheckTaggedValue("read_time", uint64(3123), dtags2))
|
|
assert.True(t, acc.CheckTaggedValue("write_time", uint64(6087), dtags2))
|
|
assert.True(t, acc.CheckTaggedValue("io_time", uint64(246552), dtags2))
|
|
|
|
// We expect 7 more DiskIOPoints to show up with an explicit match on "sdb1"
|
|
// and serial should be missing from the tags with SkipSerialNumber set
|
|
err = (&DiskIOStats{ps: &mps, Devices: []string{"sdb1"}, SkipSerialNumber: true}).Gather(&acc)
|
|
assert.Equal(t, expectedAllDiskIOPoints+7, len(acc.Points))
|
|
|
|
dtags3 := map[string]string{
|
|
"name": "sdb1",
|
|
}
|
|
|
|
assert.True(t, acc.CheckTaggedValue("reads", uint64(444), dtags3))
|
|
assert.True(t, acc.CheckTaggedValue("writes", uint64(2341), dtags3))
|
|
assert.True(t, acc.CheckTaggedValue("read_bytes", uint64(200000), dtags3))
|
|
assert.True(t, acc.CheckTaggedValue("write_bytes", uint64(400000), dtags3))
|
|
assert.True(t, acc.CheckTaggedValue("read_time", uint64(3123), dtags3))
|
|
assert.True(t, acc.CheckTaggedValue("write_time", uint64(6087), dtags3))
|
|
assert.True(t, acc.CheckTaggedValue("io_time", uint64(246552), dtags3))
|
|
}
|