You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
go-zero/zrpc/internal/balancer/p2c/p2c_test.go

113 lines
2.3 KiB
Go

package p2c
4 years ago
import (
"context"
"fmt"
4 years ago
"runtime"
4 years ago
"strconv"
4 years ago
"sync"
4 years ago
"testing"
"github.com/stretchr/testify/assert"
"github.com/tal-tech/go-zero/core/logx"
"github.com/tal-tech/go-zero/core/mathx"
4 years ago
"google.golang.org/grpc/balancer"
"google.golang.org/grpc/codes"
"google.golang.org/grpc/resolver"
"google.golang.org/grpc/status"
)
func init() {
logx.Disable()
}
func TestP2cPicker_PickNil(t *testing.T) {
builder := new(p2cPickerBuilder)
picker := builder.Build(nil)
_, _, err := picker.Pick(context.Background(), balancer.PickInfo{
FullMethodName: "/",
Ctx: context.Background(),
})
assert.NotNil(t, err)
}
func TestP2cPicker_Pick(t *testing.T) {
4 years ago
tests := []struct {
name string
candidates int
4 years ago
threshold float64
4 years ago
}{
{
name: "single",
candidates: 1,
4 years ago
threshold: 0.9,
4 years ago
},
4 years ago
{
name: "two",
candidates: 2,
4 years ago
threshold: 0.5,
4 years ago
},
4 years ago
{
name: "multiple",
candidates: 100,
4 years ago
threshold: 0.95,
4 years ago
},
}
for _, test := range tests {
4 years ago
test := test
4 years ago
t.Run(test.name, func(t *testing.T) {
4 years ago
t.Parallel()
4 years ago
const total = 10000
4 years ago
builder := new(p2cPickerBuilder)
ready := make(map[resolver.Address]balancer.SubConn)
for i := 0; i < test.candidates; i++ {
ready[resolver.Address{
Addr: strconv.Itoa(i),
}] = new(mockClientConn)
}
picker := builder.Build(ready)
4 years ago
var wg sync.WaitGroup
wg.Add(total)
for i := 0; i < total; i++ {
4 years ago
_, done, err := picker.Pick(context.Background(), balancer.PickInfo{
FullMethodName: "/",
Ctx: context.Background(),
})
assert.Nil(t, err)
if i%100 == 0 {
err = status.Error(codes.DeadlineExceeded, "deadline")
}
4 years ago
go func() {
4 years ago
runtime.Gosched()
4 years ago
done(balancer.DoneInfo{
Err: err,
})
wg.Done()
}()
4 years ago
}
4 years ago
wg.Wait()
4 years ago
dist := make(map[interface{}]int)
conns := picker.(*p2cPicker).conns
for _, conn := range conns {
dist[conn.addr.Addr] = int(conn.requests)
}
entropy := mathx.CalcEntropy(dist)
4 years ago
assert.True(t, entropy > test.threshold, fmt.Sprintf("entropy is %f, less than %f",
entropy, test.threshold))
4 years ago
})
}
}
type mockClientConn struct{}
4 years ago
func (m mockClientConn) UpdateAddresses(addresses []resolver.Address) {
}
4 years ago
func (m mockClientConn) Connect() {
}