milvus/pkg/streaming/util/message/message_id_test.go
chyezh cc8f7aa110
fix: streaming service related fix patch (#34696)
issue: #33285

- add idAlloc interface
- fix binary unsafe bug for message
- fix service discovery lost when repeated address with different server
id

---------

Signed-off-by: chyezh <chyezh@outlook.com>
2024-07-16 15:49:38 +08:00

44 lines
1005 B
Go

package message_test
import (
"testing"
"github.com/cockroachdb/errors"
"github.com/stretchr/testify/assert"
"github.com/milvus-io/milvus/pkg/mocks/streaming/util/mock_message"
"github.com/milvus-io/milvus/pkg/streaming/util/message"
)
func TestRegisterMessageIDUnmarshaler(t *testing.T) {
msgID := mock_message.NewMockMessageID(t)
message.RegisterMessageIDUnmsarshaler("test", func(b string) (message.MessageID, error) {
if b == "123" {
return msgID, nil
}
return nil, errors.New("invalid")
})
id, err := message.UnmarshalMessageID("test", "123")
assert.NotNil(t, id)
assert.NoError(t, err)
id, err = message.UnmarshalMessageID("test", "1234")
assert.Nil(t, id)
assert.Error(t, err)
assert.Panics(t, func() {
message.UnmarshalMessageID("test1", "123")
})
assert.Panics(t, func() {
message.RegisterMessageIDUnmsarshaler("test", func(b string) (message.MessageID, error) {
if b == "123" {
return msgID, nil
}
return nil, errors.New("invalid")
})
})
}