2019-07-28 18:56:18 +01:00
|
|
|
package pool
|
2016-06-07 01:18:54 +01:00
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
|
2020-08-19 17:47:17 +03:00
|
|
|
"github.com/unistack-org/micro/v3/transport"
|
|
|
|
"github.com/unistack-org/micro/v3/transport/memory"
|
2016-06-07 01:18:54 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
func testPool(t *testing.T, size int, ttl time.Duration) {
|
|
|
|
// mock transport
|
2019-01-14 15:27:25 +00:00
|
|
|
tr := memory.NewTransport()
|
2016-06-07 01:18:54 +01:00
|
|
|
|
2019-07-28 18:56:18 +01:00
|
|
|
options := Options{
|
|
|
|
TTL: ttl,
|
|
|
|
Size: size,
|
|
|
|
Transport: tr,
|
|
|
|
}
|
|
|
|
// zero pool
|
|
|
|
p := newPool(options)
|
|
|
|
|
2016-06-07 01:18:54 +01:00
|
|
|
// listen
|
|
|
|
l, err := tr.Listen(":0")
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
defer l.Close()
|
|
|
|
|
|
|
|
// accept loop
|
|
|
|
go func() {
|
|
|
|
for {
|
|
|
|
if err := l.Accept(func(s transport.Socket) {
|
|
|
|
for {
|
|
|
|
var msg transport.Message
|
|
|
|
if err := s.Recv(&msg); err != nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
if err := s.Send(&msg); err != nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}); err != nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}()
|
|
|
|
|
|
|
|
for i := 0; i < 10; i++ {
|
|
|
|
// get a conn
|
2019-07-28 18:56:18 +01:00
|
|
|
c, err := p.Get(l.Addr())
|
2016-06-07 01:18:54 +01:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
msg := &transport.Message{
|
|
|
|
Body: []byte(`hello world`),
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := c.Send(msg); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
var rcv transport.Message
|
|
|
|
|
|
|
|
if err := c.Recv(&rcv); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if string(rcv.Body) != string(msg.Body) {
|
|
|
|
t.Fatalf("got %v, expected %v", rcv.Body, msg.Body)
|
|
|
|
}
|
|
|
|
|
|
|
|
// release the conn
|
2019-07-28 18:56:18 +01:00
|
|
|
p.Release(c, nil)
|
2016-06-07 01:18:54 +01:00
|
|
|
|
|
|
|
p.Lock()
|
|
|
|
if i := len(p.conns[l.Addr()]); i > size {
|
|
|
|
p.Unlock()
|
2017-02-25 22:53:25 +08:00
|
|
|
t.Fatalf("pool size %d is greater than expected %d", i, size)
|
2016-06-07 01:18:54 +01:00
|
|
|
}
|
|
|
|
p.Unlock()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-07-28 18:56:18 +01:00
|
|
|
func TestClientPool(t *testing.T) {
|
2016-06-07 01:18:54 +01:00
|
|
|
testPool(t, 0, time.Minute)
|
|
|
|
testPool(t, 2, time.Minute)
|
|
|
|
}
|