mirror of
https://github.com/TeaOSLab/EdgeNode.git
synced 2025-11-20 04:50:26 +08:00
增加测试用例
This commit is contained in:
@@ -3,7 +3,9 @@
|
|||||||
package stats_test
|
package stats_test
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"github.com/TeaOSLab/EdgeCommon/pkg/rpc/pb"
|
||||||
"github.com/TeaOSLab/EdgeNode/internal/stats"
|
"github.com/TeaOSLab/EdgeNode/internal/stats"
|
||||||
|
"runtime"
|
||||||
"testing"
|
"testing"
|
||||||
"time"
|
"time"
|
||||||
)
|
)
|
||||||
@@ -31,3 +33,53 @@ func TestBandwidthStatManager_Loop(t *testing.T) {
|
|||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func BenchmarkBandwidthStatManager_Slice(b *testing.B) {
|
||||||
|
runtime.GOMAXPROCS(1)
|
||||||
|
|
||||||
|
for i := 0; i < b.N; i++ {
|
||||||
|
var pbStats = []*pb.ServerBandwidthStat{}
|
||||||
|
for j := 0; j < 100; j++ {
|
||||||
|
var stat = &stats.BandwidthStat{}
|
||||||
|
pbStats = append(pbStats, &pb.ServerBandwidthStat{
|
||||||
|
Id: 0,
|
||||||
|
UserId: stat.UserId,
|
||||||
|
ServerId: stat.ServerId,
|
||||||
|
Day: stat.Day,
|
||||||
|
TimeAt: stat.TimeAt,
|
||||||
|
Bytes: stat.MaxBytes / 2,
|
||||||
|
TotalBytes: stat.TotalBytes,
|
||||||
|
CachedBytes: stat.CachedBytes,
|
||||||
|
AttackBytes: stat.AttackBytes,
|
||||||
|
CountRequests: stat.CountRequests,
|
||||||
|
CountCachedRequests: stat.CountCachedRequests,
|
||||||
|
CountAttackRequests: stat.CountAttackRequests,
|
||||||
|
NodeRegionId: 1,
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func BenchmarkBandwidthStatManager_Slice2(b *testing.B) {
|
||||||
|
runtime.GOMAXPROCS(1)
|
||||||
|
|
||||||
|
for i := 0; i < b.N; i++ {
|
||||||
|
var statsSlice = []*stats.BandwidthStat{}
|
||||||
|
for j := 0; j < 100; j++ {
|
||||||
|
var stat = &stats.BandwidthStat{}
|
||||||
|
statsSlice = append(statsSlice, stat)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func BenchmarkBandwidthStatManager_Slice3(b *testing.B) {
|
||||||
|
runtime.GOMAXPROCS(1)
|
||||||
|
|
||||||
|
for i := 0; i < b.N; i++ {
|
||||||
|
var statsSlice = make([]*stats.BandwidthStat, 2000)
|
||||||
|
for j := 0; j < 100; j++ {
|
||||||
|
var stat = &stats.BandwidthStat{}
|
||||||
|
statsSlice[j] = stat
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|||||||
@@ -3,6 +3,7 @@ package stats
|
|||||||
import (
|
import (
|
||||||
"github.com/iwind/TeaGo/rands"
|
"github.com/iwind/TeaGo/rands"
|
||||||
"github.com/iwind/TeaGo/types"
|
"github.com/iwind/TeaGo/types"
|
||||||
|
"math/rand"
|
||||||
"runtime"
|
"runtime"
|
||||||
"testing"
|
"testing"
|
||||||
)
|
)
|
||||||
@@ -30,8 +31,12 @@ func TestTrafficStatManager_Upload(t *testing.T) {
|
|||||||
func BenchmarkTrafficStatManager_Add(b *testing.B) {
|
func BenchmarkTrafficStatManager_Add(b *testing.B) {
|
||||||
runtime.GOMAXPROCS(1)
|
runtime.GOMAXPROCS(1)
|
||||||
|
|
||||||
manager := NewTrafficStatManager()
|
var manager = NewTrafficStatManager()
|
||||||
for i := 0; i < b.N; i++ {
|
b.ResetTimer()
|
||||||
manager.Add(1, 1, "goedge.cn", 1024, 1, 0, 0, 0, 0, false, 0)
|
|
||||||
}
|
b.RunParallel(func(pb *testing.PB) {
|
||||||
|
for pb.Next() {
|
||||||
|
manager.Add(1, 1, "goedge.cn"+types.String(rand.Int63()%10), 1024, 1, 0, 0, 0, 0, false, 0)
|
||||||
|
}
|
||||||
|
})
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user