2021-10-22 09:25:58 +08:00
|
|
|
package random
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/go-kratos/kratos/v2/registry"
|
|
|
|
"github.com/go-kratos/kratos/v2/selector"
|
|
|
|
"github.com/go-kratos/kratos/v2/selector/filter"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestWrr(t *testing.T) {
|
|
|
|
random := New(WithFilter(filter.Version("v2.0.0")))
|
|
|
|
var nodes []selector.Node
|
|
|
|
nodes = append(nodes, selector.NewNode(
|
2022-04-14 13:48:20 +08:00
|
|
|
"http",
|
2021-10-22 09:25:58 +08:00
|
|
|
"127.0.0.1:8080",
|
|
|
|
®istry.ServiceInstance{
|
|
|
|
ID: "127.0.0.1:8080",
|
|
|
|
Version: "v2.0.0",
|
|
|
|
Metadata: map[string]string{"weight": "10"},
|
|
|
|
}))
|
|
|
|
nodes = append(nodes, selector.NewNode(
|
2022-04-14 13:48:20 +08:00
|
|
|
"http",
|
2021-10-22 09:25:58 +08:00
|
|
|
"127.0.0.1:9090",
|
|
|
|
®istry.ServiceInstance{
|
|
|
|
ID: "127.0.0.1:9090",
|
|
|
|
Version: "v2.0.0",
|
|
|
|
Metadata: map[string]string{"weight": "20"},
|
|
|
|
}))
|
|
|
|
random.Apply(nodes)
|
|
|
|
var count1, count2 int
|
|
|
|
for i := 0; i < 200; i++ {
|
|
|
|
n, done, err := random.Select(context.Background())
|
2022-01-14 10:02:42 +08:00
|
|
|
if err != nil {
|
|
|
|
t.Errorf("expect no error, got %v", err)
|
|
|
|
}
|
|
|
|
if done == nil {
|
|
|
|
t.Errorf("expect not nil, got:%v", done)
|
|
|
|
}
|
|
|
|
if n == nil {
|
|
|
|
t.Errorf("expect not nil, got:%v", n)
|
|
|
|
}
|
2021-10-22 09:25:58 +08:00
|
|
|
done(context.Background(), selector.DoneInfo{})
|
|
|
|
if n.Address() == "127.0.0.1:8080" {
|
|
|
|
count1++
|
|
|
|
} else if n.Address() == "127.0.0.1:9090" {
|
|
|
|
count2++
|
|
|
|
}
|
|
|
|
}
|
2022-01-14 10:02:42 +08:00
|
|
|
if count1 <= 80 {
|
|
|
|
t.Errorf("count1(%v) <= 80", count1)
|
|
|
|
}
|
|
|
|
if count1 >= 120 {
|
|
|
|
t.Errorf("count1(%v) >= 120", count1)
|
|
|
|
}
|
|
|
|
if count2 <= 80 {
|
|
|
|
t.Errorf("count2(%v) <= 80", count2)
|
|
|
|
}
|
|
|
|
if count2 >= 120 {
|
|
|
|
t.Errorf("count2(%v) >= 120", count2)
|
|
|
|
}
|
2021-10-22 09:25:58 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
func TestEmpty(t *testing.T) {
|
|
|
|
b := &Balancer{}
|
|
|
|
_, _, err := b.Pick(context.Background(), []selector.WeightedNode{})
|
2022-01-14 10:02:42 +08:00
|
|
|
if err == nil {
|
|
|
|
t.Errorf("expect nil, got %v", err)
|
|
|
|
}
|
2021-10-22 09:25:58 +08:00
|
|
|
}
|