|
|
@@ -111,32 +111,59 @@ func TestSocksBridageUDP(t *testing.T) {
|
|
|
common.Must(err)
|
|
|
defer udpServer.Close()
|
|
|
|
|
|
+ retry := 1
|
|
|
serverPort := tcp.PickPort()
|
|
|
- serverConfig := &core.Config{
|
|
|
- Inbound: []*core.InboundHandlerConfig{
|
|
|
- {
|
|
|
- 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_PASSWORD,
|
|
|
- Accounts: map[string]string{
|
|
|
- "Test Account": "Test Password",
|
|
|
- },
|
|
|
- Address: net.NewIPOrDomain(net.LocalHostIP),
|
|
|
- UdpEnabled: true,
|
|
|
- }),
|
|
|
+ for {
|
|
|
+ serverConfig := &core.Config{
|
|
|
+ Inbound: []*core.InboundHandlerConfig{
|
|
|
+ {
|
|
|
+ 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_PASSWORD,
|
|
|
+ Accounts: map[string]string{
|
|
|
+ "Test Account": "Test Password",
|
|
|
+ },
|
|
|
+ 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{
|
|
|
- {
|
|
|
- ProxySettings: serial.ToTypedMessage(&freedom.Config{}),
|
|
|
+ Outbound: []*core.OutboundHandlerConfig{
|
|
|
+ {
|
|
|
+ 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{
|
|
|
Inbound: []*core.InboundHandlerConfig{
|
|
|
{
|
|
|
@@ -148,7 +175,7 @@ func TestSocksBridageUDP(t *testing.T) {
|
|
|
Address: net.NewIPOrDomain(dest.Address),
|
|
|
Port: uint32(dest.Port),
|
|
|
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)
|
|
|
- defer CloseAllServers(servers)
|
|
|
+ defer CloseServer(server)
|
|
|
|
|
|
- if err := testUDPConn(clientPort, 1024, time.Second*5)(); err != nil {
|
|
|
- t.Error(err)
|
|
|
+ if !WaitConnAvailableWithTest(t, testUDPConn(clientPort, 1024, time.Second*2)) {
|
|
|
+ t.Fail()
|
|
|
}
|
|
|
}
|
|
|
|
|
|
@@ -192,46 +219,74 @@ func TestSocksBridageUDPWithRouting(t *testing.T) {
|
|
|
common.Must(err)
|
|
|
defer udpServer.Close()
|
|
|
|
|
|
+ retry := 1
|
|
|
serverPort := tcp.PickPort()
|
|
|
- serverConfig := &core.Config{
|
|
|
- App: []*serial.TypedMessage{
|
|
|
- serial.ToTypedMessage(&router.Config{
|
|
|
- Rule: []*router.RoutingRule{
|
|
|
- {
|
|
|
- TargetTag: &router.RoutingRule_Tag{
|
|
|
- Tag: "out",
|
|
|
+ for {
|
|
|
+ serverConfig := &core.Config{
|
|
|
+ App: []*serial.TypedMessage{
|
|
|
+ serial.ToTypedMessage(&router.Config{
|
|
|
+ Rule: []*router.RoutingRule{
|
|
|
+ {
|
|
|
+ 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,
|
|
|
}),
|
|
|
},
|
|
|
- },
|
|
|
- Outbound: []*core.OutboundHandlerConfig{
|
|
|
- {
|
|
|
- ProxySettings: serial.ToTypedMessage(&blackhole.Config{}),
|
|
|
+ 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},
|
|
|
+ },
|
|
|
+ }),
|
|
|
+ },
|
|
|
},
|
|
|
- {
|
|
|
- Tag: "out",
|
|
|
- ProxySettings: serial.ToTypedMessage(&freedom.Config{}),
|
|
|
+ Outbound: []*core.OutboundHandlerConfig{
|
|
|
+ {
|
|
|
+ ProxySettings: serial.ToTypedMessage(&blackhole.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{
|
|
|
Inbound: []*core.InboundHandlerConfig{
|
|
|
{
|
|
|
@@ -243,7 +298,7 @@ func TestSocksBridageUDPWithRouting(t *testing.T) {
|
|
|
Address: net.NewIPOrDomain(dest.Address),
|
|
|
Port: uint32(dest.Port),
|
|
|
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)
|
|
|
- defer CloseAllServers(servers)
|
|
|
+ defer CloseServer(server)
|
|
|
|
|
|
- if err := testUDPConn(clientPort, 1024, time.Second*5)(); err != nil {
|
|
|
- t.Error(err)
|
|
|
+ if !WaitConnAvailableWithTest(t, testUDPConn(clientPort, 1024, time.Second*2)) {
|
|
|
+ t.Fail()
|
|
|
}
|
|
|
}
|
|
|
|