mirror of
https://github.com/go-micro/go-micro.git
synced 2025-06-30 22:33:49 +02:00
add all the plugins
This commit is contained in:
200
plugins/broker/segmentio/segmentio_test.go
Normal file
200
plugins/broker/segmentio/segmentio_test.go
Normal file
@ -0,0 +1,200 @@
|
||||
package segmentio_test
|
||||
|
||||
import (
|
||||
"os"
|
||||
"strings"
|
||||
"sync/atomic"
|
||||
"testing"
|
||||
|
||||
"github.com/micro/go-micro/v2/broker"
|
||||
segmentio "github.com/micro/go-micro/plugins/broker/segmentio/v2"
|
||||
segjson "github.com/micro/go-micro/plugins/codec/segmentio/v2"
|
||||
)
|
||||
|
||||
func BenchmarkSegmentioCodecJsonPublish(b *testing.B) {
|
||||
// b.Skip()
|
||||
if tr := os.Getenv("TRAVIS"); len(tr) > 0 {
|
||||
b.Skip()
|
||||
}
|
||||
|
||||
var addrs []string
|
||||
if addr := os.Getenv("BROKER_ADDRS"); len(addr) == 0 {
|
||||
addrs = []string{"127.0.0.1:9092"}
|
||||
} else {
|
||||
addrs = strings.Split(addr, ",")
|
||||
}
|
||||
|
||||
brk := segmentio.NewBroker(broker.Addrs(addrs...))
|
||||
if err := brk.Connect(); err != nil {
|
||||
b.Fatal(err)
|
||||
}
|
||||
defer func() {
|
||||
if err := brk.Disconnect(); err != nil {
|
||||
b.Fatal(err)
|
||||
}
|
||||
}()
|
||||
|
||||
b.ResetTimer()
|
||||
for i := 0; i < b.N; i++ {
|
||||
if err := brk.Publish("test_topic", bm); err != nil {
|
||||
b.Fatal(err)
|
||||
}
|
||||
}
|
||||
}
|
||||
func BenchmarkSegmentioCodecSegmentioPublish(b *testing.B) {
|
||||
if tr := os.Getenv("TRAVIS"); len(tr) > 0 {
|
||||
b.Skip()
|
||||
}
|
||||
|
||||
var addrs []string
|
||||
if addr := os.Getenv("BROKER_ADDRS"); len(addr) == 0 {
|
||||
addrs = []string{"127.0.0.1:9092"}
|
||||
} else {
|
||||
addrs = strings.Split(addr, ",")
|
||||
}
|
||||
|
||||
brk := segmentio.NewBroker(broker.Codec(segjson.Marshaler{}), broker.Addrs(addrs...))
|
||||
if err := brk.Connect(); err != nil {
|
||||
b.Fatal(err)
|
||||
}
|
||||
defer func() {
|
||||
if err := brk.Disconnect(); err != nil {
|
||||
b.Fatal(err)
|
||||
}
|
||||
}()
|
||||
|
||||
b.ResetTimer()
|
||||
for i := 0; i < b.N; i++ {
|
||||
if err := brk.Publish("test_topic", bm); err != nil {
|
||||
b.Fatal(err)
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
func BenchmarkSegmentioCodecJsonSubscribe(b *testing.B) {
|
||||
b.Skip()
|
||||
if tr := os.Getenv("TRAVIS"); len(tr) > 0 {
|
||||
b.Skip()
|
||||
}
|
||||
|
||||
var addrs []string
|
||||
if addr := os.Getenv("BROKER_ADDRS"); len(addr) == 0 {
|
||||
addrs = []string{"127.0.0.1:9092"}
|
||||
} else {
|
||||
addrs = strings.Split(addr, ",")
|
||||
}
|
||||
|
||||
brk := segmentio.NewBroker(broker.Addrs(addrs...))
|
||||
if err := brk.Connect(); err != nil {
|
||||
b.Fatal(err)
|
||||
}
|
||||
defer func() {
|
||||
if err := brk.Disconnect(); err != nil {
|
||||
b.Fatal(err)
|
||||
}
|
||||
}()
|
||||
|
||||
cnt := 0
|
||||
var done atomic.Value
|
||||
done.Store(false)
|
||||
exit := make(chan struct{})
|
||||
fn := func(msg broker.Event) error {
|
||||
if cnt == 0 {
|
||||
b.ResetTimer()
|
||||
}
|
||||
cnt++
|
||||
if cnt == b.N {
|
||||
if v := done.Load().(bool); !v {
|
||||
done.Store(true)
|
||||
close(exit)
|
||||
}
|
||||
}
|
||||
return msg.Ack()
|
||||
}
|
||||
|
||||
go func() {
|
||||
for i := 0; i < b.N; i++ {
|
||||
if v, ok := done.Load().(bool); ok && v {
|
||||
return
|
||||
}
|
||||
if err := brk.Publish("test_topic", bm); err != nil {
|
||||
b.Fatal(err)
|
||||
}
|
||||
}
|
||||
}()
|
||||
|
||||
sub, err := brk.Subscribe("test_topic", fn, broker.Queue("test"))
|
||||
if err != nil {
|
||||
b.Fatal(err)
|
||||
}
|
||||
defer func() {
|
||||
if err := sub.Unsubscribe(); err != nil {
|
||||
b.Fatal(err)
|
||||
}
|
||||
}()
|
||||
<-exit
|
||||
}
|
||||
|
||||
func BenchmarkSegmentioCodecSegmentioSubscribe(b *testing.B) {
|
||||
if tr := os.Getenv("TRAVIS"); len(tr) > 0 {
|
||||
b.Skip()
|
||||
}
|
||||
|
||||
var addrs []string
|
||||
if addr := os.Getenv("BROKER_ADDRS"); len(addr) == 0 {
|
||||
addrs = []string{"127.0.0.1:9092"}
|
||||
} else {
|
||||
addrs = strings.Split(addr, ",")
|
||||
}
|
||||
|
||||
brk := segmentio.NewBroker(broker.Codec(segjson.Marshaler{}), broker.Addrs(addrs...))
|
||||
if err := brk.Connect(); err != nil {
|
||||
b.Fatal(err)
|
||||
}
|
||||
defer func() {
|
||||
if err := brk.Disconnect(); err != nil {
|
||||
b.Fatal(err)
|
||||
}
|
||||
}()
|
||||
|
||||
cnt := 0
|
||||
var done atomic.Value
|
||||
done.Store(false)
|
||||
exit := make(chan struct{})
|
||||
fn := func(msg broker.Event) error {
|
||||
if cnt == 0 {
|
||||
b.ResetTimer()
|
||||
}
|
||||
cnt++
|
||||
if cnt == b.N {
|
||||
if v, ok := done.Load().(bool); ok && !v {
|
||||
done.Store(true)
|
||||
close(exit)
|
||||
}
|
||||
}
|
||||
return msg.Ack()
|
||||
}
|
||||
|
||||
go func() {
|
||||
for i := 0; i < b.N; i++ {
|
||||
if v := done.Load().(bool); v {
|
||||
return
|
||||
}
|
||||
if err := brk.Publish("test_topic", bm); err != nil {
|
||||
b.Fatal(err)
|
||||
}
|
||||
}
|
||||
}()
|
||||
|
||||
sub, err := brk.Subscribe("test_topic", fn, broker.Queue("test"))
|
||||
if err != nil {
|
||||
b.Fatal(err)
|
||||
}
|
||||
defer func() {
|
||||
if err := sub.Unsubscribe(); err != nil {
|
||||
b.Fatal(err)
|
||||
}
|
||||
}()
|
||||
<-exit
|
||||
}
|
Reference in New Issue
Block a user