milvus/pkg/streaming/util/message/builder_test.go
Zhen Ye 2aa48bf4ca
fix: wrong execution order of DDL/DCL on secondary (#44886)
issue: #44697, #44696

- The DDL executing order of secondary keep same with order of control
channel timetick now.
- filtering the control channel operation on shard manager of
streamingnode to avoid wrong vchannel of create segment.
- fix that the immutable txn message lost replicate header.

---------

Signed-off-by: chyezh <chyezh@outlook.com>
2025-10-21 22:38:05 +08:00

125 lines
4.5 KiB
Go

package message_test
import (
"testing"
"time"
"github.com/stretchr/testify/assert"
"go.uber.org/zap"
"github.com/milvus-io/milvus-proto/go-api/v2/msgpb"
"github.com/milvus-io/milvus/pkg/v2/log"
"github.com/milvus-io/milvus/pkg/v2/streaming/util/message"
"github.com/milvus-io/milvus/pkg/v2/streaming/walimpls/impls/walimplstest"
)
func TestMutableBuilder(t *testing.T) {
b := message.NewTimeTickMessageBuilderV1().
WithHeader(&message.TimeTickMessageHeader{}).
WithBody(&msgpb.TimeTickMsg{}).
WithAllVChannel().
MustBuildMutable()
assert.True(t, b.IsPersisted())
assert.Equal(t, b.VChannel(), "")
log.Info("test", zap.Object("msg", b))
b = message.NewTimeTickMessageBuilderV1().
WithHeader(&message.TimeTickMessageHeader{}).
WithBody(&msgpb.TimeTickMsg{}).
WithNotPersisted().
WithVChannel("v1").
MustBuildMutable()
assert.False(t, b.IsPersisted())
assert.Equal(t, b.VChannel(), "v1")
log.Info("test", zap.Object("msg", b))
assert.Panics(t, func() {
message.NewCreateCollectionMessageBuilderV1().WithNotPersisted()
})
}
func TestImmutableTxnBuilder(t *testing.T) {
txnCtx := message.TxnContext{
TxnID: 1,
Keepalive: time.Second,
}
begin := message.NewBeginTxnMessageBuilderV2().
WithHeader(&message.BeginTxnMessageHeader{
KeepaliveMilliseconds: 1000,
}).
WithBody(&message.BeginTxnMessageBody{}).
WithVChannel("v1").
MustBuildMutable()
msgID := walimplstest.NewTestMessageID(1)
immutableBegin := begin.WithTimeTick(1).WithTxnContext(txnCtx).WithLastConfirmed(msgID).IntoImmutableMessage(msgID)
b := message.NewImmutableTxnMessageBuilder(message.MustAsImmutableBeginTxnMessageV2(immutableBegin))
assert.NotZero(t, b.EstimateSize())
assert.Greater(t, b.ExpiredTimeTick(), uint64(1))
msg := message.NewInsertMessageBuilderV1().
WithHeader(&message.InsertMessageHeader{}).
WithBody(&msgpb.InsertRequest{}).
WithVChannel("v1").
MustBuildMutable()
mutableMsg := msg.WithTimeTick(2).WithTxnContext(txnCtx).WithLastConfirmed(msgID)
log.Info("test", zap.Object("msg", mutableMsg))
immutableMsg := mutableMsg.IntoImmutableMessage(msgID)
b.Add(immutableMsg)
commit := message.NewCommitTxnMessageBuilderV2().
WithHeader(&message.CommitTxnMessageHeader{}).
WithBody(&message.CommitTxnMessageBody{}).
WithVChannel("v1").
MustBuildMutable()
rh := message.ReplicateHeader{
ClusterID: "by-dev",
MessageID: msgID,
LastConfirmedMessageID: msgID,
TimeTick: 3,
VChannel: "v1",
}
immutableCommit := commit.WithTimeTick(3).WithTxnContext(txnCtx).WithLastConfirmed(msgID).WithReplicateHeader(&rh).IntoImmutableMessage(msgID)
log.Info("test", zap.Object("msg", immutableCommit))
assert.NotZero(t, b.EstimateSize())
beginMsg, msgs := b.Messages()
assert.NotEmpty(t, beginMsg)
assert.Len(t, msgs, 1)
immutableTxnMsg, err := b.Build(message.MustAsImmutableCommitTxnMessageV2(immutableCommit))
assert.NoError(t, err)
assert.Equal(t, "by-dev", immutableTxnMsg.ReplicateHeader().ClusterID)
assert.Equal(t, uint64(3), immutableTxnMsg.ReplicateHeader().TimeTick)
assert.Equal(t, "v1", immutableTxnMsg.ReplicateHeader().VChannel)
assert.Equal(t, msgID, immutableTxnMsg.ReplicateHeader().MessageID)
assert.Equal(t, msgID, immutableTxnMsg.ReplicateHeader().LastConfirmedMessageID)
log.Info("test", zap.Object("msg", immutableTxnMsg))
}
func TestReplicateBuilder(t *testing.T) {
msg := message.NewManualFlushMessageBuilderV2().
WithHeader(&message.ManualFlushMessageHeader{}).
WithBody(&message.ManualFlushMessageBody{}).
WithBroadcast([]string{"v1", "v2"}).
MustBuildBroadcast()
msgs := msg.WithBroadcastID(1).SplitIntoMutableMessage()
msgID := walimplstest.NewTestMessageID(1)
immutableMsg := msgs[0].WithTimeTick(100).WithLastConfirmed(msgID).IntoImmutableMessage(msgID)
replicateMsg := message.MustNewReplicateMessage("by-dev", immutableMsg.IntoImmutableMessageProto())
assert.NotNil(t, replicateMsg)
assert.Equal(t, "by-dev", replicateMsg.ReplicateHeader().ClusterID)
assert.Equal(t, uint64(100), replicateMsg.ReplicateHeader().TimeTick)
assert.Equal(t, "v1", replicateMsg.ReplicateHeader().VChannel)
assert.Equal(t, "v1", replicateMsg.VChannel())
assert.True(t, msgID.EQ(replicateMsg.ReplicateHeader().MessageID))
assert.True(t, msgID.EQ(replicateMsg.ReplicateHeader().LastConfirmedMessageID))
replicateMsg.OverwriteReplicateVChannel("v11", []string{"v11", "v12"})
assert.Equal(t, "v11", replicateMsg.VChannel())
assert.Equal(t, []string{"v11", "v12"}, replicateMsg.BroadcastHeader().VChannels)
assert.Equal(t, uint64(1), replicateMsg.BroadcastHeader().BroadcastID)
}