Files
EdgeNode/internal/utils/counters/item_test.go

81 lines
1.7 KiB
Go
Raw Normal View History

// Copyright 2023 GoEdge CDN goedge.cdn@gmail.com. All rights reserved. Official site: https://goedge.cn .
package counters_test
import (
"github.com/TeaOSLab/EdgeNode/internal/utils/counters"
"github.com/TeaOSLab/EdgeNode/internal/utils/testutils"
"github.com/iwind/TeaGo/assert"
timeutil "github.com/iwind/TeaGo/utils/time"
"runtime"
"testing"
"time"
)
func TestItem_Increase(t *testing.T) {
if !testutils.IsSingleTesting() {
return
}
var item = counters.NewItem(10)
t.Log(item.Increase())
time.Sleep(1 * time.Second)
t.Log(item.Increase())
time.Sleep(2 * time.Second)
t.Log(item.Increase())
time.Sleep(5 * time.Second)
t.Log(item.Increase())
time.Sleep(6 * time.Second)
t.Log(item.Increase())
time.Sleep(5 * time.Second)
t.Log(item.Increase())
time.Sleep(11 * time.Second)
t.Log(item.Increase())
}
func TestItem_Increase2(t *testing.T) {
// run only under single testing
if !testutils.IsSingleTesting() {
return
}
var a = assert.NewAssertion(t)
var item = counters.NewItem(20)
for i := 0; i < 100; i++ {
t.Log(item.Increase(), timeutil.Format("H:i:s"))
time.Sleep(2 * time.Second)
}
item.Reset()
a.IsTrue(item.Sum() == 0)
}
func TestItem_IsExpired(t *testing.T) {
if !testutils.IsSingleTesting() {
return
}
2023-07-15 11:08:25 +08:00
var currentTime = time.Now().Unix()
var item = counters.NewItem(10)
2023-07-15 11:08:25 +08:00
t.Log(item.IsExpired(currentTime))
time.Sleep(10 * time.Second)
2023-07-15 11:08:25 +08:00
t.Log(item.IsExpired(currentTime))
time.Sleep(2 * time.Second)
2023-07-15 11:08:25 +08:00
t.Log(item.IsExpired(currentTime))
}
func BenchmarkItem_Increase(b *testing.B) {
runtime.GOMAXPROCS(1)
var item = counters.NewItem(60)
b.RunParallel(func(pb *testing.PB) {
for pb.Next() {
item.Increase()
item.Sum()
}
})
}