Zhen Ye c171280f63
enhance: support replicate message in wal. (#44456)
issue: #44123

- support replicate message  in wal of milvus.
- support CDC-replicate recovery from wal.
- fix some CDC replicator bugs

Signed-off-by: chyezh <chyezh@outlook.com>
2025-09-22 17:06:11 +08:00

87 lines
3.4 KiB
Go

package utility
import (
"testing"
"github.com/stretchr/testify/assert"
"github.com/milvus-io/milvus-proto/go-api/v2/commonpb"
"github.com/milvus-io/milvus/pkg/v2/proto/streamingpb"
"github.com/milvus-io/milvus/pkg/v2/streaming/walimpls/impls/rmq"
)
func TestNewWALCheckpointFromProto(t *testing.T) {
assert.Nil(t, NewWALCheckpointFromProto(nil))
assert.Nil(t, NewWALCheckpointFromProto(nil).IntoProto())
messageID := rmq.NewRmqID(1)
timeTick := uint64(12345)
recoveryMagic := int64(1)
protoCheckpoint := &streamingpb.WALCheckpoint{
MessageId: messageID.IntoProto(),
TimeTick: timeTick,
RecoveryMagic: recoveryMagic,
}
checkpoint := NewWALCheckpointFromProto(protoCheckpoint)
assert.True(t, messageID.EQ(checkpoint.MessageID))
assert.Equal(t, timeTick, checkpoint.TimeTick)
assert.Equal(t, recoveryMagic, checkpoint.Magic)
proto := checkpoint.IntoProto()
checkpoint2 := NewWALCheckpointFromProto(proto)
assert.True(t, messageID.EQ(checkpoint2.MessageID))
assert.Equal(t, timeTick, checkpoint2.TimeTick)
assert.Equal(t, recoveryMagic, checkpoint2.Magic)
checkpoint3 := checkpoint.Clone()
assert.True(t, messageID.EQ(checkpoint3.MessageID))
assert.Equal(t, timeTick, checkpoint3.TimeTick)
assert.Equal(t, recoveryMagic, checkpoint3.Magic)
protoCheckpoint.ReplicateConfig = &commonpb.ReplicateConfiguration{}
protoCheckpoint.ReplicateCheckpoint = &commonpb.ReplicateCheckpoint{
ClusterId: "by-dev",
Pchannel: "p1",
MessageId: nil,
TimeTick: 0,
}
newCheckpoint := NewWALCheckpointFromProto(protoCheckpoint)
assert.Equal(t, "by-dev", newCheckpoint.ReplicateCheckpoint.ClusterID)
assert.Equal(t, "p1", newCheckpoint.ReplicateCheckpoint.PChannel)
assert.Equal(t, uint64(0), newCheckpoint.ReplicateCheckpoint.TimeTick)
assert.Nil(t, newCheckpoint.ReplicateCheckpoint.MessageID)
assert.NotNil(t, newCheckpoint.ReplicateConfig)
protoCheckpoint.ReplicateCheckpoint.MessageId = rmq.NewRmqID(2).IntoProto()
protoCheckpoint.ReplicateCheckpoint.TimeTick = 123456
newCheckpoint = NewWALCheckpointFromProto(protoCheckpoint)
assert.Equal(t, "by-dev", newCheckpoint.ReplicateCheckpoint.ClusterID)
assert.Equal(t, "p1", newCheckpoint.ReplicateCheckpoint.PChannel)
assert.Equal(t, uint64(123456), newCheckpoint.ReplicateCheckpoint.TimeTick)
assert.True(t, rmq.NewRmqID(2).EQ(newCheckpoint.ReplicateCheckpoint.MessageID))
assert.NotNil(t, newCheckpoint.ReplicateConfig)
proto = newCheckpoint.IntoProto()
checkpoint2 = NewWALCheckpointFromProto(proto)
assert.True(t, messageID.EQ(checkpoint2.MessageID))
assert.Equal(t, timeTick, checkpoint2.TimeTick)
assert.Equal(t, recoveryMagic, checkpoint2.Magic)
assert.Equal(t, "by-dev", checkpoint2.ReplicateCheckpoint.ClusterID)
assert.Equal(t, "p1", checkpoint2.ReplicateCheckpoint.PChannel)
assert.Equal(t, uint64(123456), checkpoint2.ReplicateCheckpoint.TimeTick)
assert.True(t, rmq.NewRmqID(2).EQ(checkpoint2.ReplicateCheckpoint.MessageID))
assert.NotNil(t, checkpoint2.ReplicateConfig)
checkpoint2 = newCheckpoint.Clone()
assert.True(t, messageID.EQ(checkpoint2.MessageID))
assert.Equal(t, timeTick, checkpoint2.TimeTick)
assert.Equal(t, recoveryMagic, checkpoint2.Magic)
assert.Equal(t, "by-dev", checkpoint2.ReplicateCheckpoint.ClusterID)
assert.Equal(t, "p1", checkpoint2.ReplicateCheckpoint.PChannel)
assert.Equal(t, uint64(123456), checkpoint2.ReplicateCheckpoint.TimeTick)
assert.True(t, rmq.NewRmqID(2).EQ(checkpoint2.ReplicateCheckpoint.MessageID))
assert.NotNil(t, checkpoint2.ReplicateConfig)
}