milvus/pkg/streaming/walimpls/impls/pulsar/message_id_test.go
congqixia cb7f2fa6fd
enhance: Use v2 package name for pkg module (#39990)
Related to #39095

https://go.dev/doc/modules/version-numbers

Update pkg version according to golang dep version convention

---------

Signed-off-by: Congqi Xia <congqi.xia@zilliz.com>
2025-02-22 23:15:58 +08:00

73 lines
1.8 KiB
Go

package pulsar
import (
"testing"
"github.com/apache/pulsar-client-go/pulsar"
"github.com/stretchr/testify/assert"
"google.golang.org/protobuf/proto"
"github.com/milvus-io/milvus/pkg/v2/streaming/util/message"
)
func TestMessageID(t *testing.T) {
pid := message.MessageID(newMessageIDOfPulsar(1, 2, 3)).(interface{ PulsarID() pulsar.MessageID }).PulsarID()
assert.Equal(t, walName, newMessageIDOfPulsar(1, 2, 3).WALName())
assert.Equal(t, int64(1), pid.LedgerID())
assert.Equal(t, int64(2), pid.EntryID())
assert.Equal(t, int32(3), pid.BatchIdx())
ids := []pulsarID{
newMessageIDOfPulsar(0, 0, 0),
newMessageIDOfPulsar(0, 0, 1),
newMessageIDOfPulsar(0, 0, 1000),
newMessageIDOfPulsar(0, 1, 0),
newMessageIDOfPulsar(0, 1, 1000),
newMessageIDOfPulsar(0, 1000, 0),
newMessageIDOfPulsar(1, 0, 0),
newMessageIDOfPulsar(1, 1000, 0),
newMessageIDOfPulsar(2, 0, 0),
}
for x, idx := range ids {
for y, idy := range ids {
assert.Equal(t, idx.EQ(idy), x == y)
assert.Equal(t, idy.EQ(idx), x == y)
assert.Equal(t, idy.LT(idx), x > y)
assert.Equal(t, idy.LTE(idx), x >= y)
assert.Equal(t, idx.LT(idy), x < y)
assert.Equal(t, idx.LTE(idy), x <= y)
}
}
msgID, err := UnmarshalMessageID(pulsarID{newMessageIDOfPulsar(1, 2, 3)}.Marshal())
assert.NoError(t, err)
assert.True(t, msgID.EQ(pulsarID{newMessageIDOfPulsar(1, 2, 3)}))
_, err = UnmarshalMessageID(string([]byte{0x01, 0x02, 0x03, 0x04}))
assert.Error(t, err)
}
// newMessageIDOfPulsar only for test.
func newMessageIDOfPulsar(ledgerID uint64, entryID uint64, batchIdx int32) pulsarID {
id := &MessageIdData{
LedgerId: &ledgerID,
EntryId: &entryID,
BatchIndex: &batchIdx,
}
msg, err := proto.Marshal(id)
if err != nil {
panic(err)
}
msgID, err := pulsar.DeserializeMessageID(msg)
if err != nil {
panic(err)
}
return pulsarID{
msgID,
}
}