policy_test.go 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267
  1. package scenarios
  2. import (
  3. "io"
  4. "testing"
  5. "time"
  6. "golang.org/x/sync/errgroup"
  7. "v2ray.com/core"
  8. "v2ray.com/core/app/log"
  9. "v2ray.com/core/app/policy"
  10. "v2ray.com/core/app/proxyman"
  11. "v2ray.com/core/common"
  12. clog "v2ray.com/core/common/log"
  13. "v2ray.com/core/common/net"
  14. "v2ray.com/core/common/protocol"
  15. "v2ray.com/core/common/serial"
  16. "v2ray.com/core/common/uuid"
  17. "v2ray.com/core/proxy/dokodemo"
  18. "v2ray.com/core/proxy/freedom"
  19. "v2ray.com/core/proxy/vmess"
  20. "v2ray.com/core/proxy/vmess/inbound"
  21. "v2ray.com/core/proxy/vmess/outbound"
  22. "v2ray.com/core/testing/servers/tcp"
  23. )
  24. func startQuickClosingTCPServer() (net.Listener, error) {
  25. listener, err := net.Listen("tcp", "127.0.0.1:0")
  26. if err != nil {
  27. return nil, err
  28. }
  29. go func() {
  30. for {
  31. conn, err := listener.Accept()
  32. if err != nil {
  33. break
  34. }
  35. b := make([]byte, 1024)
  36. conn.Read(b)
  37. conn.Close()
  38. }
  39. }()
  40. return listener, nil
  41. }
  42. func TestVMessClosing(t *testing.T) {
  43. tcpServer, err := startQuickClosingTCPServer()
  44. common.Must(err)
  45. defer tcpServer.Close()
  46. dest := net.DestinationFromAddr(tcpServer.Addr())
  47. userID := protocol.NewID(uuid.New())
  48. serverPort := tcp.PickPort()
  49. serverConfig := &core.Config{
  50. App: []*serial.TypedMessage{
  51. serial.ToTypedMessage(&policy.Config{
  52. Level: map[uint32]*policy.Policy{
  53. 0: {
  54. Timeout: &policy.Policy_Timeout{
  55. UplinkOnly: &policy.Second{Value: 0},
  56. DownlinkOnly: &policy.Second{Value: 0},
  57. },
  58. },
  59. },
  60. }),
  61. },
  62. Inbound: []*core.InboundHandlerConfig{
  63. {
  64. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  65. PortRange: net.SinglePortRange(serverPort),
  66. Listen: net.NewIPOrDomain(net.LocalHostIP),
  67. }),
  68. ProxySettings: serial.ToTypedMessage(&inbound.Config{
  69. User: []*protocol.User{
  70. {
  71. Account: serial.ToTypedMessage(&vmess.Account{
  72. Id: userID.String(),
  73. AlterId: 64,
  74. }),
  75. },
  76. },
  77. }),
  78. },
  79. },
  80. Outbound: []*core.OutboundHandlerConfig{
  81. {
  82. ProxySettings: serial.ToTypedMessage(&freedom.Config{}),
  83. },
  84. },
  85. }
  86. clientPort := tcp.PickPort()
  87. clientConfig := &core.Config{
  88. App: []*serial.TypedMessage{
  89. serial.ToTypedMessage(&policy.Config{
  90. Level: map[uint32]*policy.Policy{
  91. 0: {
  92. Timeout: &policy.Policy_Timeout{
  93. UplinkOnly: &policy.Second{Value: 0},
  94. DownlinkOnly: &policy.Second{Value: 0},
  95. },
  96. },
  97. },
  98. }),
  99. },
  100. Inbound: []*core.InboundHandlerConfig{
  101. {
  102. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  103. PortRange: net.SinglePortRange(clientPort),
  104. Listen: net.NewIPOrDomain(net.LocalHostIP),
  105. }),
  106. ProxySettings: serial.ToTypedMessage(&dokodemo.Config{
  107. Address: net.NewIPOrDomain(dest.Address),
  108. Port: uint32(dest.Port),
  109. NetworkList: &net.NetworkList{
  110. Network: []net.Network{net.Network_TCP},
  111. },
  112. }),
  113. },
  114. },
  115. Outbound: []*core.OutboundHandlerConfig{
  116. {
  117. ProxySettings: serial.ToTypedMessage(&outbound.Config{
  118. Receiver: []*protocol.ServerEndpoint{
  119. {
  120. Address: net.NewIPOrDomain(net.LocalHostIP),
  121. Port: uint32(serverPort),
  122. User: []*protocol.User{
  123. {
  124. Account: serial.ToTypedMessage(&vmess.Account{
  125. Id: userID.String(),
  126. AlterId: 64,
  127. SecuritySettings: &protocol.SecurityConfig{
  128. Type: protocol.SecurityType_AES128_GCM,
  129. },
  130. }),
  131. },
  132. },
  133. },
  134. },
  135. }),
  136. },
  137. },
  138. }
  139. servers, err := InitializeServerConfigs(serverConfig, clientConfig)
  140. common.Must(err)
  141. defer CloseAllServers(servers)
  142. if err := testTCPConn(clientPort, 1024, time.Second*2)(); err != io.EOF {
  143. t.Error(err)
  144. }
  145. }
  146. func TestZeroBuffer(t *testing.T) {
  147. tcpServer := tcp.Server{
  148. MsgProcessor: xor,
  149. }
  150. dest, err := tcpServer.Start()
  151. common.Must(err)
  152. defer tcpServer.Close()
  153. userID := protocol.NewID(uuid.New())
  154. serverPort := tcp.PickPort()
  155. serverConfig := &core.Config{
  156. App: []*serial.TypedMessage{
  157. serial.ToTypedMessage(&policy.Config{
  158. Level: map[uint32]*policy.Policy{
  159. 0: {
  160. Timeout: &policy.Policy_Timeout{
  161. UplinkOnly: &policy.Second{Value: 0},
  162. DownlinkOnly: &policy.Second{Value: 0},
  163. },
  164. Buffer: &policy.Policy_Buffer{
  165. Connection: 0,
  166. },
  167. },
  168. },
  169. }),
  170. },
  171. Inbound: []*core.InboundHandlerConfig{
  172. {
  173. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  174. PortRange: net.SinglePortRange(serverPort),
  175. Listen: net.NewIPOrDomain(net.LocalHostIP),
  176. }),
  177. ProxySettings: serial.ToTypedMessage(&inbound.Config{
  178. User: []*protocol.User{
  179. {
  180. Account: serial.ToTypedMessage(&vmess.Account{
  181. Id: userID.String(),
  182. AlterId: 64,
  183. }),
  184. },
  185. },
  186. }),
  187. },
  188. },
  189. Outbound: []*core.OutboundHandlerConfig{
  190. {
  191. ProxySettings: serial.ToTypedMessage(&freedom.Config{}),
  192. },
  193. },
  194. }
  195. clientPort := tcp.PickPort()
  196. clientConfig := &core.Config{
  197. App: []*serial.TypedMessage{
  198. serial.ToTypedMessage(&log.Config{
  199. ErrorLogLevel: clog.Severity_Debug,
  200. ErrorLogType: log.LogType_Console,
  201. }),
  202. },
  203. Inbound: []*core.InboundHandlerConfig{
  204. {
  205. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  206. PortRange: net.SinglePortRange(clientPort),
  207. Listen: net.NewIPOrDomain(net.LocalHostIP),
  208. }),
  209. ProxySettings: serial.ToTypedMessage(&dokodemo.Config{
  210. Address: net.NewIPOrDomain(dest.Address),
  211. Port: uint32(dest.Port),
  212. NetworkList: &net.NetworkList{
  213. Network: []net.Network{net.Network_TCP},
  214. },
  215. }),
  216. },
  217. },
  218. Outbound: []*core.OutboundHandlerConfig{
  219. {
  220. ProxySettings: serial.ToTypedMessage(&outbound.Config{
  221. Receiver: []*protocol.ServerEndpoint{
  222. {
  223. Address: net.NewIPOrDomain(net.LocalHostIP),
  224. Port: uint32(serverPort),
  225. User: []*protocol.User{
  226. {
  227. Account: serial.ToTypedMessage(&vmess.Account{
  228. Id: userID.String(),
  229. AlterId: 64,
  230. SecuritySettings: &protocol.SecurityConfig{
  231. Type: protocol.SecurityType_AES128_GCM,
  232. },
  233. }),
  234. },
  235. },
  236. },
  237. },
  238. }),
  239. },
  240. },
  241. }
  242. servers, err := InitializeServerConfigs(serverConfig, clientConfig)
  243. common.Must(err)
  244. defer CloseAllServers(servers)
  245. var errg errgroup.Group
  246. for i := 0; i < 10; i++ {
  247. errg.Go(testTCPConn(clientPort, 10240*1024, time.Second*20))
  248. }
  249. if err := errg.Wait(); err != nil {
  250. t.Error(err)
  251. }
  252. }