2019-06-03 20:44:43 +03:00
|
|
|
package grpc
|
|
|
|
|
|
|
|
import (
|
2019-12-03 22:59:44 +03:00
|
|
|
"context"
|
2019-06-03 20:44:43 +03:00
|
|
|
"net"
|
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"google.golang.org/grpc"
|
|
|
|
pgrpc "google.golang.org/grpc"
|
|
|
|
pb "google.golang.org/grpc/examples/helloworld/helloworld"
|
|
|
|
)
|
|
|
|
|
2019-12-27 15:25:58 +03:00
|
|
|
func testPool(t *testing.T, size int, ttl time.Duration, idle int, ms int) {
|
2019-06-03 20:44:43 +03:00
|
|
|
// setup server
|
|
|
|
l, err := net.Listen("tcp", ":0")
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("failed to listen: %v", err)
|
|
|
|
}
|
|
|
|
defer l.Close()
|
|
|
|
|
|
|
|
s := pgrpc.NewServer()
|
|
|
|
pb.RegisterGreeterServer(s, &greeterServer{})
|
|
|
|
|
|
|
|
go s.Serve(l)
|
|
|
|
defer s.Stop()
|
|
|
|
|
|
|
|
// zero pool
|
2019-12-27 15:25:58 +03:00
|
|
|
p := newPool(size, ttl, idle, ms)
|
2019-06-03 20:44:43 +03:00
|
|
|
|
|
|
|
for i := 0; i < 10; i++ {
|
|
|
|
// get a conn
|
|
|
|
cc, err := p.getConn(l.Addr().String(), grpc.WithInsecure())
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
rsp := pb.HelloReply{}
|
|
|
|
|
|
|
|
err = cc.Invoke(context.TODO(), "/helloworld.Greeter/SayHello", &pb.HelloRequest{Name: "John"}, &rsp)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if rsp.Message != "Hello John" {
|
|
|
|
t.Fatalf("Got unexpected response %v", rsp.Message)
|
|
|
|
}
|
|
|
|
|
|
|
|
// release the conn
|
|
|
|
p.release(l.Addr().String(), cc, nil)
|
|
|
|
|
|
|
|
p.Lock()
|
2019-12-27 15:25:58 +03:00
|
|
|
if i := p.conns[l.Addr().String()].count; i > size {
|
2019-06-03 20:44:43 +03:00
|
|
|
p.Unlock()
|
|
|
|
t.Fatalf("pool size %d is greater than expected %d", i, size)
|
|
|
|
}
|
|
|
|
p.Unlock()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestGRPCPool(t *testing.T) {
|
2019-12-27 15:25:58 +03:00
|
|
|
testPool(t, 0, time.Minute, 10, 2)
|
|
|
|
testPool(t, 2, time.Minute, 10, 1)
|
2019-06-03 20:44:43 +03:00
|
|
|
}
|