shirou_gopsutil/mem/mem_test.go

142 lines
3.8 KiB
Go
Raw Normal View History

2014-12-30 21:09:05 +08:00
package mem
2014-04-18 15:34:47 +08:00
import (
2021-12-05 05:29:38 +08:00
"errors"
2014-04-18 15:34:47 +08:00
"fmt"
"runtime"
2014-04-18 15:34:47 +08:00
"testing"
"github.com/stretchr/testify/assert"
"github.com/shirou/gopsutil/v3/internal/common"
2014-04-18 15:34:47 +08:00
)
func skipIfNotImplementedErr(t *testing.T, err error) {
2021-12-05 05:29:38 +08:00
if errors.Is(err, common.ErrNotImplementedError) {
t.Skip("not implemented")
}
}
2014-04-18 15:34:47 +08:00
func TestVirtual_memory(t *testing.T) {
if runtime.GOOS == "solaris" || runtime.GOOS == "illumos" {
t.Skip("Only .Total .Available are supported on Solaris/illumos")
}
v, err := VirtualMemory()
skipIfNotImplementedErr(t, err)
2014-04-18 15:34:47 +08:00
if err != nil {
t.Errorf("error %v", err)
}
empty := &VirtualMemoryStat{}
2014-05-12 10:51:08 +08:00
if v == empty {
t.Errorf("error %v", v)
}
t.Log(v)
assert.True(t, v.Total > 0)
assert.True(t, v.Available > 0)
assert.True(t, v.Used > 0)
total := v.Used + v.Free + v.Buffers + v.Cached
totalStr := "used + free + buffers + cached"
switch runtime.GOOS {
case "windows":
total = v.Used + v.Available
totalStr = "used + available"
case "darwin", "openbsd":
total = v.Used + v.Free + v.Cached + v.Inactive
totalStr = "used + free + cached + inactive"
case "freebsd":
total = v.Used + v.Free + v.Cached + v.Inactive + v.Laundry
totalStr = "used + free + cached + inactive + laundry"
}
assert.Equal(t, v.Total, total,
"Total should be computable (%v): %v", totalStr, v)
assert.True(t, runtime.GOOS == "windows" || v.Free > 0)
assert.True(t, runtime.GOOS == "windows" || v.Available > v.Free,
"Free should be a subset of Available: %v", v)
inDelta := assert.InDelta
if runtime.GOOS == "windows" {
inDelta = assert.InEpsilon
}
inDelta(t, v.UsedPercent,
100*float64(v.Used)/float64(v.Total), 0.1,
"UsedPercent should be how many percent of Total is Used: %v", v)
2014-04-18 15:34:47 +08:00
}
func TestSwap_memory(t *testing.T) {
v, err := SwapMemory()
skipIfNotImplementedErr(t, err)
2014-04-18 15:34:47 +08:00
if err != nil {
t.Errorf("error %v", err)
}
empty := &SwapMemoryStat{}
2014-05-12 10:51:08 +08:00
if v == empty {
t.Errorf("error %v", v)
}
t.Log(v)
2014-05-12 10:51:08 +08:00
}
func TestVirtualMemoryStat_String(t *testing.T) {
v := VirtualMemoryStat{
2014-05-12 10:51:08 +08:00
Total: 10,
Available: 20,
Used: 30,
UsedPercent: 30.1,
Free: 40,
}
2022-06-07 20:48:50 +08:00
t.Log(v)
e := `{"total":10,"available":20,"used":30,"usedPercent":30.1,"free":40,"active":0,"inactive":0,"wired":0,"laundry":0,"buffers":0,"cached":0,"writeBack":0,"dirty":0,"writeBackTmp":0,"shared":0,"slab":0,"sreclaimable":0,"sunreclaim":0,"pageTables":0,"swapCached":0,"commitLimit":0,"committedAS":0,"highTotal":0,"highFree":0,"lowTotal":0,"lowFree":0,"swapTotal":0,"swapFree":0,"mapped":0,"vmallocTotal":0,"vmallocUsed":0,"vmallocChunk":0,"hugePagesTotal":0,"hugePagesFree":0,"hugePagesRsvd":0,"hugePagesSurp":0,"hugePageSize":0}`
2014-05-12 10:51:08 +08:00
if e != fmt.Sprintf("%v", v) {
t.Errorf("VirtualMemoryStat string is invalid: %v", v)
}
}
func TestSwapMemoryStat_String(t *testing.T) {
v := SwapMemoryStat{
2014-05-12 10:51:08 +08:00
Total: 10,
Used: 30,
Free: 40,
UsedPercent: 30.1,
Sin: 1,
Sout: 2,
PgIn: 3,
PgOut: 4,
PgFault: 5,
PgMajFault: 6,
2014-05-12 10:51:08 +08:00
}
e := `{"total":10,"used":30,"free":40,"usedPercent":30.1,"sin":1,"sout":2,"pgIn":3,"pgOut":4,"pgFault":5,"pgMajFault":6}`
2014-05-12 10:51:08 +08:00
if e != fmt.Sprintf("%v", v) {
t.Errorf("SwapMemoryStat string is invalid: %v", v)
}
2014-04-18 15:34:47 +08:00
}
2021-08-18 21:52:13 +08:00
func TestSwapDevices(t *testing.T) {
v, err := SwapDevices()
skipIfNotImplementedErr(t, err)
if err != nil {
t.Fatalf("error calling SwapDevices: %v", err)
}
t.Logf("SwapDevices() -> %+v", v)
if len(v) == 0 {
t.Fatalf("no swap devices found. [this is expected if the host has swap disabled]")
}
for _, device := range v {
if device.Name == "" {
t.Fatalf("deviceName not set in %+v", device)
}
if device.FreeBytes == 0 {
t.Logf("[WARNING] free-bytes is zero in %+v. This might be expected", device)
}
if device.UsedBytes == 0 {
t.Logf("[WARNING] used-bytes is zero in %+v. This might be expected", device)
}
}
}