dokodemo_test.go 6.1 KB

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