mirror of
https://gitee.com/milvus-io/milvus.git
synced 2025-12-07 09:38:39 +08:00
148 lines
3.0 KiB
Go
148 lines
3.0 KiB
Go
package adaptor
|
|
|
|
import (
|
|
"context"
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
"github.com/milvus-io/milvus/pkg/v2/mocks/streaming/util/mock_message"
|
|
"github.com/milvus-io/milvus/pkg/v2/streaming/util/message"
|
|
"github.com/milvus-io/milvus/pkg/v2/streaming/walimpls/impls/rmq"
|
|
)
|
|
|
|
func TestDeplicatedMessageOnMsgPackHandler(t *testing.T) {
|
|
messageID := rmq.NewRmqID(1)
|
|
tt := uint64(100)
|
|
msg := message.CreateTestInsertMessage(
|
|
t,
|
|
1,
|
|
1000,
|
|
tt,
|
|
messageID,
|
|
)
|
|
msg2 := message.CreateTestInsertMessage(
|
|
t,
|
|
1,
|
|
1000,
|
|
101,
|
|
messageID,
|
|
)
|
|
immutableMsg := msg.WithOldVersion().IntoImmutableMessage(messageID)
|
|
|
|
upstream := make(chan message.ImmutableMessage, 3)
|
|
upstream <- immutableMsg
|
|
upstream <- immutableMsg
|
|
upstream <- msg2.IntoImmutableMessage(messageID)
|
|
|
|
h := NewMsgPackAdaptorHandler()
|
|
done := make(chan struct{})
|
|
go func() {
|
|
for msg := range h.Chan() {
|
|
assert.Len(t, msg.Msgs, 1)
|
|
}
|
|
close(done)
|
|
}()
|
|
var resp message.HandleResult
|
|
for i := 0; i < 10; i++ {
|
|
var upstream2 <-chan message.ImmutableMessage
|
|
if len(upstream) > 0 {
|
|
upstream2 = upstream
|
|
}
|
|
resp = h.Handle(message.HandleParam{
|
|
Ctx: context.Background(),
|
|
Upstream: upstream2,
|
|
Message: resp.Incoming,
|
|
})
|
|
}
|
|
h.Close()
|
|
<-done
|
|
}
|
|
|
|
func TestMsgPackAdaptorHandler(t *testing.T) {
|
|
messageID := rmq.NewRmqID(1)
|
|
tt := uint64(100)
|
|
msg := message.CreateTestInsertMessage(
|
|
t,
|
|
1,
|
|
1000,
|
|
tt,
|
|
messageID,
|
|
)
|
|
immutableMsg := msg.IntoImmutableMessage(messageID)
|
|
|
|
upstream := make(chan message.ImmutableMessage, 1)
|
|
|
|
ctx := context.Background()
|
|
h := NewMsgPackAdaptorHandler()
|
|
done := make(chan struct{})
|
|
go func() {
|
|
for range h.Chan() {
|
|
}
|
|
close(done)
|
|
}()
|
|
upstream <- immutableMsg
|
|
resp := h.Handle(message.HandleParam{
|
|
Ctx: ctx,
|
|
Upstream: upstream,
|
|
Message: nil,
|
|
})
|
|
assert.Equal(t, resp.Incoming, immutableMsg)
|
|
assert.False(t, resp.MessageHandled)
|
|
assert.NoError(t, resp.Error)
|
|
|
|
resp = h.Handle(message.HandleParam{
|
|
Ctx: ctx,
|
|
Upstream: upstream,
|
|
Message: resp.Incoming,
|
|
})
|
|
assert.NoError(t, resp.Error)
|
|
assert.Nil(t, resp.Incoming)
|
|
assert.True(t, resp.MessageHandled)
|
|
|
|
resp = h.Handle(message.HandleParam{
|
|
Ctx: ctx,
|
|
})
|
|
assert.NoError(t, resp.Error)
|
|
assert.Nil(t, resp.Incoming)
|
|
assert.False(t, resp.MessageHandled)
|
|
h.Close()
|
|
|
|
<-done
|
|
}
|
|
|
|
func TestDefaultHandler(t *testing.T) {
|
|
h := make(ChanMessageHandler, 1)
|
|
done := make(chan struct{})
|
|
go func() {
|
|
for range h {
|
|
}
|
|
close(done)
|
|
}()
|
|
|
|
upstream := make(chan message.ImmutableMessage, 1)
|
|
msg := mock_message.NewMockImmutableMessage(t)
|
|
upstream <- msg
|
|
resp := h.Handle(message.HandleParam{
|
|
Ctx: context.Background(),
|
|
Upstream: upstream,
|
|
Message: nil,
|
|
})
|
|
assert.NotNil(t, resp.Incoming)
|
|
assert.NoError(t, resp.Error)
|
|
assert.False(t, resp.MessageHandled)
|
|
assert.Equal(t, resp.Incoming, msg)
|
|
|
|
resp = h.Handle(message.HandleParam{
|
|
Ctx: context.Background(),
|
|
Upstream: upstream,
|
|
Message: resp.Incoming,
|
|
})
|
|
assert.NoError(t, resp.Error)
|
|
assert.Nil(t, resp.Incoming)
|
|
assert.True(t, resp.MessageHandled)
|
|
|
|
h.Close()
|
|
<-done
|
|
}
|