Add ut for task_policies (#16663)

See also: #16652

Signed-off-by: yangxuan <xuan.yang@zilliz.com>
pull/16681/head
XuanYang-cn 2022-04-27 16:55:46 +08:00 committed by GitHub
parent 68ef720d6b
commit 35b7267edb
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 112 additions and 1 deletions

View File

@ -51,7 +51,9 @@ func roundRobinPolicy(ctx context.Context, getQueryNodePolicy getQueryNodePolicy
for err != nil && current < replicaNum {
currentID := leaders.GetNodeIds()[current]
if err != errBegin {
log.Warn("retry with another QueryNode", zap.String("leader", leaders.GetChannelName()), zap.Int64("nodeID", currentID))
log.Warn("retry with another QueryNode",
zap.Int("retries numbers", current),
zap.String("leader", leaders.GetChannelName()), zap.Int64("nodeID", currentID))
}
qn, err = getQueryNodePolicy(ctx, leaders.GetNodeAddrs()[current])

View File

@ -0,0 +1,109 @@
package proxy
import (
"context"
"fmt"
"testing"
"github.com/milvus-io/milvus/internal/proto/querypb"
"github.com/milvus-io/milvus/internal/types"
"github.com/stretchr/testify/require"
)
func TestRoundRobinPolicy(t *testing.T) {
var (
getQueryNodePolicy = mockGetQueryNodePolicy
ctx = context.TODO()
)
t.Run("All fails", func(t *testing.T) {
allFailTests := []struct {
leaderIDs []UniqueID
description string
}{
{[]UniqueID{1}, "one invalid shard leader"},
{[]UniqueID{1, 2}, "two invalid shard leaders"},
{[]UniqueID{1, 1}, "two invalid same shard leaders"},
}
for _, test := range allFailTests {
t.Run(test.description, func(t *testing.T) {
query := (&mockQuery{isvalid: false}).query
leaders := &querypb.ShardLeadersList{
ChannelName: t.Name(),
NodeIds: test.leaderIDs,
NodeAddrs: make([]string, len(test.leaderIDs)),
}
err := roundRobinPolicy(ctx, getQueryNodePolicy, query, leaders)
require.Error(t, err)
})
}
})
t.Run("Pass at the first try", func(t *testing.T) {
allPassTests := []struct {
leaderIDs []UniqueID
description string
}{
{[]UniqueID{1}, "one valid shard leader"},
{[]UniqueID{1, 2}, "two valid shard leaders"},
{[]UniqueID{1, 1}, "two valid same shard leaders"},
}
for _, test := range allPassTests {
query := (&mockQuery{isvalid: true}).query
leaders := &querypb.ShardLeadersList{
ChannelName: t.Name(),
NodeIds: test.leaderIDs,
NodeAddrs: make([]string, len(test.leaderIDs)),
}
err := roundRobinPolicy(ctx, getQueryNodePolicy, query, leaders)
require.NoError(t, err)
}
})
t.Run("Pass at the second try", func(t *testing.T) {
passAtLast := []struct {
leaderIDs []UniqueID
description string
}{
{[]UniqueID{-1, 2}, "invalid vs valid shard leaders"},
{[]UniqueID{-1, -1, 3}, "invalid, invalid, and valid shard leaders"},
}
for _, test := range passAtLast {
query := (&mockQuery{isvalid: true}).query
leaders := &querypb.ShardLeadersList{
ChannelName: t.Name(),
NodeIds: test.leaderIDs,
NodeAddrs: make([]string, len(test.leaderIDs)),
}
err := roundRobinPolicy(ctx, getQueryNodePolicy, query, leaders)
require.NoError(t, err)
}
})
}
func mockGetQueryNodePolicy(ctx context.Context, address string) (types.QueryNode, error) {
return &QueryNodeMock{address: address}, nil
}
type mockQuery struct {
isvalid bool
}
func (m *mockQuery) query(nodeID UniqueID, qn types.QueryNode) error {
if nodeID == -1 {
return fmt.Errorf("error at condition")
}
if m.isvalid {
return nil
}
return fmt.Errorf("mock error in query, NodeID=%d", nodeID)
}