You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

255 lines
7.0 KiB

package test
import (
"fmt"
amqp "github.com/rabbitmq/amqp091-go"
"goskeleton/app/global/my_errors"
"goskeleton/app/utils/rabbitmq/hello_world"
"goskeleton/app/utils/rabbitmq/publish_subscribe"
"goskeleton/app/utils/rabbitmq/routing"
"goskeleton/app/utils/rabbitmq/topics"
"goskeleton/app/utils/rabbitmq/work_queue"
_ "goskeleton/bootstrap"
"os"
"strconv"
"testing"
)
// 消息队列rabbitmq在线文档地址https://www.yuque.com/xiaofensinixidaouxiang/bkfhct/tkcuc8
// 延迟消息队列在线文档地址https://www.yuque.com/xiaofensinixidaouxiang/bkfhct/grroyv
// 本篇的单元测试提供的是非延迟消息队列的测试,只要学会单元测试提供的示例,延迟队列也是非常简单的,参考在线文档即可
// 1.HelloWorld 模式
func TestRabbitMqHelloWorldProducer(t *testing.T) {
helloProducer, err := hello_world.CreateProducer()
if err != nil {
t.Errorf("HelloWorld单元测试未通过。%s\n", err.Error())
os.Exit(1)
}
var res bool
for i := 0; i < 10; i++ {
str := fmt.Sprintf("%d_HelloWorld开始发送消息测试", i+1)
res = helloProducer.Send(str)
//time.Sleep(time.Second * 1)
}
helloProducer.Close() // 消息投递结束,必须关闭连接
// 总共发送了10条消息我们简单判断一下最后一条消息返回的结果
if res {
t.Log("消息发送OK")
} else {
t.Errorf("HelloWorld模式消息发送失败")
}
}
// 消费者
func TestMqHelloWorldConsumer(t *testing.T) {
consumer, err := hello_world.CreateConsumer()
if err != nil {
t.Errorf("HelloWorld单元测试未通过。%s\n", err.Error())
os.Exit(1)
}
consumer.OnConnectionError(func(err *amqp.Error) {
t.Errorf(my_errors.ErrorsRabbitMqReconnectFail+"%s\n", err.Error())
})
consumer.Received(func(receivedData string) {
t.Logf("HelloWorld回调函数处理消息--->%s\n", receivedData)
})
}
// 2.WorkQueue模式
func TestRabbitMqWorkQueueProducer(t *testing.T) {
producer, _ := work_queue.CreateProducer()
var res bool
for i := 0; i < 10; i++ {
str := fmt.Sprintf("%d_WorkQueue开始发送消息测试", i+1)
res = producer.Send(str)
//time.Sleep(time.Second * 1)
}
producer.Close() // 消息投递结束,必须关闭连接
if res {
t.Logf("消息发送OK")
} else {
t.Errorf("WorkQueue模式消息发送失败")
}
}
// 消费者
func TestMqWorkQueueConsumer(t *testing.T) {
consumer, err := work_queue.CreateConsumer()
if err != nil {
t.Errorf("WorkQueue单元测试未通过。%s\n", err.Error())
os.Exit(1)
}
consumer.OnConnectionError(func(err *amqp.Error) {
t.Errorf(my_errors.ErrorsRabbitMqReconnectFail + ", %s" + err.Error())
})
consumer.Received(func(receivedData string) {
t.Logf("WorkQueue回调函数处理消息--->%s\n", receivedData)
})
}
// 3.PublishSubscribe 发布、订阅模式模式
func TestRabbitMqPublishSubscribeProducer(t *testing.T) {
producer, err := publish_subscribe.CreateProducer()
if err != nil {
t.Errorf("WorkQueue 单元测试未通过。%s\n", err.Error())
os.Exit(1)
}
var res bool
for i := 0; i < 10; i++ {
str := fmt.Sprintf("%d_PublishSubscribe开始发送消息测试", i+1)
// 参数二: 消息延迟的毫秒数,只有创建的对象是延迟模式该参数才有效
res = producer.Send(str, 1000)
fmt.Println(str, res)
//time.Sleep(time.Second * 2)
}
producer.Close() // 消息投递结束,必须关闭连接
if res {
t.Log("消息发送OK")
} else {
t.Errorf("PublishSubscribe 模式消息发送失败")
}
}
// 消费者
func TestRabbitMqPublishSubscribeConsumer(t *testing.T) {
consumer, err := publish_subscribe.CreateConsumer()
if err != nil {
t.Errorf("PublishSubscribe单元测试未通过。%s\n", err.Error())
os.Exit(1)
}
consumer.OnConnectionError(func(err *amqp.Error) {
t.Errorf(my_errors.ErrorsRabbitMqReconnectFail + "%s\n" + err.Error())
})
consumer.Received(func(receivedData string) {
t.Logf("PublishSubscribe回调函数处理消息--->%s\n", receivedData)
})
}
// Routing 路由模式
func TestRabbitMqRoutingProducer(t *testing.T) {
producer, err := routing.CreateProducer()
if err != nil {
t.Errorf("Routing单元测试未通过。%s\n", err.Error())
os.Exit(1)
}
var res bool
var key string
for i := 1; i <= 20; i++ {
// 将 偶数 和 奇数 分发到不同的key消费者端启动两个也各自处理偶数和奇数
if i%2 == 0 {
key = "key_even" // 偶数键
} else {
key = "key_odd" // 奇数键
}
//strData := fmt.Sprintf("%d_Routing_%s, 开始发送消息测试"+time.Now().Format("2006-01-02 15:04:05"), i, key)
// 参数三: 消息延迟的毫秒数,只有创建的对象是延迟模式该参数才有效
res = producer.Send(key, strconv.Itoa(i)+"- Routing开始发送消息测试", 10000)
//time.Sleep(time.Second * 1)
}
producer.Close() // 消息投递结束,必须关闭连接
if res {
t.Logf("消息发送OK")
} else {
t.Errorf("Routing 模式消息发送失败")
}
}
// 消费者
func TestRabbitMqRoutingConsumer(t *testing.T) {
consumer, err := routing.CreateConsumer()
if err != nil {
t.Errorf("Routing单元测试未通过。%s\n", err.Error())
os.Exit(1)
}
consumer.OnConnectionError(func(err *amqp.Error) {
t.Errorf(my_errors.ErrorsRabbitMqReconnectFail + " %s\n" + err.Error())
})
// 通过route_key 匹配指定队列的消息来处理
consumer.Received("key_even", func(receivedData string) {
fmt.Println("处理偶数的回调函数 ---> 收到消息内容: " + receivedData)
// t.Logf("处理偶数的回调函数:--->收到消息时间:%s - 消息内容:%s\n", time.Now().Format("2006-01-02 15:04:05"), receivedData)
})
}
// topics 模式
func TestRabbitMqTopicsProducer(t *testing.T) {
producer, err := topics.CreateProducer()
if err != nil {
t.Errorf("Routing单元测试未通过。%s\n", err.Error())
os.Exit(1)
}
var res bool
var key string
for i := 1; i <= 10; i++ {
// 将 偶数 和 奇数 分发到不同的key消费者端启动两个也各自处理偶数和奇数
if i%2 == 0 {
key = "key.even" // 偶数键
} else {
key = "key.odd" // 奇数键
}
strData := fmt.Sprintf("%d_Routing_%s, 开始发送消息测试", i, key)
// 参数三: 消息延迟的毫秒数,只有创建的对象是延迟模式该参数才有效
res = producer.Send(key, strData, 10000)
//time.Sleep(time.Second * 1)
}
producer.Close() // 消息投递结束,必须关闭连接
if res {
t.Logf("消息发送OK")
} else {
t.Errorf("topics 模式消息发送失败")
}
//Output: 消息发送OK
}
// 消费者
func TestRabbitMqTopicsConsumer(t *testing.T) {
consumer, err := topics.CreateConsumer()
if err != nil {
t.Errorf("Routing单元测试未通过。%s\n", err.Error())
os.Exit(1)
}
consumer.OnConnectionError(func(err *amqp.Error) {
t.Errorf(my_errors.ErrorsRabbitMqReconnectFail + " %s\n" + err.Error())
})
// 通过route_key 模糊匹配队列路由键的消息来处理
consumer.Received("#.odd", func(receivedData string) {
t.Logf("模糊匹配偶数键:--->%s\n", receivedData)
})
}