Files
vRp.CD2g_test/utils/buffer/unbounded_benchmark_test.go
kercylan98 3408c212d0 refactor: 重构 server 包分流渠道设计,修复部分问题
- 使用 RingBuffer 实现分流渠道的无界缓冲区,修复分流渠道被关闭后,未处理完成的消息将会被丢弃的问题;
- 移除 server.WithDisableAutomaticReleaseShunt 可选项,分流渠道将在消息处理完毕且没有连接使用时自行释放;
2024-01-08 19:11:17 +08:00

51 lines
843 B
Go

package buffer_test
import (
"github.com/kercylan98/minotaur/utils/buffer"
"testing"
)
func BenchmarkUnbounded_Write(b *testing.B) {
u := buffer.NewUnbounded[int]()
b.ResetTimer()
for i := 0; i < b.N; i++ {
u.Put(i)
}
}
func BenchmarkUnbounded_Read(b *testing.B) {
u := buffer.NewUnbounded[int]()
for i := 0; i < b.N; i++ {
u.Put(i)
}
b.ResetTimer()
for i := 0; i < b.N; i++ {
<-u.Get()
u.Load()
}
}
func BenchmarkUnbounded_Write_Parallel(b *testing.B) {
u := buffer.NewUnbounded[int]()
b.ResetTimer()
b.RunParallel(func(pb *testing.PB) {
for pb.Next() {
u.Put(1)
}
})
}
func BenchmarkUnbounded_Read_Parallel(b *testing.B) {
u := buffer.NewUnbounded[int]()
for i := 0; i < b.N; i++ {
u.Put(i)
}
b.ResetTimer()
b.RunParallel(func(pb *testing.PB) {
for pb.Next() {
<-u.Get()
u.Load()
}
})
}