package net import ( "fmt" "os" "runtime" "testing" "github.com/shirou/gopsutil/internal/common" ) func TestAddrString(t *testing.T) { v := Addr{IP: "192.168.0.1", Port: 8000} s := fmt.Sprintf("%v", v) if s != "{\"ip\":\"192.168.0.1\",\"port\":8000}" { t.Errorf("Addr string is invalid: %v", v) } } func TestNetIOCountersStatString(t *testing.T) { v := NetIOCountersStat{ Name: "test", BytesSent: 100, } e := `{"name":"test","bytes_sent":100,"bytes_recv":0,"packets_sent":0,"packets_recv":0,"errin":0,"errout":0,"dropin":0,"dropout":0}` if e != fmt.Sprintf("%v", v) { t.Errorf("NetIOCountersStat string is invalid: %v", v) } } func TestNetProtoCountersStatString(t *testing.T) { v := NetProtoCountersStat{ Protocol: "tcp", Stats: map[string]int64{ "MaxConn": -1, "ActiveOpens": 4000, "PassiveOpens": 3000, }, } e := `{"protocol":"tcp","stats":{"ActiveOpens":4000,"MaxConn":-1,"PassiveOpens":3000}}` if e != fmt.Sprintf("%v", v) { t.Errorf("NetProtoCountersStat string is invalid: %v", v) } } func TestNetConnectionStatString(t *testing.T) { v := NetConnectionStat{ Fd: 10, Family: 10, Type: 10, } e := `{"fd":10,"family":10,"type":10,"localaddr":{"ip":"","port":0},"remoteaddr":{"ip":"","port":0},"status":"","pid":0}` if e != fmt.Sprintf("%v", v) { t.Errorf("NetConnectionStat string is invalid: %v", v) } } func TestNetIOCountersAll(t *testing.T) { v, err := NetIOCounters(false) per, err := NetIOCounters(true) if err != nil { t.Errorf("Could not get NetIOCounters: %v", err) } if len(v) != 1 { t.Errorf("Could not get NetIOCounters: %v", v) } if v[0].Name != "all" { t.Errorf("Invalid NetIOCounters: %v", v) } var pr uint64 for _, p := range per { pr += p.PacketsRecv } if v[0].PacketsRecv != pr { t.Errorf("invalid sum value: %v, %v", v[0].PacketsRecv, pr) } } func TestNetIOCountersPerNic(t *testing.T) { v, err := NetIOCounters(true) if err != nil { t.Errorf("Could not get NetIOCounters: %v", err) } if len(v) == 0 { t.Errorf("Could not get NetIOCounters: %v", v) } for _, vv := range v { if vv.Name == "" { t.Errorf("Invalid NetIOCounters: %v", vv) } } } func TestGetNetIOCountersAll(t *testing.T) { n := []NetIOCountersStat{ NetIOCountersStat{ Name: "a", BytesRecv: 10, PacketsRecv: 10, }, NetIOCountersStat{ Name: "b", BytesRecv: 10, PacketsRecv: 10, Errin: 10, }, } ret, err := getNetIOCountersAll(n) if err != nil { t.Error(err) } if len(ret) != 1 { t.Errorf("invalid return count") } if ret[0].Name != "all" { t.Errorf("invalid return name") } if ret[0].BytesRecv != 20 { t.Errorf("invalid count bytesrecv") } if ret[0].Errin != 10 { t.Errorf("invalid count errin") } } func TestNetInterfaces(t *testing.T) { v, err := NetInterfaces() if err != nil { t.Errorf("Could not get NetInterfaceStat: %v", err) } if len(v) == 0 { t.Errorf("Could not get NetInterfaceStat: %v", err) } for _, vv := range v { if vv.Name == "" { t.Errorf("Invalid NetInterface: %v", vv) } } } func TestNetProtoCountersStatsAll(t *testing.T) { v, err := NetProtoCounters(nil) if err != nil { t.Fatalf("Could not get NetProtoCounters: %v", err) } if len(v) == 0 { t.Fatalf("Could not get NetProtoCounters: %v", err) } for _, vv := range v { if vv.Protocol == "" { t.Errorf("Invalid NetProtoCountersStat: %v", vv) } if len(vv.Stats) == 0 { t.Errorf("Invalid NetProtoCountersStat: %v", vv) } } } func TestNetProtoCountersStats(t *testing.T) { v, err := NetProtoCounters([]string{"tcp", "ip"}) if err != nil { t.Fatalf("Could not get NetProtoCounters: %v", err) } if len(v) == 0 { t.Fatalf("Could not get NetProtoCounters: %v", err) } if len(v) != 2 { t.Fatalf("Go incorrect number of NetProtoCounters: %v", err) } for _, vv := range v { if vv.Protocol != "tcp" && vv.Protocol != "ip" { t.Errorf("Invalid NetProtoCountersStat: %v", vv) } if len(vv.Stats) == 0 { t.Errorf("Invalid NetProtoCountersStat: %v", vv) } } } func TestNetConnections(t *testing.T) { if ci := os.Getenv("CI"); ci != "" { // skip if test on drone.io return } v, err := NetConnections("inet") if err != nil { t.Errorf("could not get NetConnections: %v", err) } if len(v) == 0 { t.Errorf("could not get NetConnections: %v", v) } for _, vv := range v { if vv.Family == 0 { t.Errorf("invalid NetConnections: %v", vv) } } } func TestNetFilterCounters(t *testing.T) { if ci := os.Getenv("CI"); ci != "" { // skip if test on drone.io return } if runtime.GOOS == "linux" { // some test environment has not the path. if !common.PathExists("/proc/sys/net/netfilter/nf_conntrack_count") { t.SkipNow() } } v, err := NetFilterCounters() if err != nil { t.Errorf("could not get NetConnections: %v", err) } if len(v) == 0 { t.Errorf("could not get NetConnections: %v", v) } for _, vv := range v { if vv.ConnTrackMax == 0 { t.Errorf("nf_conntrack_max needs to be greater than zero: %v", vv) } } }