chyezh 3563136c2a
enhance: timetick interceptor implementation (#34238)
issue: #33285

- optimize the message package
- add interceptor package to achieve append operation intercepting.
- add timetick interceptor to attach timetick properties for message.
- add timetick background task to send timetick message.

Signed-off-by: chyezh <chyezh@outlook.com>
2024-07-02 14:42:08 +08:00

64 lines
1.4 KiB
Go

//go:build test
// +build test
package walimplstest
import (
"strconv"
"github.com/milvus-io/milvus/pkg/streaming/util/message"
)
var _ message.MessageID = testMessageID(0)
// NewTestMessageID create a new test message id.
func NewTestMessageID(id int64) message.MessageID {
return testMessageID(id)
}
// UnmarshalTestMessageID unmarshal the message id.
func UnmarshalTestMessageID(data []byte) (message.MessageID, error) {
id, err := unmarshalTestMessageID(data)
if err != nil {
return nil, err
}
return id, nil
}
// unmashalTestMessageID unmarshal the message id.
func unmarshalTestMessageID(data []byte) (testMessageID, error) {
id, err := strconv.ParseInt(string(data), 10, 64)
if err != nil {
return 0, err
}
return testMessageID(id), nil
}
// testMessageID is the message id for rmq.
type testMessageID int64
// WALName returns the name of message id related wal.
func (id testMessageID) WALName() string {
return WALName
}
// LT less than.
func (id testMessageID) LT(other message.MessageID) bool {
return id < other.(testMessageID)
}
// LTE less than or equal to.
func (id testMessageID) LTE(other message.MessageID) bool {
return id <= other.(testMessageID)
}
// EQ Equal to.
func (id testMessageID) EQ(other message.MessageID) bool {
return id == other.(testMessageID)
}
// Marshal marshal the message id.
func (id testMessageID) Marshal() []byte {
return []byte(strconv.FormatInt(int64(id), 10))
}