mirror of
https://github.com/XTLS/Xray-core.git
synced 2024-11-26 02:21:27 +00:00
Fix some flaky tests related to pick port (#985)
* Fix some tests to PickPort correctly * Add retry logic for two socks tests Two socks tests listen for both TCP and UDP with same port number, in some cases the port is not available Add retry logic for server core, start server core and client core separately Extract a common method * Add retry logic for two dokodemo tests Two dokodemo tests listen for 5 ports, in some cases they are not available Add retry logic for client core, start server and client separately
This commit is contained in:
parent
c1a54ae58e
commit
94c249a8c8
|
@ -58,7 +58,7 @@ func TestXrayClose(t *testing.T) {
|
||||||
Address: net.NewIPOrDomain(net.LocalHostIP),
|
Address: net.NewIPOrDomain(net.LocalHostIP),
|
||||||
Port: uint32(0),
|
Port: uint32(0),
|
||||||
NetworkList: &net.NetworkList{
|
NetworkList: &net.NetworkList{
|
||||||
Network: []net.Network{net.Network_TCP, net.Network_UDP},
|
Network: []net.Network{net.Network_TCP},
|
||||||
},
|
},
|
||||||
}),
|
}),
|
||||||
},
|
},
|
||||||
|
|
|
@ -11,6 +11,7 @@ import (
|
||||||
"runtime"
|
"runtime"
|
||||||
"sync"
|
"sync"
|
||||||
"syscall"
|
"syscall"
|
||||||
|
"testing"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/golang/protobuf/proto"
|
"github.com/golang/protobuf/proto"
|
||||||
|
@ -235,3 +236,20 @@ func testTCPConn2(conn net.Conn, payloadSize int, timeout time.Duration) func()
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func WaitConnAvailableWithTest(t *testing.T, testFunc func() error) bool {
|
||||||
|
for i := 1; ; i++ {
|
||||||
|
if i > 10 {
|
||||||
|
t.Log("All attempts failed to test tcp conn")
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
time.Sleep(time.Millisecond * 10)
|
||||||
|
if err := testFunc(); err != nil {
|
||||||
|
t.Log("err ", err)
|
||||||
|
} else {
|
||||||
|
t.Log("success with", i, "attempts")
|
||||||
|
break
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
|
|
@ -64,55 +64,68 @@ func TestDokodemoTCP(t *testing.T) {
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
server, err := InitializeServerConfig(serverConfig)
|
||||||
|
common.Must(err)
|
||||||
|
defer CloseServer(server)
|
||||||
|
|
||||||
clientPort := uint32(tcp.PickPort())
|
|
||||||
clientPortRange := uint32(5)
|
clientPortRange := uint32(5)
|
||||||
clientConfig := &core.Config{
|
retry := 1
|
||||||
App: []*serial.TypedMessage{
|
clientPort := uint32(tcp.PickPort())
|
||||||
serial.ToTypedMessage(&log.Config{
|
for {
|
||||||
ErrorLogLevel: clog.Severity_Debug,
|
clientConfig := &core.Config{
|
||||||
ErrorLogType: log.LogType_Console,
|
App: []*serial.TypedMessage{
|
||||||
}),
|
serial.ToTypedMessage(&log.Config{
|
||||||
},
|
ErrorLogLevel: clog.Severity_Debug,
|
||||||
Inbound: []*core.InboundHandlerConfig{
|
ErrorLogType: log.LogType_Console,
|
||||||
{
|
|
||||||
ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
|
|
||||||
PortList: &net.PortList{Range: []*net.PortRange{{From: clientPort, To: clientPort + clientPortRange}}},
|
|
||||||
Listen: net.NewIPOrDomain(net.LocalHostIP),
|
|
||||||
}),
|
|
||||||
ProxySettings: serial.ToTypedMessage(&dokodemo.Config{
|
|
||||||
Address: net.NewIPOrDomain(dest.Address),
|
|
||||||
Port: uint32(dest.Port),
|
|
||||||
NetworkList: &net.NetworkList{
|
|
||||||
Network: []net.Network{net.Network_TCP},
|
|
||||||
},
|
|
||||||
}),
|
}),
|
||||||
},
|
},
|
||||||
},
|
Inbound: []*core.InboundHandlerConfig{
|
||||||
Outbound: []*core.OutboundHandlerConfig{
|
{
|
||||||
{
|
ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
|
||||||
ProxySettings: serial.ToTypedMessage(&outbound.Config{
|
PortList: &net.PortList{Range: []*net.PortRange{{From: clientPort, To: clientPort + clientPortRange}}},
|
||||||
Receiver: []*protocol.ServerEndpoint{
|
Listen: net.NewIPOrDomain(net.LocalHostIP),
|
||||||
{
|
}),
|
||||||
Address: net.NewIPOrDomain(net.LocalHostIP),
|
ProxySettings: serial.ToTypedMessage(&dokodemo.Config{
|
||||||
Port: uint32(serverPort),
|
Address: net.NewIPOrDomain(dest.Address),
|
||||||
User: []*protocol.User{
|
Port: uint32(dest.Port),
|
||||||
{
|
NetworkList: &net.NetworkList{
|
||||||
Account: serial.ToTypedMessage(&vmess.Account{
|
Network: []net.Network{net.Network_TCP},
|
||||||
Id: userID.String(),
|
},
|
||||||
}),
|
}),
|
||||||
|
},
|
||||||
|
},
|
||||||
|
Outbound: []*core.OutboundHandlerConfig{
|
||||||
|
{
|
||||||
|
ProxySettings: serial.ToTypedMessage(&outbound.Config{
|
||||||
|
Receiver: []*protocol.ServerEndpoint{
|
||||||
|
{
|
||||||
|
Address: net.NewIPOrDomain(net.LocalHostIP),
|
||||||
|
Port: uint32(serverPort),
|
||||||
|
User: []*protocol.User{
|
||||||
|
{
|
||||||
|
Account: serial.ToTypedMessage(&vmess.Account{
|
||||||
|
Id: userID.String(),
|
||||||
|
}),
|
||||||
|
},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
},
|
}),
|
||||||
}),
|
},
|
||||||
},
|
},
|
||||||
},
|
}
|
||||||
}
|
|
||||||
|
|
||||||
servers, err := InitializeServerConfigs(serverConfig, clientConfig)
|
server, _ := InitializeServerConfig(clientConfig)
|
||||||
common.Must(err)
|
if server != nil && WaitConnAvailableWithTest(t, testTCPConn(net.Port(clientPort), 1024, time.Second*2)) {
|
||||||
defer CloseAllServers(servers)
|
defer CloseServer(server)
|
||||||
|
break
|
||||||
|
}
|
||||||
|
retry++
|
||||||
|
if retry > 5 {
|
||||||
|
t.Fatal("All attempts failed to start client")
|
||||||
|
}
|
||||||
|
clientPort = uint32(tcp.PickPort())
|
||||||
|
}
|
||||||
|
|
||||||
for port := clientPort; port <= clientPort+clientPortRange; port++ {
|
for port := clientPort; port <= clientPort+clientPortRange; port++ {
|
||||||
if err := testTCPConn(net.Port(port), 1024, time.Second*2)(); err != nil {
|
if err := testTCPConn(net.Port(port), 1024, time.Second*2)(); err != nil {
|
||||||
|
@ -155,49 +168,62 @@ func TestDokodemoUDP(t *testing.T) {
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
server, err := InitializeServerConfig(serverConfig)
|
||||||
|
common.Must(err)
|
||||||
|
defer CloseServer(server)
|
||||||
|
|
||||||
clientPort := uint32(udp.PickPort())
|
|
||||||
clientPortRange := uint32(5)
|
clientPortRange := uint32(5)
|
||||||
clientConfig := &core.Config{
|
retry := 1
|
||||||
Inbound: []*core.InboundHandlerConfig{
|
clientPort := uint32(udp.PickPort())
|
||||||
{
|
for {
|
||||||
ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
|
clientConfig := &core.Config{
|
||||||
PortList: &net.PortList{Range: []*net.PortRange{{From: clientPort, To: clientPort + clientPortRange}}},
|
Inbound: []*core.InboundHandlerConfig{
|
||||||
Listen: net.NewIPOrDomain(net.LocalHostIP),
|
{
|
||||||
}),
|
ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
|
||||||
ProxySettings: serial.ToTypedMessage(&dokodemo.Config{
|
PortList: &net.PortList{Range: []*net.PortRange{{From: clientPort, To: clientPort + clientPortRange}}},
|
||||||
Address: net.NewIPOrDomain(dest.Address),
|
Listen: net.NewIPOrDomain(net.LocalHostIP),
|
||||||
Port: uint32(dest.Port),
|
}),
|
||||||
NetworkList: &net.NetworkList{
|
ProxySettings: serial.ToTypedMessage(&dokodemo.Config{
|
||||||
Network: []net.Network{net.Network_UDP},
|
Address: net.NewIPOrDomain(dest.Address),
|
||||||
},
|
Port: uint32(dest.Port),
|
||||||
}),
|
NetworkList: &net.NetworkList{
|
||||||
|
Network: []net.Network{net.Network_UDP},
|
||||||
|
},
|
||||||
|
}),
|
||||||
|
},
|
||||||
},
|
},
|
||||||
},
|
Outbound: []*core.OutboundHandlerConfig{
|
||||||
Outbound: []*core.OutboundHandlerConfig{
|
{
|
||||||
{
|
ProxySettings: serial.ToTypedMessage(&outbound.Config{
|
||||||
ProxySettings: serial.ToTypedMessage(&outbound.Config{
|
Receiver: []*protocol.ServerEndpoint{
|
||||||
Receiver: []*protocol.ServerEndpoint{
|
{
|
||||||
{
|
Address: net.NewIPOrDomain(net.LocalHostIP),
|
||||||
Address: net.NewIPOrDomain(net.LocalHostIP),
|
Port: uint32(serverPort),
|
||||||
Port: uint32(serverPort),
|
User: []*protocol.User{
|
||||||
User: []*protocol.User{
|
{
|
||||||
{
|
Account: serial.ToTypedMessage(&vmess.Account{
|
||||||
Account: serial.ToTypedMessage(&vmess.Account{
|
Id: userID.String(),
|
||||||
Id: userID.String(),
|
}),
|
||||||
}),
|
},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
},
|
}),
|
||||||
}),
|
},
|
||||||
},
|
},
|
||||||
},
|
}
|
||||||
}
|
|
||||||
|
|
||||||
servers, err := InitializeServerConfigs(serverConfig, clientConfig)
|
server, _ := InitializeServerConfig(clientConfig)
|
||||||
common.Must(err)
|
if server != nil && WaitConnAvailableWithTest(t, testUDPConn(net.Port(clientPort), 1024, time.Second*2)) {
|
||||||
defer CloseAllServers(servers)
|
defer CloseServer(server)
|
||||||
|
break
|
||||||
|
}
|
||||||
|
retry++
|
||||||
|
if retry > 5 {
|
||||||
|
t.Fatal("All attempts failed to start client")
|
||||||
|
}
|
||||||
|
clientPort = uint32(udp.PickPort())
|
||||||
|
}
|
||||||
|
|
||||||
var errg errgroup.Group
|
var errg errgroup.Group
|
||||||
for port := clientPort; port <= clientPort+clientPortRange; port++ {
|
for port := clientPort; port <= clientPort+clientPortRange; port++ {
|
||||||
|
|
|
@ -234,7 +234,7 @@ func TestProxyOverKCP(t *testing.T) {
|
||||||
defer tcpServer.Close()
|
defer tcpServer.Close()
|
||||||
|
|
||||||
serverUserID := protocol.NewID(uuid.New())
|
serverUserID := protocol.NewID(uuid.New())
|
||||||
serverPort := tcp.PickPort()
|
serverPort := udp.PickPort()
|
||||||
serverConfig := &core.Config{
|
serverConfig := &core.Config{
|
||||||
Inbound: []*core.InboundHandlerConfig{
|
Inbound: []*core.InboundHandlerConfig{
|
||||||
{
|
{
|
||||||
|
|
|
@ -111,32 +111,59 @@ func TestSocksBridageUDP(t *testing.T) {
|
||||||
common.Must(err)
|
common.Must(err)
|
||||||
defer udpServer.Close()
|
defer udpServer.Close()
|
||||||
|
|
||||||
|
retry := 1
|
||||||
serverPort := tcp.PickPort()
|
serverPort := tcp.PickPort()
|
||||||
serverConfig := &core.Config{
|
for {
|
||||||
Inbound: []*core.InboundHandlerConfig{
|
serverConfig := &core.Config{
|
||||||
{
|
Inbound: []*core.InboundHandlerConfig{
|
||||||
ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
|
{
|
||||||
PortList: &net.PortList{Range: []*net.PortRange{net.SinglePortRange(serverPort)}},
|
ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
|
||||||
Listen: net.NewIPOrDomain(net.LocalHostIP),
|
PortList: &net.PortList{Range: []*net.PortRange{net.SinglePortRange(serverPort)}},
|
||||||
}),
|
Listen: net.NewIPOrDomain(net.LocalHostIP),
|
||||||
ProxySettings: serial.ToTypedMessage(&socks.ServerConfig{
|
}),
|
||||||
AuthType: socks.AuthType_PASSWORD,
|
ProxySettings: serial.ToTypedMessage(&socks.ServerConfig{
|
||||||
Accounts: map[string]string{
|
AuthType: socks.AuthType_PASSWORD,
|
||||||
"Test Account": "Test Password",
|
Accounts: map[string]string{
|
||||||
},
|
"Test Account": "Test Password",
|
||||||
Address: net.NewIPOrDomain(net.LocalHostIP),
|
},
|
||||||
UdpEnabled: true,
|
Address: net.NewIPOrDomain(net.LocalHostIP),
|
||||||
}),
|
UdpEnabled: true,
|
||||||
|
}),
|
||||||
|
},
|
||||||
|
{
|
||||||
|
ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
|
||||||
|
PortList: &net.PortList{Range: []*net.PortRange{net.SinglePortRange(serverPort + 1)}},
|
||||||
|
Listen: net.NewIPOrDomain(net.LocalHostIP),
|
||||||
|
}),
|
||||||
|
ProxySettings: serial.ToTypedMessage(&dokodemo.Config{
|
||||||
|
Address: net.NewIPOrDomain(dest.Address),
|
||||||
|
Port: uint32(dest.Port),
|
||||||
|
NetworkList: &net.NetworkList{
|
||||||
|
Network: []net.Network{net.Network_UDP},
|
||||||
|
},
|
||||||
|
}),
|
||||||
|
},
|
||||||
},
|
},
|
||||||
},
|
Outbound: []*core.OutboundHandlerConfig{
|
||||||
Outbound: []*core.OutboundHandlerConfig{
|
{
|
||||||
{
|
ProxySettings: serial.ToTypedMessage(&freedom.Config{}),
|
||||||
ProxySettings: serial.ToTypedMessage(&freedom.Config{}),
|
},
|
||||||
},
|
},
|
||||||
},
|
}
|
||||||
|
|
||||||
|
server, _ := InitializeServerConfig(serverConfig)
|
||||||
|
if server != nil && WaitConnAvailableWithTest(t, testUDPConn(serverPort+1, 1024, time.Second*2)) {
|
||||||
|
defer CloseServer(server)
|
||||||
|
break
|
||||||
|
}
|
||||||
|
retry++
|
||||||
|
if retry > 5 {
|
||||||
|
t.Fatal("All attempts failed to start server")
|
||||||
|
}
|
||||||
|
serverPort = tcp.PickPort()
|
||||||
}
|
}
|
||||||
|
|
||||||
clientPort := tcp.PickPort()
|
clientPort := udp.PickPort()
|
||||||
clientConfig := &core.Config{
|
clientConfig := &core.Config{
|
||||||
Inbound: []*core.InboundHandlerConfig{
|
Inbound: []*core.InboundHandlerConfig{
|
||||||
{
|
{
|
||||||
|
@ -148,7 +175,7 @@ func TestSocksBridageUDP(t *testing.T) {
|
||||||
Address: net.NewIPOrDomain(dest.Address),
|
Address: net.NewIPOrDomain(dest.Address),
|
||||||
Port: uint32(dest.Port),
|
Port: uint32(dest.Port),
|
||||||
NetworkList: &net.NetworkList{
|
NetworkList: &net.NetworkList{
|
||||||
Network: []net.Network{net.Network_TCP, net.Network_UDP},
|
Network: []net.Network{net.Network_UDP},
|
||||||
},
|
},
|
||||||
}),
|
}),
|
||||||
},
|
},
|
||||||
|
@ -175,12 +202,12 @@ func TestSocksBridageUDP(t *testing.T) {
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
servers, err := InitializeServerConfigs(serverConfig, clientConfig)
|
server, err := InitializeServerConfig(clientConfig)
|
||||||
common.Must(err)
|
common.Must(err)
|
||||||
defer CloseAllServers(servers)
|
defer CloseServer(server)
|
||||||
|
|
||||||
if err := testUDPConn(clientPort, 1024, time.Second*5)(); err != nil {
|
if !WaitConnAvailableWithTest(t, testUDPConn(clientPort, 1024, time.Second*2)) {
|
||||||
t.Error(err)
|
t.Fail()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -192,46 +219,74 @@ func TestSocksBridageUDPWithRouting(t *testing.T) {
|
||||||
common.Must(err)
|
common.Must(err)
|
||||||
defer udpServer.Close()
|
defer udpServer.Close()
|
||||||
|
|
||||||
|
retry := 1
|
||||||
serverPort := tcp.PickPort()
|
serverPort := tcp.PickPort()
|
||||||
serverConfig := &core.Config{
|
for {
|
||||||
App: []*serial.TypedMessage{
|
serverConfig := &core.Config{
|
||||||
serial.ToTypedMessage(&router.Config{
|
App: []*serial.TypedMessage{
|
||||||
Rule: []*router.RoutingRule{
|
serial.ToTypedMessage(&router.Config{
|
||||||
{
|
Rule: []*router.RoutingRule{
|
||||||
TargetTag: &router.RoutingRule_Tag{
|
{
|
||||||
Tag: "out",
|
TargetTag: &router.RoutingRule_Tag{
|
||||||
|
Tag: "out",
|
||||||
|
},
|
||||||
|
InboundTag: []string{"socks", "dokodemo"},
|
||||||
},
|
},
|
||||||
InboundTag: []string{"socks"},
|
|
||||||
},
|
},
|
||||||
|
}),
|
||||||
|
},
|
||||||
|
Inbound: []*core.InboundHandlerConfig{
|
||||||
|
{
|
||||||
|
Tag: "socks",
|
||||||
|
ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
|
||||||
|
PortList: &net.PortList{Range: []*net.PortRange{net.SinglePortRange(serverPort)}},
|
||||||
|
Listen: net.NewIPOrDomain(net.LocalHostIP),
|
||||||
|
}),
|
||||||
|
ProxySettings: serial.ToTypedMessage(&socks.ServerConfig{
|
||||||
|
AuthType: socks.AuthType_NO_AUTH,
|
||||||
|
Address: net.NewIPOrDomain(net.LocalHostIP),
|
||||||
|
UdpEnabled: true,
|
||||||
|
}),
|
||||||
|
},
|
||||||
|
{
|
||||||
|
Tag: "dokodemo",
|
||||||
|
ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
|
||||||
|
PortList: &net.PortList{Range: []*net.PortRange{net.SinglePortRange(serverPort + 1)}},
|
||||||
|
Listen: net.NewIPOrDomain(net.LocalHostIP),
|
||||||
|
}),
|
||||||
|
ProxySettings: serial.ToTypedMessage(&dokodemo.Config{
|
||||||
|
Address: net.NewIPOrDomain(dest.Address),
|
||||||
|
Port: uint32(dest.Port),
|
||||||
|
NetworkList: &net.NetworkList{
|
||||||
|
Network: []net.Network{net.Network_UDP},
|
||||||
|
},
|
||||||
|
}),
|
||||||
},
|
},
|
||||||
}),
|
|
||||||
},
|
|
||||||
Inbound: []*core.InboundHandlerConfig{
|
|
||||||
{
|
|
||||||
Tag: "socks",
|
|
||||||
ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
|
|
||||||
PortList: &net.PortList{Range: []*net.PortRange{net.SinglePortRange(serverPort)}},
|
|
||||||
Listen: net.NewIPOrDomain(net.LocalHostIP),
|
|
||||||
}),
|
|
||||||
ProxySettings: serial.ToTypedMessage(&socks.ServerConfig{
|
|
||||||
AuthType: socks.AuthType_NO_AUTH,
|
|
||||||
Address: net.NewIPOrDomain(net.LocalHostIP),
|
|
||||||
UdpEnabled: true,
|
|
||||||
}),
|
|
||||||
},
|
},
|
||||||
},
|
Outbound: []*core.OutboundHandlerConfig{
|
||||||
Outbound: []*core.OutboundHandlerConfig{
|
{
|
||||||
{
|
ProxySettings: serial.ToTypedMessage(&blackhole.Config{}),
|
||||||
ProxySettings: serial.ToTypedMessage(&blackhole.Config{}),
|
},
|
||||||
|
{
|
||||||
|
Tag: "out",
|
||||||
|
ProxySettings: serial.ToTypedMessage(&freedom.Config{}),
|
||||||
|
},
|
||||||
},
|
},
|
||||||
{
|
}
|
||||||
Tag: "out",
|
|
||||||
ProxySettings: serial.ToTypedMessage(&freedom.Config{}),
|
server, _ := InitializeServerConfig(serverConfig)
|
||||||
},
|
if server != nil && WaitConnAvailableWithTest(t, testUDPConn(serverPort+1, 1024, time.Second*2)) {
|
||||||
},
|
defer CloseServer(server)
|
||||||
|
break
|
||||||
|
}
|
||||||
|
retry++
|
||||||
|
if retry > 5 {
|
||||||
|
t.Fatal("All attempts failed to start server")
|
||||||
|
}
|
||||||
|
serverPort = tcp.PickPort()
|
||||||
}
|
}
|
||||||
|
|
||||||
clientPort := tcp.PickPort()
|
clientPort := udp.PickPort()
|
||||||
clientConfig := &core.Config{
|
clientConfig := &core.Config{
|
||||||
Inbound: []*core.InboundHandlerConfig{
|
Inbound: []*core.InboundHandlerConfig{
|
||||||
{
|
{
|
||||||
|
@ -243,7 +298,7 @@ func TestSocksBridageUDPWithRouting(t *testing.T) {
|
||||||
Address: net.NewIPOrDomain(dest.Address),
|
Address: net.NewIPOrDomain(dest.Address),
|
||||||
Port: uint32(dest.Port),
|
Port: uint32(dest.Port),
|
||||||
NetworkList: &net.NetworkList{
|
NetworkList: &net.NetworkList{
|
||||||
Network: []net.Network{net.Network_TCP, net.Network_UDP},
|
Network: []net.Network{net.Network_UDP},
|
||||||
},
|
},
|
||||||
}),
|
}),
|
||||||
},
|
},
|
||||||
|
@ -262,12 +317,12 @@ func TestSocksBridageUDPWithRouting(t *testing.T) {
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
servers, err := InitializeServerConfigs(serverConfig, clientConfig)
|
server, err := InitializeServerConfig(clientConfig)
|
||||||
common.Must(err)
|
common.Must(err)
|
||||||
defer CloseAllServers(servers)
|
defer CloseServer(server)
|
||||||
|
|
||||||
if err := testUDPConn(clientPort, 1024, time.Second*5)(); err != nil {
|
if !WaitConnAvailableWithTest(t, testUDPConn(clientPort, 1024, time.Second*2)) {
|
||||||
t.Error(err)
|
t.Fail()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -108,7 +108,7 @@ func TestVMessDynamicPort(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
server, _ := InitializeServerConfig(serverConfig)
|
server, _ := InitializeServerConfig(serverConfig)
|
||||||
if server != nil && tcpConnAvailableAtPort(t, serverPort+100) {
|
if server != nil && WaitConnAvailableWithTest(t, testTCPConn(serverPort+100, 1024, time.Second*2)) {
|
||||||
defer CloseServer(server)
|
defer CloseServer(server)
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
|
@ -167,28 +167,11 @@ func TestVMessDynamicPort(t *testing.T) {
|
||||||
common.Must(err)
|
common.Must(err)
|
||||||
defer CloseServer(server)
|
defer CloseServer(server)
|
||||||
|
|
||||||
if !tcpConnAvailableAtPort(t, clientPort) {
|
if !WaitConnAvailableWithTest(t, testTCPConn(clientPort, 1024, time.Second*2)) {
|
||||||
t.Fail()
|
t.Fail()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func tcpConnAvailableAtPort(t *testing.T, port net.Port) bool {
|
|
||||||
for i := 1; ; i++ {
|
|
||||||
if i > 10 {
|
|
||||||
t.Log("All attempts failed to test tcp conn")
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
time.Sleep(time.Millisecond * 10)
|
|
||||||
if err := testTCPConn(port, 1024, time.Second*2)(); err != nil {
|
|
||||||
t.Log("err ", err)
|
|
||||||
} else {
|
|
||||||
t.Log("success with", i, "attempts")
|
|
||||||
break
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return true
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestVMessGCM(t *testing.T) {
|
func TestVMessGCM(t *testing.T) {
|
||||||
tcpServer := tcp.Server{
|
tcpServer := tcp.Server{
|
||||||
MsgProcessor: xor,
|
MsgProcessor: xor,
|
||||||
|
|
Loading…
Reference in a new issue