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)) }