dokodemo_test.go 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234
  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. NetworkList: &net.NetworkList{
  86. Network: []net.Network{net.Network_TCP},
  87. },
  88. }),
  89. },
  90. },
  91. Outbound: []*core.OutboundHandlerConfig{
  92. {
  93. ProxySettings: serial.ToTypedMessage(&outbound.Config{
  94. Receiver: []*protocol.ServerEndpoint{
  95. {
  96. Address: net.NewIPOrDomain(net.LocalHostIP),
  97. Port: uint32(serverPort),
  98. User: []*protocol.User{
  99. {
  100. Account: serial.ToTypedMessage(&vmess.Account{
  101. Id: userID.String(),
  102. }),
  103. },
  104. },
  105. },
  106. },
  107. }),
  108. },
  109. },
  110. }
  111. server, _ := InitializeServerConfig(clientConfig)
  112. if server != nil && WaitConnAvailableWithTest(t, testTCPConn(net.Port(clientPort), 1024, time.Second*2)) {
  113. defer CloseServer(server)
  114. break
  115. }
  116. retry++
  117. if retry > 5 {
  118. t.Fatal("All attempts failed to start client")
  119. }
  120. clientPort = uint32(tcp.PickPort())
  121. }
  122. for port := clientPort; port <= clientPort+clientPortRange; port++ {
  123. if err := testTCPConn(net.Port(port), 1024, time.Second*2)(); err != nil {
  124. t.Error(err)
  125. }
  126. }
  127. }
  128. func TestDokodemoUDP(t *testing.T) {
  129. udpServer := udp.Server{
  130. MsgProcessor: xor,
  131. }
  132. dest, err := udpServer.Start()
  133. common.Must(err)
  134. defer udpServer.Close()
  135. userID := protocol.NewID(uuid.New())
  136. serverPort := tcp.PickPort()
  137. serverConfig := &core.Config{
  138. Inbound: []*core.InboundHandlerConfig{
  139. {
  140. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  141. PortList: &net.PortList{Range: []*net.PortRange{net.SinglePortRange(serverPort)}},
  142. Listen: net.NewIPOrDomain(net.LocalHostIP),
  143. }),
  144. ProxySettings: serial.ToTypedMessage(&inbound.Config{
  145. User: []*protocol.User{
  146. {
  147. Account: serial.ToTypedMessage(&vmess.Account{
  148. Id: userID.String(),
  149. }),
  150. },
  151. },
  152. }),
  153. },
  154. },
  155. Outbound: []*core.OutboundHandlerConfig{
  156. {
  157. ProxySettings: serial.ToTypedMessage(&freedom.Config{}),
  158. },
  159. },
  160. }
  161. server, err := InitializeServerConfig(serverConfig)
  162. common.Must(err)
  163. defer CloseServer(server)
  164. clientPortRange := uint32(3)
  165. retry := 1
  166. clientPort := uint32(udp.PickPort())
  167. for {
  168. clientConfig := &core.Config{
  169. Inbound: []*core.InboundHandlerConfig{
  170. {
  171. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  172. PortList: &net.PortList{Range: []*net.PortRange{{From: clientPort, To: clientPort + clientPortRange}}},
  173. Listen: net.NewIPOrDomain(net.LocalHostIP),
  174. }),
  175. ProxySettings: serial.ToTypedMessage(&dokodemo.Config{
  176. Address: net.NewIPOrDomain(dest.Address),
  177. Port: uint32(dest.Port),
  178. NetworkList: &net.NetworkList{
  179. Network: []net.Network{net.Network_UDP},
  180. },
  181. }),
  182. },
  183. },
  184. Outbound: []*core.OutboundHandlerConfig{
  185. {
  186. ProxySettings: serial.ToTypedMessage(&outbound.Config{
  187. Receiver: []*protocol.ServerEndpoint{
  188. {
  189. Address: net.NewIPOrDomain(net.LocalHostIP),
  190. Port: uint32(serverPort),
  191. User: []*protocol.User{
  192. {
  193. Account: serial.ToTypedMessage(&vmess.Account{
  194. Id: userID.String(),
  195. }),
  196. },
  197. },
  198. },
  199. },
  200. }),
  201. },
  202. },
  203. }
  204. server, _ := InitializeServerConfig(clientConfig)
  205. if server != nil && WaitConnAvailableWithTest(t, testUDPConn(net.Port(clientPort), 1024, time.Second*2)) {
  206. defer CloseServer(server)
  207. break
  208. }
  209. retry++
  210. if retry > 5 {
  211. t.Fatal("All attempts failed to start client")
  212. }
  213. clientPort = uint32(udp.PickPort())
  214. }
  215. var errg errgroup.Group
  216. for port := clientPort; port <= clientPort+clientPortRange; port++ {
  217. errg.Go(testUDPConn(net.Port(port), 1024, time.Second*5))
  218. }
  219. if err := errg.Wait(); err != nil {
  220. t.Error(err)
  221. }
  222. }