mirror of
https://gitee.com/milvus-io/milvus.git
synced 2025-12-08 18:18:30 +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>
51 lines
1.7 KiB
Go
51 lines
1.7 KiB
Go
package message_test
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/cockroachdb/errors"
|
|
"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/streaming/util/message"
|
|
)
|
|
|
|
func TestRegisterMessageIDUnmarshaler(t *testing.T) {
|
|
msgID := mock_message.NewMockMessageID(t)
|
|
|
|
id, err := message.UnmarshalMessageID(&commonpb.MessageID{WALName: commonpb.WALName(message.WALNameTest), Id: "123"})
|
|
assert.NotNil(t, id)
|
|
assert.NoError(t, err)
|
|
|
|
id, err = message.UnmarshalMessageID(&commonpb.MessageID{WALName: commonpb.WALName(message.WALNameTest), Id: "123a"})
|
|
assert.Nil(t, id)
|
|
assert.Error(t, err)
|
|
|
|
assert.Panics(t, func() {
|
|
message.UnmarshalMessageID(&commonpb.MessageID{WALName: commonpb.WALName(101), Id: "123"})
|
|
})
|
|
|
|
assert.Panics(t, func() {
|
|
message.RegisterMessageIDUnmsarshaler(message.WALNameTest, func(b string) (message.MessageID, error) {
|
|
if b == "123" {
|
|
return msgID, nil
|
|
}
|
|
return nil, errors.New("invalid")
|
|
})
|
|
})
|
|
}
|
|
|
|
func TestCases(t *testing.T) {
|
|
msgID := mock_message.NewMockMessageID(t)
|
|
msgID.EXPECT().IntoProto().Return(&commonpb.MessageID{WALName: commonpb.WALName(message.WALNameTest), Id: "123"}).Maybe()
|
|
msgID.EXPECT().Marshal().Return("123").Maybe()
|
|
msgID.EXPECT().WALName().Return(message.WALNameTest).Maybe()
|
|
message.CreateTestInsertMessage(t, 1, 100, 100, msgID)
|
|
message.CreateTestCreateCollectionMessage(t, 1, 100, msgID)
|
|
message.CreateTestEmptyInsertMesage(1, nil)
|
|
message.CreateTestDropCollectionMessage(t, 1, 100, msgID)
|
|
message.CreateTestTimeTickSyncMessage(t, 1, 100, msgID)
|
|
message.CreateTestCreateSegmentMessage(t, 1, 100, msgID)
|
|
}
|