mirror of
https://gitee.com/milvus-io/milvus.git
synced 2025-12-28 22:45:26 +08:00
This PR implements a new CDC service for Milvus 2.6, providing log-based cross-cluster replication. issue: https://github.com/milvus-io/milvus/issues/44123 --------- Signed-off-by: bigsheeper <yihao.dai@zilliz.com> Signed-off-by: chyezh <chyezh@outlook.com> Co-authored-by: chyezh <chyezh@outlook.com>
128 lines
4.6 KiB
Go
128 lines
4.6 KiB
Go
package options
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
"github.com/milvus-io/milvus-proto/go-api/v2/commonpb"
|
|
"github.com/milvus-io/milvus/pkg/v2/mocks/streaming/util/mock_message"
|
|
"github.com/milvus-io/milvus/pkg/v2/proto/streamingpb"
|
|
"github.com/milvus-io/milvus/pkg/v2/streaming/util/message"
|
|
)
|
|
|
|
func TestDeliverPolicy(t *testing.T) {
|
|
policy := DeliverPolicyAll()
|
|
_ = policy.GetPolicy().(*streamingpb.DeliverPolicy_All)
|
|
|
|
policy = DeliverPolicyLatest()
|
|
_ = policy.GetPolicy().(*streamingpb.DeliverPolicy_Latest)
|
|
|
|
messageID := mock_message.NewMockMessageID(t)
|
|
messageID.EXPECT().IntoProto().Return(&commonpb.MessageID{WALName: commonpb.WALName(message.WALNameTest), Id: "123"})
|
|
policy = DeliverPolicyStartFrom(messageID)
|
|
_ = policy.GetPolicy().(*streamingpb.DeliverPolicy_StartFrom)
|
|
|
|
policy = DeliverPolicyStartAfter(messageID)
|
|
_ = policy.GetPolicy().(*streamingpb.DeliverPolicy_StartAfter)
|
|
}
|
|
|
|
func TestDeliverFilter(t *testing.T) {
|
|
filter := DeliverFilterTimeTickGT(1)
|
|
_ = filter.GetFilter().(*streamingpb.DeliverFilter_TimeTickGt)
|
|
|
|
filter = DeliverFilterTimeTickGTE(2)
|
|
_ = filter.GetFilter().(*streamingpb.DeliverFilter_TimeTickGte)
|
|
|
|
filter = DeliverFilterMessageType(message.MessageTypeDelete)
|
|
_ = filter.GetFilter().(*streamingpb.DeliverFilter_MessageType)
|
|
}
|
|
|
|
func TestNewMessageFilter(t *testing.T) {
|
|
filters := []DeliverFilter{
|
|
DeliverFilterTimeTickGT(1),
|
|
}
|
|
filterFunc := GetFilterFunc(filters)
|
|
|
|
msg := mock_message.NewMockImmutableMessage(t)
|
|
msg.EXPECT().TimeTick().Return(1).Maybe()
|
|
msg.EXPECT().TxnContext().Return(nil).Maybe()
|
|
assert.False(t, filterFunc(msg))
|
|
|
|
msg = mock_message.NewMockImmutableMessage(t)
|
|
msg.EXPECT().TimeTick().Return(1).Maybe()
|
|
msg.EXPECT().TxnContext().Return(nil).Maybe()
|
|
assert.False(t, filterFunc(msg))
|
|
|
|
msg = mock_message.NewMockImmutableMessage(t)
|
|
msg.EXPECT().TimeTick().Return(2).Maybe()
|
|
msg.EXPECT().TxnContext().Return(nil).Maybe()
|
|
assert.True(t, filterFunc(msg))
|
|
|
|
// if message is a txn message, it should be only filterred by time tick when the message type is commit.
|
|
msg = mock_message.NewMockImmutableMessage(t)
|
|
msg.EXPECT().TimeTick().Return(1).Maybe()
|
|
msg.EXPECT().TxnContext().Return(&message.TxnContext{}).Maybe()
|
|
msg.EXPECT().MessageType().Return(message.MessageTypeCommitTxn).Maybe()
|
|
assert.False(t, filterFunc(msg))
|
|
|
|
msg = mock_message.NewMockImmutableMessage(t)
|
|
msg.EXPECT().TimeTick().Return(1).Maybe()
|
|
msg.EXPECT().TxnContext().Return(&message.TxnContext{}).Maybe()
|
|
msg.EXPECT().MessageType().Return(message.MessageTypeInsert).Maybe()
|
|
assert.True(t, filterFunc(msg))
|
|
|
|
// if message is a txn message, it should be only filterred by time tick when the message type is commit.
|
|
msg = mock_message.NewMockImmutableMessage(t)
|
|
msg.EXPECT().TimeTick().Return(1).Maybe()
|
|
msg.EXPECT().TxnContext().Return(&message.TxnContext{}).Maybe()
|
|
msg.EXPECT().MessageType().Return(message.MessageTypeCommitTxn).Maybe()
|
|
assert.False(t, filterFunc(msg))
|
|
|
|
msg = mock_message.NewMockImmutableMessage(t)
|
|
msg.EXPECT().TimeTick().Return(1).Maybe()
|
|
msg.EXPECT().TxnContext().Return(&message.TxnContext{}).Maybe()
|
|
msg.EXPECT().MessageType().Return(message.MessageTypeInsert).Maybe()
|
|
assert.True(t, filterFunc(msg))
|
|
|
|
filters = []*streamingpb.DeliverFilter{
|
|
DeliverFilterTimeTickGTE(1),
|
|
}
|
|
filterFunc = GetFilterFunc(filters)
|
|
|
|
msg = mock_message.NewMockImmutableMessage(t)
|
|
msg.EXPECT().TimeTick().Return(1).Maybe()
|
|
msg.EXPECT().TxnContext().Return(nil).Maybe()
|
|
assert.True(t, filterFunc(msg))
|
|
|
|
// if message is a txn message, it should be only filterred by time tick when the message type is commit.
|
|
msg = mock_message.NewMockImmutableMessage(t)
|
|
msg.EXPECT().TimeTick().Return(1).Maybe()
|
|
msg.EXPECT().TxnContext().Return(&message.TxnContext{}).Maybe()
|
|
msg.EXPECT().MessageType().Return(message.MessageTypeCommitTxn).Maybe()
|
|
assert.True(t, filterFunc(msg))
|
|
|
|
msg = mock_message.NewMockImmutableMessage(t)
|
|
msg.EXPECT().TimeTick().Return(1).Maybe()
|
|
msg.EXPECT().TxnContext().Return(&message.TxnContext{}).Maybe()
|
|
msg.EXPECT().MessageType().Return(message.MessageTypeInsert).Maybe()
|
|
assert.True(t, filterFunc(msg))
|
|
|
|
filters = []*streamingpb.DeliverFilter{
|
|
DeliverFilterMessageType(message.MessageTypeInsert, message.MessageTypeDelete),
|
|
}
|
|
filterFunc = GetFilterFunc(filters)
|
|
|
|
msg = mock_message.NewMockImmutableMessage(t)
|
|
msg.EXPECT().MessageType().Return(message.MessageTypeInsert).Maybe()
|
|
assert.True(t, filterFunc(msg))
|
|
|
|
msg = mock_message.NewMockImmutableMessage(t)
|
|
msg.EXPECT().MessageType().Return(message.MessageTypeDelete).Maybe()
|
|
assert.True(t, filterFunc(msg))
|
|
|
|
msg = mock_message.NewMockImmutableMessage(t)
|
|
msg.EXPECT().MessageType().Return(message.MessageTypeFlush).Maybe()
|
|
assert.False(t, filterFunc(msg))
|
|
}
|