2020-08-23 20:37:22 +03:00
|
|
|
package http
|
|
|
|
|
|
|
|
import (
|
2021-01-29 18:57:29 +03:00
|
|
|
"context"
|
2020-08-23 20:37:22 +03:00
|
|
|
"sync"
|
|
|
|
"testing"
|
|
|
|
|
2021-10-28 01:00:16 +03:00
|
|
|
"go.unistack.org/micro/v3/network/transport"
|
2020-08-23 20:37:22 +03:00
|
|
|
)
|
|
|
|
|
|
|
|
func call(b *testing.B, c int) {
|
|
|
|
b.StopTimer()
|
|
|
|
|
2021-01-29 18:57:29 +03:00
|
|
|
ctx := context.Background()
|
2020-08-23 20:37:22 +03:00
|
|
|
tr := NewTransport()
|
|
|
|
|
|
|
|
// server listen
|
2021-01-29 18:57:29 +03:00
|
|
|
l, err := tr.Listen(ctx, "localhost:0")
|
2020-08-23 20:37:22 +03:00
|
|
|
if err != nil {
|
|
|
|
b.Fatal(err)
|
|
|
|
}
|
|
|
|
defer l.Close()
|
|
|
|
|
|
|
|
// socket func
|
|
|
|
fn := func(sock transport.Socket) {
|
|
|
|
defer sock.Close()
|
|
|
|
|
|
|
|
for {
|
|
|
|
var m transport.Message
|
|
|
|
if err := sock.Recv(&m); err != nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := sock.Send(&m); err != nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
done := make(chan bool)
|
|
|
|
|
|
|
|
// accept connections
|
|
|
|
go func() {
|
|
|
|
if err := l.Accept(fn); err != nil {
|
|
|
|
select {
|
|
|
|
case <-done:
|
|
|
|
default:
|
|
|
|
b.Fatalf("Unexpected accept err: %v", err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}()
|
|
|
|
|
|
|
|
m := transport.Message{
|
|
|
|
Header: map[string]string{
|
|
|
|
"Content-Type": "application/json",
|
|
|
|
},
|
|
|
|
Body: []byte(`{"message": "Hello World"}`),
|
|
|
|
}
|
|
|
|
|
|
|
|
// client connection
|
2021-01-29 18:57:29 +03:00
|
|
|
client, err := tr.Dial(ctx, l.Addr())
|
2020-08-23 20:37:22 +03:00
|
|
|
if err != nil {
|
|
|
|
b.Fatalf("Unexpected dial err: %v", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
send := func(c transport.Client) {
|
|
|
|
// send message
|
|
|
|
if err := c.Send(&m); err != nil {
|
|
|
|
b.Fatalf("Unexpected send err: %v", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
var rm transport.Message
|
|
|
|
// receive message
|
|
|
|
if err := c.Recv(&rm); err != nil {
|
|
|
|
b.Fatalf("Unexpected recv err: %v", err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// warm
|
|
|
|
for i := 0; i < 10; i++ {
|
|
|
|
send(client)
|
|
|
|
}
|
|
|
|
|
|
|
|
client.Close()
|
|
|
|
|
|
|
|
ch := make(chan int, c*4)
|
|
|
|
|
|
|
|
var wg sync.WaitGroup
|
|
|
|
wg.Add(c)
|
|
|
|
|
|
|
|
for i := 0; i < c; i++ {
|
|
|
|
go func() {
|
2021-01-29 18:57:29 +03:00
|
|
|
cl, err := tr.Dial(ctx, l.Addr())
|
2020-08-23 20:37:22 +03:00
|
|
|
if err != nil {
|
|
|
|
b.Fatalf("Unexpected dial err: %v", err)
|
|
|
|
}
|
|
|
|
defer cl.Close()
|
|
|
|
|
|
|
|
for range ch {
|
|
|
|
send(cl)
|
|
|
|
}
|
|
|
|
|
|
|
|
wg.Done()
|
|
|
|
}()
|
|
|
|
}
|
|
|
|
|
|
|
|
b.StartTimer()
|
|
|
|
|
|
|
|
for i := 0; i < b.N; i++ {
|
|
|
|
ch <- i
|
|
|
|
}
|
|
|
|
|
|
|
|
b.StopTimer()
|
|
|
|
close(ch)
|
|
|
|
|
|
|
|
wg.Wait()
|
|
|
|
|
|
|
|
// finish
|
|
|
|
close(done)
|
|
|
|
}
|
|
|
|
|
|
|
|
func BenchmarkTransport1(b *testing.B) {
|
|
|
|
call(b, 1)
|
|
|
|
}
|
|
|
|
|
|
|
|
func BenchmarkTransport8(b *testing.B) {
|
|
|
|
call(b, 8)
|
|
|
|
}
|
|
|
|
|
|
|
|
func BenchmarkTransport16(b *testing.B) {
|
|
|
|
call(b, 16)
|
|
|
|
}
|
|
|
|
|
|
|
|
func BenchmarkTransport64(b *testing.B) {
|
|
|
|
call(b, 64)
|
|
|
|
}
|
|
|
|
|
|
|
|
func BenchmarkTransport128(b *testing.B) {
|
|
|
|
call(b, 128)
|
|
|
|
}
|