milvus/pkg/streaming/util/message/message_id_test.go
yihao.dai 51f69f32d0
feat: Add CDC support (#44124)
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>
2025-09-16 16:32:01 +08:00

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)
}