gf/net/gtcp/gtcp_z_unit_pool_pkg_test.go
John Guo b1611fee1b
improve port listening for ghttp.Server (#2175)
* version updates

* fix issue #2172

* improve port listening for ghttp.Server

* UT cases update

* UT cases update

* add GetListenedPort/GetListenedAddress for gtcp.Server

* UT cases update for package gudp

* up
2022-10-08 21:45:21 +08:00

192 lines
5.0 KiB
Go

// Copyright GoFrame Author(https://goframe.org). All Rights Reserved.
//
// This Source Code Form is subject to the terms of the MIT License.
// If a copy of the MIT was not distributed with this file,
// You can obtain one at https://github.com/gogf/gf.
package gtcp_test
import (
"testing"
"time"
"github.com/gogf/gf/v2/net/gtcp"
"github.com/gogf/gf/v2/test/gtest"
"github.com/gogf/gf/v2/util/gconv"
)
func Test_Pool_Package_Basic(t *testing.T) {
s := gtcp.NewServer(gtcp.FreePortAddress, func(conn *gtcp.Conn) {
defer conn.Close()
for {
data, err := conn.RecvPkg()
if err != nil {
break
}
conn.SendPkg(data)
}
})
go s.Run()
defer s.Close()
time.Sleep(100 * time.Millisecond)
// SendPkg
gtest.C(t, func(t *gtest.T) {
conn, err := gtcp.NewPoolConn(s.GetListenedAddress())
t.AssertNil(err)
defer conn.Close()
for i := 0; i < 100; i++ {
err := conn.SendPkg([]byte(gconv.String(i)))
t.AssertNil(err)
}
for i := 0; i < 100; i++ {
err := conn.SendPkgWithTimeout([]byte(gconv.String(i)), time.Second)
t.AssertNil(err)
}
})
// SendPkg with big data - failure.
gtest.C(t, func(t *gtest.T) {
conn, err := gtcp.NewPoolConn(s.GetListenedAddress())
t.AssertNil(err)
defer conn.Close()
data := make([]byte, 65536)
err = conn.SendPkg(data)
t.AssertNE(err, nil)
})
// SendRecvPkg
gtest.C(t, func(t *gtest.T) {
conn, err := gtcp.NewPoolConn(s.GetListenedAddress())
t.AssertNil(err)
defer conn.Close()
for i := 100; i < 200; i++ {
data := []byte(gconv.String(i))
result, err := conn.SendRecvPkg(data)
t.AssertNil(err)
t.Assert(result, data)
}
for i := 100; i < 200; i++ {
data := []byte(gconv.String(i))
result, err := conn.SendRecvPkgWithTimeout(data, time.Second)
t.AssertNil(err)
t.Assert(result, data)
}
})
// SendRecvPkg with big data - failure.
gtest.C(t, func(t *gtest.T) {
conn, err := gtcp.NewPoolConn(s.GetListenedAddress())
t.AssertNil(err)
defer conn.Close()
data := make([]byte, 65536)
result, err := conn.SendRecvPkg(data)
t.AssertNE(err, nil)
t.Assert(result, nil)
})
// SendRecvPkg with big data - success.
gtest.C(t, func(t *gtest.T) {
conn, err := gtcp.NewPoolConn(s.GetListenedAddress())
t.AssertNil(err)
defer conn.Close()
data := make([]byte, 65500)
data[100] = byte(65)
data[65400] = byte(85)
result, err := conn.SendRecvPkg(data)
t.AssertNil(err)
t.Assert(result, data)
})
}
func Test_Pool_Package_Timeout(t *testing.T) {
s := gtcp.NewServer(gtcp.FreePortAddress, func(conn *gtcp.Conn) {
defer conn.Close()
for {
data, err := conn.RecvPkg()
if err != nil {
break
}
time.Sleep(time.Second)
gtest.Assert(conn.SendPkg(data), nil)
}
})
go s.Run()
defer s.Close()
time.Sleep(100 * time.Millisecond)
gtest.C(t, func(t *gtest.T) {
conn, err := gtcp.NewPoolConn(s.GetListenedAddress())
t.AssertNil(err)
defer conn.Close()
data := []byte("10000")
result, err := conn.SendRecvPkgWithTimeout(data, time.Millisecond*500)
t.AssertNE(err, nil)
t.Assert(result, nil)
})
gtest.C(t, func(t *gtest.T) {
conn, err := gtcp.NewPoolConn(s.GetListenedAddress())
t.AssertNil(err)
defer conn.Close()
data := []byte("10000")
result, err := conn.SendRecvPkgWithTimeout(data, time.Second*2)
t.AssertNil(err)
t.Assert(result, data)
})
}
func Test_Pool_Package_Option(t *testing.T) {
s := gtcp.NewServer(gtcp.FreePortAddress, func(conn *gtcp.Conn) {
defer conn.Close()
option := gtcp.PkgOption{HeaderSize: 1}
for {
data, err := conn.RecvPkg(option)
if err != nil {
break
}
gtest.Assert(conn.SendPkg(data, option), nil)
}
})
go s.Run()
defer s.Close()
time.Sleep(100 * time.Millisecond)
// SendRecvPkg with big data - failure.
gtest.C(t, func(t *gtest.T) {
conn, err := gtcp.NewPoolConn(s.GetListenedAddress())
t.AssertNil(err)
defer conn.Close()
data := make([]byte, 0xFF+1)
result, err := conn.SendRecvPkg(data, gtcp.PkgOption{HeaderSize: 1})
t.AssertNE(err, nil)
t.Assert(result, nil)
})
// SendRecvPkg with big data - success.
gtest.C(t, func(t *gtest.T) {
conn, err := gtcp.NewPoolConn(s.GetListenedAddress())
t.AssertNil(err)
defer conn.Close()
data := make([]byte, 0xFF)
data[100] = byte(65)
data[200] = byte(85)
result, err := conn.SendRecvPkg(data, gtcp.PkgOption{HeaderSize: 1})
t.AssertNil(err)
t.Assert(result, data)
})
// SendRecvPkgWithTimeout with big data - failure.
gtest.C(t, func(t *gtest.T) {
conn, err := gtcp.NewPoolConn(s.GetListenedAddress())
t.AssertNil(err)
defer conn.Close()
data := make([]byte, 0xFF+1)
result, err := conn.SendRecvPkgWithTimeout(data, time.Second, gtcp.PkgOption{HeaderSize: 1})
t.AssertNE(err, nil)
t.Assert(result, nil)
})
// SendRecvPkgWithTimeout with big data - success.
gtest.C(t, func(t *gtest.T) {
conn, err := gtcp.NewPoolConn(s.GetListenedAddress())
t.AssertNil(err)
defer conn.Close()
data := make([]byte, 0xFF)
data[100] = byte(65)
data[200] = byte(85)
result, err := conn.SendRecvPkgWithTimeout(data, time.Second, gtcp.PkgOption{HeaderSize: 1})
t.AssertNil(err)
t.Assert(result, data)
})
}