micro/util/pool/default_test.go

90 lines
1.5 KiB
Go
Raw Normal View History

2019-07-28 18:56:18 +01:00
package pool
2016-06-07 01:18:54 +01:00
import (
"testing"
"time"
"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)
}