2023-04-03 22:13:44 +01:00
|
|
|
// Copyright (c) Tailscale Inc & AUTHORS
|
|
|
|
// SPDX-License-Identifier: BSD-3-Clause
|
|
|
|
|
2023-04-12 23:50:52 +01:00
|
|
|
//go:build tailscale_go && (darwin || ios || android || ts_enable_sockstats)
|
2023-04-03 22:13:44 +01:00
|
|
|
|
|
|
|
package sockstats
|
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
)
|
|
|
|
|
|
|
|
type testTime struct {
|
|
|
|
time.Time
|
|
|
|
}
|
|
|
|
|
|
|
|
func (t *testTime) now() time.Time {
|
|
|
|
return t.Time
|
|
|
|
}
|
|
|
|
|
|
|
|
func (t *testTime) Add(d time.Duration) {
|
|
|
|
t.Time = t.Time.Add(d)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestRadioMonitor(t *testing.T) {
|
|
|
|
tests := []struct {
|
2023-04-12 23:50:52 +01:00
|
|
|
name string
|
2023-04-03 22:13:44 +01:00
|
|
|
activity func(*testTime, *radioMonitor)
|
2023-04-12 23:50:52 +01:00
|
|
|
want int64
|
2023-04-03 22:13:44 +01:00
|
|
|
}{
|
|
|
|
{
|
|
|
|
"no activity",
|
|
|
|
func(_ *testTime, _ *radioMonitor) {},
|
|
|
|
0,
|
|
|
|
},
|
2023-05-09 17:40:55 +01:00
|
|
|
{
|
|
|
|
"active less than init stall period",
|
|
|
|
func(tt *testTime, rm *radioMonitor) {
|
|
|
|
rm.active()
|
|
|
|
tt.Add(1 * time.Second)
|
|
|
|
},
|
|
|
|
0, // radio on, but not long enough to report data
|
|
|
|
},
|
2023-04-03 22:13:44 +01:00
|
|
|
{
|
|
|
|
"active, 10 sec idle",
|
|
|
|
func(tt *testTime, rm *radioMonitor) {
|
|
|
|
rm.active()
|
2023-04-19 21:45:02 +01:00
|
|
|
tt.Add(9 * time.Second)
|
2023-04-03 22:13:44 +01:00
|
|
|
},
|
2023-04-19 20:56:52 +01:00
|
|
|
50, // radio on 5 seconds of 10 seconds
|
2023-04-03 22:13:44 +01:00
|
|
|
},
|
2023-04-19 21:45:02 +01:00
|
|
|
{
|
2023-05-09 17:40:55 +01:00
|
|
|
"active, spanning three seconds",
|
2023-04-19 21:45:02 +01:00
|
|
|
func(tt *testTime, rm *radioMonitor) {
|
|
|
|
rm.active()
|
2023-05-09 17:40:55 +01:00
|
|
|
tt.Add(2100 * time.Millisecond)
|
2023-04-19 21:45:02 +01:00
|
|
|
rm.active()
|
|
|
|
},
|
2023-05-09 17:40:55 +01:00
|
|
|
100, // radio on for 3 seconds
|
2023-04-19 21:45:02 +01:00
|
|
|
},
|
2023-04-03 22:13:44 +01:00
|
|
|
{
|
|
|
|
"400 iterations: 2 sec active, 1 min idle",
|
|
|
|
func(tt *testTime, rm *radioMonitor) {
|
|
|
|
// 400 iterations to ensure values loop back around rm.usage array
|
2024-04-16 21:15:13 +01:00
|
|
|
for range 400 {
|
2023-04-03 22:13:44 +01:00
|
|
|
rm.active()
|
|
|
|
tt.Add(1 * time.Second)
|
|
|
|
rm.active()
|
2023-04-19 20:56:52 +01:00
|
|
|
tt.Add(59 * time.Second)
|
2023-04-03 22:13:44 +01:00
|
|
|
}
|
|
|
|
},
|
|
|
|
10, // radio on 6 seconds of every minute
|
|
|
|
},
|
2023-04-19 20:56:52 +01:00
|
|
|
{
|
|
|
|
"activity at end of time window",
|
|
|
|
func(tt *testTime, rm *radioMonitor) {
|
2023-05-09 17:40:55 +01:00
|
|
|
tt.Add(3 * time.Second)
|
2023-04-19 20:56:52 +01:00
|
|
|
rm.active()
|
|
|
|
},
|
2023-05-09 17:40:55 +01:00
|
|
|
25,
|
2023-04-19 20:56:52 +01:00
|
|
|
},
|
2023-04-03 22:13:44 +01:00
|
|
|
}
|
|
|
|
|
2023-05-09 17:40:55 +01:00
|
|
|
oldStallPeriod := initStallPeriod
|
|
|
|
initStallPeriod = 3
|
|
|
|
t.Cleanup(func() { initStallPeriod = oldStallPeriod })
|
|
|
|
|
2023-04-03 22:13:44 +01:00
|
|
|
for _, tt := range tests {
|
|
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
|
|
tm := &testTime{time.Date(2021, 1, 1, 0, 0, 0, 0, time.UTC)}
|
|
|
|
rm := &radioMonitor{
|
|
|
|
startTime: tm.Time.Unix(),
|
|
|
|
now: tm.now,
|
|
|
|
}
|
|
|
|
tt.activity(tm, rm)
|
|
|
|
got := rm.radioHighPercent()
|
|
|
|
if got != tt.want {
|
|
|
|
t.Errorf("got radioOnPercent %d, want %d", got, tt.want)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|