milvus/internal/mq/mqimpl/rocksmq/client/client_impl_test.go

275 lines
7.3 KiB
Go

// Copyright (C) 2019-2020 Zilliz. All rights reserved.
//
// Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance
// with the License. You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software distributed under the License
// is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express
// or implied. See the License for the specific language governing permissions and limitations under the License.
package client
import (
"fmt"
"os"
"testing"
"time"
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/mock"
"github.com/milvus-io/milvus/internal/mq/mqimpl/rocksmq/server"
"github.com/milvus-io/milvus/pkg/mq/msgstream/mqwrapper"
"github.com/milvus-io/milvus/pkg/util/paramtable"
)
var rmqPath = "/tmp/rocksmq_client"
func TestMain(m *testing.M) {
paramtable.Init()
code := m.Run()
os.Exit(code)
}
func TestClient(t *testing.T) {
client, err := NewClient(Options{})
assert.NotNil(t, client)
assert.NoError(t, err)
}
func TestClient_CreateProducer(t *testing.T) {
var client0 client
producer0, err := client0.CreateProducer(ProducerOptions{})
assert.Nil(t, producer0)
assert.Error(t, err)
/////////////////////////////////////////////////
client, err := NewClient(Options{
Server: newMockRocksMQ(),
})
assert.NoError(t, err)
producer, err := client.CreateProducer(ProducerOptions{
Topic: newTopicName(),
})
assert.Error(t, err)
assert.Nil(t, producer)
/////////////////////////////////////////////////
os.MkdirAll(rmqPath, os.ModePerm)
rmqPathTest := rmqPath + "/test_client1"
rmq := newRocksMQ(t, rmqPathTest)
defer removePath(rmqPath)
client1, err := NewClient(Options{
Server: rmq,
})
assert.NoError(t, err)
defer client1.Close()
producer1, err := client1.CreateProducer(ProducerOptions{
Topic: newTopicName(),
})
assert.NotNil(t, producer1)
assert.NoError(t, err)
defer producer1.Close()
// /////////////////////////////////////////////////
// dummyTopic := strings.Repeat(newTopicName(), 100)
// producer2, err := client1.CreateProducer(ProducerOptions{
// Topic: dummyTopic,
// })
// assert.Nil(t, producer2)
// assert.Error(t, err)
}
func TestClient_Subscribe(t *testing.T) {
client, err := NewClient(Options{
Server: newMockRocksMQ(),
})
assert.NoError(t, err)
consumer, err := client.Subscribe(ConsumerOptions{
Topic: newTopicName(),
SubscriptionName: newConsumerName(),
SubscriptionInitialPosition: mqwrapper.SubscriptionPositionEarliest,
})
assert.Error(t, err)
assert.Nil(t, consumer)
/////////////////////////////////////////////////
os.MkdirAll(rmqPath, os.ModePerm)
rmqPathTest := rmqPath + "/test_client2"
rmq := newRocksMQ(t, rmqPathTest)
defer removePath(rmqPath)
client1, err := NewClient(Options{
Server: rmq,
})
assert.NoError(t, err)
defer client1.Close()
opt := ConsumerOptions{
Topic: newTopicName(),
SubscriptionName: newConsumerName(),
SubscriptionInitialPosition: mqwrapper.SubscriptionPositionEarliest,
}
consumer1, err := client1.Subscribe(opt)
assert.NoError(t, err)
assert.NotNil(t, consumer1)
consumer2, err := client1.Subscribe(opt)
assert.NoError(t, err)
assert.NotNil(t, consumer2)
opt1 := ConsumerOptions{
Topic: newTopicName(),
SubscriptionName: newConsumerName(),
SubscriptionInitialPosition: mqwrapper.SubscriptionPositionLatest,
}
consumer3, err := client1.Subscribe(opt1)
assert.NoError(t, err)
assert.NotNil(t, consumer3)
consumer4, err := client1.Subscribe(opt1)
assert.NoError(t, err)
assert.NotNil(t, consumer4)
producer1, err := client1.CreateProducer(ProducerOptions{
Topic: newTopicName(),
})
assert.NotNil(t, producer1)
assert.NoError(t, err)
}
func TestClient_SubscribeError(t *testing.T) {
mockMQ := server.NewMockRocksMQ(t)
client, err := NewClient(Options{
Server: mockMQ,
})
testTopic := newTopicName()
testGroupName := newConsumerName()
assert.NoError(t, err)
mockMQ.EXPECT().ExistConsumerGroup(testTopic, testGroupName).Return(false, nil, nil)
mockMQ.EXPECT().CreateConsumerGroup(testTopic, testGroupName).Return(nil)
mockMQ.EXPECT().RegisterConsumer(mock.Anything).Return(nil)
mockMQ.EXPECT().SeekToLatest(testTopic, testGroupName).Return(fmt.Errorf("test error"))
consumer, err := client.Subscribe(ConsumerOptions{
Topic: testTopic,
SubscriptionName: testGroupName,
SubscriptionInitialPosition: mqwrapper.SubscriptionPositionLatest,
})
assert.Error(t, err)
assert.Nil(t, consumer)
}
func TestClient_SeekLatest(t *testing.T) {
os.MkdirAll(rmqPath, os.ModePerm)
rmqPathTest := rmqPath + "/seekLatest"
rmq := newRocksMQ(t, rmqPathTest)
defer removePath(rmqPath)
client, err := NewClient(Options{
Server: rmq,
})
assert.NoError(t, err)
defer client.Close()
topicName := newTopicName()
opt := ConsumerOptions{
Topic: topicName,
SubscriptionName: newConsumerName(),
SubscriptionInitialPosition: mqwrapper.SubscriptionPositionEarliest,
}
consumer1, err := client.Subscribe(opt)
assert.NoError(t, err)
assert.NotNil(t, consumer1)
producer, err := client.CreateProducer(ProducerOptions{
Topic: topicName,
})
assert.NotNil(t, producer)
assert.NoError(t, err)
msg := &ProducerMessage{
Payload: make([]byte, 10),
Properties: map[string]string{},
}
id, err := producer.Send(msg)
assert.NoError(t, err)
msgChan := consumer1.Chan()
msgRead, ok := <-msgChan
assert.Equal(t, ok, true)
assert.Equal(t, msgRead.MsgID, id)
consumer1.Close()
opt1 := ConsumerOptions{
Topic: topicName,
SubscriptionName: newConsumerName(),
SubscriptionInitialPosition: mqwrapper.SubscriptionPositionLatest,
}
consumer2, err := client.Subscribe(opt1)
assert.NoError(t, err)
assert.NotNil(t, consumer2)
msgChan = consumer2.Chan()
loop := true
ticker := time.NewTicker(2 * time.Second)
defer ticker.Stop()
for loop {
select {
case msg := <-msgChan:
assert.Equal(t, len(msg.Payload), 8)
loop = false
case <-ticker.C:
msg := &ProducerMessage{
Payload: make([]byte, 8),
}
_, err = producer.Send(msg)
assert.NoError(t, err)
}
}
producer1, err := client.CreateProducer(ProducerOptions{
Topic: newTopicName(),
})
assert.NotNil(t, producer1)
assert.NoError(t, err)
}
func TestClient_consume(t *testing.T) {
os.MkdirAll(rmqPath, os.ModePerm)
rmqPathTest := rmqPath + "/test_client3"
rmq := newRocksMQ(t, rmqPathTest)
defer removePath(rmqPath)
client, err := NewClient(Options{
Server: rmq,
})
assert.NoError(t, err)
defer client.Close()
topicName := newTopicName()
producer, err := client.CreateProducer(ProducerOptions{
Topic: topicName,
})
assert.NotNil(t, producer)
assert.NoError(t, err)
opt := ConsumerOptions{
Topic: topicName,
SubscriptionName: newConsumerName(),
SubscriptionInitialPosition: mqwrapper.SubscriptionPositionEarliest,
}
consumer, err := client.Subscribe(opt)
assert.NoError(t, err)
assert.NotNil(t, consumer)
msg := &ProducerMessage{
Payload: make([]byte, 10),
}
id, err := producer.Send(msg)
assert.NoError(t, err)
msgChan := consumer.Chan()
msgConsume, ok := <-msgChan
assert.Equal(t, ok, true)
assert.Equal(t, id, msgConsume.MsgID)
}