dokodemo_test.go 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222
  1. package scenarios
  2. import (
  3. "testing"
  4. "time"
  5. "github.com/xtls/xray-core/app/log"
  6. "github.com/xtls/xray-core/app/proxyman"
  7. "github.com/xtls/xray-core/common"
  8. clog "github.com/xtls/xray-core/common/log"
  9. "github.com/xtls/xray-core/common/net"
  10. "github.com/xtls/xray-core/common/protocol"
  11. "github.com/xtls/xray-core/common/serial"
  12. "github.com/xtls/xray-core/common/uuid"
  13. "github.com/xtls/xray-core/core"
  14. "github.com/xtls/xray-core/proxy/dokodemo"
  15. "github.com/xtls/xray-core/proxy/freedom"
  16. "github.com/xtls/xray-core/proxy/vmess"
  17. "github.com/xtls/xray-core/proxy/vmess/inbound"
  18. "github.com/xtls/xray-core/proxy/vmess/outbound"
  19. "github.com/xtls/xray-core/testing/servers/tcp"
  20. "github.com/xtls/xray-core/testing/servers/udp"
  21. "golang.org/x/sync/errgroup"
  22. )
  23. func TestDokodemoTCP(t *testing.T) {
  24. tcpServer := tcp.Server{
  25. MsgProcessor: xor,
  26. }
  27. dest, err := tcpServer.Start()
  28. common.Must(err)
  29. defer tcpServer.Close()
  30. userID := protocol.NewID(uuid.New())
  31. serverPort := tcp.PickPort()
  32. serverConfig := &core.Config{
  33. App: []*serial.TypedMessage{
  34. serial.ToTypedMessage(&log.Config{
  35. ErrorLogLevel: clog.Severity_Debug,
  36. ErrorLogType: log.LogType_Console,
  37. }),
  38. },
  39. Inbound: []*core.InboundHandlerConfig{
  40. {
  41. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  42. PortList: &net.PortList{Range: []*net.PortRange{net.SinglePortRange(serverPort)}},
  43. Listen: net.NewIPOrDomain(net.LocalHostIP),
  44. }),
  45. ProxySettings: serial.ToTypedMessage(&inbound.Config{
  46. User: []*protocol.User{
  47. {
  48. Account: serial.ToTypedMessage(&vmess.Account{
  49. Id: userID.String(),
  50. }),
  51. },
  52. },
  53. }),
  54. },
  55. },
  56. Outbound: []*core.OutboundHandlerConfig{
  57. {
  58. ProxySettings: serial.ToTypedMessage(&freedom.Config{}),
  59. },
  60. },
  61. }
  62. server, err := InitializeServerConfig(serverConfig)
  63. common.Must(err)
  64. defer CloseServer(server)
  65. clientPortRange := uint32(5)
  66. retry := 1
  67. clientPort := uint32(tcp.PickPort())
  68. for {
  69. clientConfig := &core.Config{
  70. App: []*serial.TypedMessage{
  71. serial.ToTypedMessage(&log.Config{
  72. ErrorLogLevel: clog.Severity_Debug,
  73. ErrorLogType: log.LogType_Console,
  74. }),
  75. },
  76. Inbound: []*core.InboundHandlerConfig{
  77. {
  78. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  79. PortList: &net.PortList{Range: []*net.PortRange{{From: clientPort, To: clientPort + clientPortRange}}},
  80. Listen: net.NewIPOrDomain(net.LocalHostIP),
  81. }),
  82. ProxySettings: serial.ToTypedMessage(&dokodemo.Config{
  83. Address: net.NewIPOrDomain(dest.Address),
  84. Port: uint32(dest.Port),
  85. Networks: []net.Network{net.Network_TCP},
  86. }),
  87. },
  88. },
  89. Outbound: []*core.OutboundHandlerConfig{
  90. {
  91. ProxySettings: serial.ToTypedMessage(&outbound.Config{
  92. Receiver: &protocol.ServerEndpoint{
  93. Address: net.NewIPOrDomain(net.LocalHostIP),
  94. Port: uint32(serverPort),
  95. User: &protocol.User{
  96. Account: serial.ToTypedMessage(&vmess.Account{
  97. Id: userID.String(),
  98. }),
  99. },
  100. },
  101. }),
  102. },
  103. },
  104. }
  105. server, _ := InitializeServerConfig(clientConfig)
  106. if server != nil && WaitConnAvailableWithTest(t, testTCPConn(net.Port(clientPort), 1024, time.Second*2)) {
  107. defer CloseServer(server)
  108. break
  109. }
  110. retry++
  111. if retry > 5 {
  112. t.Fatal("All attempts failed to start client")
  113. }
  114. clientPort = uint32(tcp.PickPort())
  115. }
  116. for port := clientPort; port <= clientPort+clientPortRange; port++ {
  117. if err := testTCPConn(net.Port(port), 1024, time.Second*2)(); err != nil {
  118. t.Error(err)
  119. }
  120. }
  121. }
  122. func TestDokodemoUDP(t *testing.T) {
  123. udpServer := udp.Server{
  124. MsgProcessor: xor,
  125. }
  126. dest, err := udpServer.Start()
  127. common.Must(err)
  128. defer udpServer.Close()
  129. userID := protocol.NewID(uuid.New())
  130. serverPort := tcp.PickPort()
  131. serverConfig := &core.Config{
  132. Inbound: []*core.InboundHandlerConfig{
  133. {
  134. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  135. PortList: &net.PortList{Range: []*net.PortRange{net.SinglePortRange(serverPort)}},
  136. Listen: net.NewIPOrDomain(net.LocalHostIP),
  137. }),
  138. ProxySettings: serial.ToTypedMessage(&inbound.Config{
  139. User: []*protocol.User{
  140. {
  141. Account: serial.ToTypedMessage(&vmess.Account{
  142. Id: userID.String(),
  143. }),
  144. },
  145. },
  146. }),
  147. },
  148. },
  149. Outbound: []*core.OutboundHandlerConfig{
  150. {
  151. ProxySettings: serial.ToTypedMessage(&freedom.Config{}),
  152. },
  153. },
  154. }
  155. server, err := InitializeServerConfig(serverConfig)
  156. common.Must(err)
  157. defer CloseServer(server)
  158. clientPortRange := uint32(3)
  159. retry := 1
  160. clientPort := uint32(udp.PickPort())
  161. for {
  162. clientConfig := &core.Config{
  163. Inbound: []*core.InboundHandlerConfig{
  164. {
  165. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  166. PortList: &net.PortList{Range: []*net.PortRange{{From: clientPort, To: clientPort + clientPortRange}}},
  167. Listen: net.NewIPOrDomain(net.LocalHostIP),
  168. }),
  169. ProxySettings: serial.ToTypedMessage(&dokodemo.Config{
  170. Address: net.NewIPOrDomain(dest.Address),
  171. Port: uint32(dest.Port),
  172. Networks: []net.Network{net.Network_UDP},
  173. }),
  174. },
  175. },
  176. Outbound: []*core.OutboundHandlerConfig{
  177. {
  178. ProxySettings: serial.ToTypedMessage(&outbound.Config{
  179. Receiver: &protocol.ServerEndpoint{
  180. Address: net.NewIPOrDomain(net.LocalHostIP),
  181. Port: uint32(serverPort),
  182. User: &protocol.User{
  183. Account: serial.ToTypedMessage(&vmess.Account{
  184. Id: userID.String(),
  185. }),
  186. },
  187. },
  188. }),
  189. },
  190. },
  191. }
  192. server, _ := InitializeServerConfig(clientConfig)
  193. if server != nil && WaitConnAvailableWithTest(t, testUDPConn(net.Port(clientPort), 1024, time.Second*2)) {
  194. defer CloseServer(server)
  195. break
  196. }
  197. retry++
  198. if retry > 5 {
  199. t.Fatal("All attempts failed to start client")
  200. }
  201. clientPort = uint32(udp.PickPort())
  202. }
  203. var errg errgroup.Group
  204. for port := clientPort; port <= clientPort+clientPortRange; port++ {
  205. errg.Go(testUDPConn(net.Port(port), 1024, time.Second*5))
  206. }
  207. if err := errg.Wait(); err != nil {
  208. t.Error(err)
  209. }
  210. }