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.
gojobs/jobs_test.go

146 lines
2.7 KiB

2 years ago
package gojobs
import (
2 years ago
"github.com/robfig/cron/v3"
2 years ago
"go.dtapp.net/gojobs/pb"
2 years ago
"go.dtapp.net/gouuid"
2 years ago
"io"
"log"
"sync"
"testing"
"time"
)
func TestJobs(t *testing.T) {
2 years ago
wg := sync.WaitGroup{}
2 years ago
wg.Add(4)
2 years ago
go testServer(&wg)
go testCron(&wg)
2 years ago
go testWorker1(&wg)
go testWorker2(&wg)
2 years ago
wg.Wait()
2 years ago
}
2 years ago
func testServer(wg *sync.WaitGroup) {
2 years ago
server := NewServer(&ServerConfig{
PublishTimeout: time.Millisecond * 100,
PubBuffer: 10,
Address: "0.0.0.0:8888",
})
2 years ago
server.StartCron()
2 years ago
2 years ago
server.StartUp()
2 years ago
<-make(chan bool)
2 years ago
wg.Done()
2 years ago
}
func testCron(wg *sync.WaitGroup) {
server := NewCron(&CronConfig{
Address: "localhost:8888",
})
defer server.Conn.Close()
2 years ago
// 创建一个cron实例 精确到秒
c := cron.New(cron.WithSeconds())
// 每隔15秒执行一次
_, _ = c.AddFunc("*/15 * * * * *", func() {
server.Send(&pb.PublishRequest{
2 years ago
Id: gouuid.GetUuId(),
//Value: prefix + "wechat.send" + " 我是定时任务",
Value: prefixSprintf("127.0.0.1") + "wechat.send" + " 我是定时任务",
2 years ago
Ip: "127.0.0.1",
})
})
// 每隔30秒执行一次
_, _ = c.AddFunc("*/30 * * * * *", func() {
server.Send(&pb.PublishRequest{
2 years ago
Id: gouuid.GetUuId(),
//Value: prefix + "wechat.send" + " 我是定时任务",
Value: prefixSprintf("14.155.157.19") + "wechat.send" + " 我是定时任务",
2 years ago
Ip: "14.155.157.19",
})
})
// 启动任务
c.Start()
// 关闭任务
defer c.Stop()
select {}
wg.Done()
}
func testWorker1(wg *sync.WaitGroup) {
2 years ago
server := NewWorker(&WorkerConfig{
Address: "localhost:8888",
ClientIp: "127.0.0.1",
2 years ago
})
defer server.Conn.Close()
2 years ago
2 years ago
// 订阅服务
server.SubscribeCron()
// 启动任务,会想过滤器函数,订阅者应该收到的信息为 cron:任务名称
stream := server.StartCron()
2 years ago
2 years ago
// 阻塞遍历流,输出结果
for {
reply, err := stream.Recv()
if io.EOF == err {
log.Println("[跑业务1]已关闭:", err.Error())
break
2 years ago
}
2 years ago
if nil != err {
log.Println("[跑业务1]异常:", err.Error())
break
}
2 years ago
log.Println("[跑业务1]收到:", reply)
2 years ago
}
wg.Done()
}
2 years ago
func testWorker2(wg *sync.WaitGroup) {
2 years ago
2 years ago
server := NewWorker(&WorkerConfig{
Address: "localhost:8888",
ClientIp: "14.155.157.19",
2 years ago
})
defer server.Conn.Close()
2 years ago
// 订阅服务
server.SubscribeCron()
// 启动任务,会想过滤器函数,订阅者应该收到的信息为 cron:任务名称
stream := server.StartCron()
2 years ago
// 阻塞遍历流,输出结果
for {
reply, err := stream.Recv()
if io.EOF == err {
2 years ago
log.Println("[跑业务2]已关闭:", err.Error())
2 years ago
break
}
if nil != err {
2 years ago
log.Println("[跑业务2]异常:", err.Error())
2 years ago
break
}
2 years ago
log.Println("[跑业务2]收到:", reply)
2 years ago
}
wg.Done()
}