hy2_test.go 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468
  1. package scenarios
  2. import (
  3. "testing"
  4. "time"
  5. "golang.org/x/sync/errgroup"
  6. "google.golang.org/protobuf/types/known/anypb"
  7. core "github.com/v2fly/v2ray-core/v5"
  8. "github.com/v2fly/v2ray-core/v5/app/log"
  9. "github.com/v2fly/v2ray-core/v5/app/proxyman"
  10. "github.com/v2fly/v2ray-core/v5/common"
  11. clog "github.com/v2fly/v2ray-core/v5/common/log"
  12. "github.com/v2fly/v2ray-core/v5/common/net"
  13. "github.com/v2fly/v2ray-core/v5/common/protocol"
  14. "github.com/v2fly/v2ray-core/v5/common/protocol/tls/cert"
  15. "github.com/v2fly/v2ray-core/v5/common/serial"
  16. "github.com/v2fly/v2ray-core/v5/common/uuid"
  17. "github.com/v2fly/v2ray-core/v5/proxy/dokodemo"
  18. "github.com/v2fly/v2ray-core/v5/proxy/freedom"
  19. "github.com/v2fly/v2ray-core/v5/proxy/hysteria2"
  20. "github.com/v2fly/v2ray-core/v5/proxy/vmess"
  21. "github.com/v2fly/v2ray-core/v5/proxy/vmess/inbound"
  22. "github.com/v2fly/v2ray-core/v5/proxy/vmess/outbound"
  23. "github.com/v2fly/v2ray-core/v5/testing/servers/tcp"
  24. "github.com/v2fly/v2ray-core/v5/testing/servers/udp"
  25. "github.com/v2fly/v2ray-core/v5/transport/internet"
  26. "github.com/v2fly/v2ray-core/v5/transport/internet/headers/http"
  27. hyTransport "github.com/v2fly/v2ray-core/v5/transport/internet/hysteria2"
  28. tcpTransport "github.com/v2fly/v2ray-core/v5/transport/internet/tcp"
  29. "github.com/v2fly/v2ray-core/v5/transport/internet/tls"
  30. )
  31. func TestVMessHysteria2Congestion(t *testing.T) {
  32. for _, v := range []string{"bbr", "brutal"} {
  33. testVMessHysteria2(t, v)
  34. }
  35. }
  36. func testVMessHysteria2(t *testing.T, congestionType string) {
  37. tcpServer := tcp.Server{
  38. MsgProcessor: xor,
  39. }
  40. dest, err := tcpServer.Start()
  41. common.Must(err)
  42. defer tcpServer.Close()
  43. userID := protocol.NewID(uuid.New())
  44. serverPort := udp.PickPort()
  45. serverConfig := &core.Config{
  46. App: []*anypb.Any{
  47. serial.ToTypedMessage(&log.Config{
  48. Error: &log.LogSpecification{Level: clog.Severity_Debug, Type: log.LogType_Console},
  49. }),
  50. },
  51. Inbound: []*core.InboundHandlerConfig{
  52. {
  53. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  54. PortRange: net.SinglePortRange(serverPort),
  55. Listen: net.NewIPOrDomain(net.LocalHostIP),
  56. StreamSettings: &internet.StreamConfig{
  57. ProtocolName: "hysteria2",
  58. SecurityType: serial.GetMessageType(&tls.Config{}),
  59. SecuritySettings: []*anypb.Any{
  60. serial.ToTypedMessage(
  61. &tls.Config{
  62. Certificate: []*tls.Certificate{tls.ParseCertificate(cert.MustGenerate(nil))},
  63. },
  64. ),
  65. },
  66. TransportSettings: []*internet.TransportConfig{
  67. {
  68. ProtocolName: "hysteria2",
  69. Settings: serial.ToTypedMessage(&hyTransport.Config{
  70. Congestion: &hyTransport.Congestion{Type: congestionType, UpMbps: 100, DownMbps: 100},
  71. Password: "password",
  72. }),
  73. },
  74. },
  75. },
  76. }),
  77. ProxySettings: serial.ToTypedMessage(&inbound.Config{
  78. User: []*protocol.User{
  79. {
  80. Account: serial.ToTypedMessage(&vmess.Account{
  81. Id: userID.String(),
  82. AlterId: 0,
  83. }),
  84. },
  85. },
  86. }),
  87. },
  88. },
  89. Outbound: []*core.OutboundHandlerConfig{
  90. {
  91. ProxySettings: serial.ToTypedMessage(&freedom.Config{}),
  92. },
  93. },
  94. }
  95. clientPort := tcp.PickPort()
  96. clientConfig := &core.Config{
  97. App: []*anypb.Any{
  98. serial.ToTypedMessage(&log.Config{
  99. Error: &log.LogSpecification{Level: clog.Severity_Debug, Type: log.LogType_Console},
  100. }),
  101. },
  102. Inbound: []*core.InboundHandlerConfig{
  103. {
  104. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  105. PortRange: net.SinglePortRange(clientPort),
  106. Listen: net.NewIPOrDomain(net.LocalHostIP),
  107. }),
  108. ProxySettings: serial.ToTypedMessage(&dokodemo.Config{
  109. Address: net.NewIPOrDomain(dest.Address),
  110. Port: uint32(dest.Port),
  111. NetworkList: &net.NetworkList{
  112. Network: []net.Network{net.Network_TCP},
  113. },
  114. }),
  115. },
  116. },
  117. Outbound: []*core.OutboundHandlerConfig{
  118. {
  119. SenderSettings: serial.ToTypedMessage(&proxyman.SenderConfig{
  120. StreamSettings: &internet.StreamConfig{
  121. ProtocolName: "hysteria2",
  122. SecurityType: serial.GetMessageType(&tls.Config{}),
  123. SecuritySettings: []*anypb.Any{
  124. serial.ToTypedMessage(
  125. &tls.Config{
  126. ServerName: "www.v2fly.org",
  127. AllowInsecure: true,
  128. },
  129. ),
  130. },
  131. TransportSettings: []*internet.TransportConfig{
  132. {
  133. ProtocolName: "hysteria2",
  134. Settings: serial.ToTypedMessage(&hyTransport.Config{
  135. Congestion: &hyTransport.Congestion{Type: congestionType, UpMbps: 100, DownMbps: 100},
  136. Password: "password",
  137. }),
  138. },
  139. },
  140. },
  141. }),
  142. ProxySettings: serial.ToTypedMessage(&outbound.Config{
  143. Receiver: []*protocol.ServerEndpoint{
  144. {
  145. Address: net.NewIPOrDomain(net.LocalHostIP),
  146. Port: uint32(serverPort),
  147. User: []*protocol.User{
  148. {
  149. Account: serial.ToTypedMessage(&vmess.Account{
  150. Id: userID.String(),
  151. AlterId: 0,
  152. SecuritySettings: &protocol.SecurityConfig{
  153. Type: protocol.SecurityType_NONE,
  154. },
  155. }),
  156. },
  157. },
  158. },
  159. },
  160. }),
  161. },
  162. },
  163. }
  164. servers, err := InitializeServerConfigs(serverConfig, clientConfig)
  165. if err != nil {
  166. t.Fatal("Failed to initialize all servers: ", err.Error())
  167. }
  168. defer CloseAllServers(servers)
  169. var errg errgroup.Group
  170. for i := 0; i < 10; i++ {
  171. errg.Go(testTCPConn(clientPort, 10240*1024, time.Second*40))
  172. }
  173. if err := errg.Wait(); err != nil {
  174. t.Error(err)
  175. }
  176. }
  177. func TestHysteria2Offical(t *testing.T) {
  178. for _, v := range []bool{true, false} {
  179. testHysteria2Offical(t, v)
  180. }
  181. }
  182. func testHysteria2Offical(t *testing.T, isUDP bool) {
  183. var dest net.Destination
  184. var err error
  185. if isUDP {
  186. udpServer := udp.Server{
  187. MsgProcessor: xor,
  188. }
  189. dest, err = udpServer.Start()
  190. common.Must(err)
  191. defer udpServer.Close()
  192. } else {
  193. tcpServer := tcp.Server{
  194. MsgProcessor: xor,
  195. }
  196. dest, err = tcpServer.Start()
  197. common.Must(err)
  198. defer tcpServer.Close()
  199. }
  200. serverPort := udp.PickPort()
  201. serverConfig := &core.Config{
  202. App: []*anypb.Any{
  203. serial.ToTypedMessage(&log.Config{
  204. Error: &log.LogSpecification{Level: clog.Severity_Debug, Type: log.LogType_Console},
  205. }),
  206. },
  207. Inbound: []*core.InboundHandlerConfig{
  208. {
  209. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  210. PortRange: net.SinglePortRange(serverPort),
  211. Listen: net.NewIPOrDomain(net.LocalHostIP),
  212. StreamSettings: &internet.StreamConfig{
  213. ProtocolName: "hysteria2",
  214. SecurityType: serial.GetMessageType(&tls.Config{}),
  215. SecuritySettings: []*anypb.Any{
  216. serial.ToTypedMessage(
  217. &tls.Config{
  218. Certificate: []*tls.Certificate{tls.ParseCertificate(cert.MustGenerate(nil))},
  219. },
  220. ),
  221. },
  222. TransportSettings: []*internet.TransportConfig{
  223. {
  224. ProtocolName: "hysteria2",
  225. Settings: serial.ToTypedMessage(&hyTransport.Config{
  226. Congestion: &hyTransport.Congestion{Type: "brutal", UpMbps: 100, DownMbps: 100},
  227. UseUdpExtension: true,
  228. Password: "password",
  229. }),
  230. },
  231. },
  232. },
  233. }),
  234. ProxySettings: serial.ToTypedMessage(&hysteria2.ServerConfig{}),
  235. },
  236. },
  237. Outbound: []*core.OutboundHandlerConfig{
  238. {
  239. ProxySettings: serial.ToTypedMessage(&freedom.Config{}),
  240. },
  241. },
  242. }
  243. clientPort := tcp.PickPort()
  244. clientConfig := &core.Config{
  245. App: []*anypb.Any{
  246. serial.ToTypedMessage(&log.Config{
  247. Error: &log.LogSpecification{Level: clog.Severity_Debug, Type: log.LogType_Console},
  248. }),
  249. },
  250. Inbound: []*core.InboundHandlerConfig{
  251. {
  252. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  253. PortRange: net.SinglePortRange(clientPort),
  254. Listen: net.NewIPOrDomain(net.LocalHostIP),
  255. }),
  256. ProxySettings: serial.ToTypedMessage(&dokodemo.Config{
  257. Address: net.NewIPOrDomain(dest.Address),
  258. Port: uint32(dest.Port),
  259. NetworkList: &net.NetworkList{
  260. Network: []net.Network{net.Network_TCP, net.Network_UDP},
  261. },
  262. }),
  263. },
  264. },
  265. Outbound: []*core.OutboundHandlerConfig{
  266. {
  267. SenderSettings: serial.ToTypedMessage(&proxyman.SenderConfig{
  268. StreamSettings: &internet.StreamConfig{
  269. ProtocolName: "hysteria2",
  270. SecurityType: serial.GetMessageType(&tls.Config{}),
  271. SecuritySettings: []*anypb.Any{
  272. serial.ToTypedMessage(
  273. &tls.Config{
  274. ServerName: "www.v2fly.org",
  275. AllowInsecure: true,
  276. },
  277. ),
  278. },
  279. TransportSettings: []*internet.TransportConfig{
  280. {
  281. ProtocolName: "hysteria2",
  282. Settings: serial.ToTypedMessage(&hyTransport.Config{
  283. Congestion: &hyTransport.Congestion{Type: "brutal", UpMbps: 100, DownMbps: 100},
  284. UseUdpExtension: true,
  285. Password: "password",
  286. }),
  287. },
  288. },
  289. },
  290. }),
  291. ProxySettings: serial.ToTypedMessage(&hysteria2.ClientConfig{
  292. Server: []*protocol.ServerEndpoint{
  293. {
  294. Address: net.NewIPOrDomain(net.LocalHostIP),
  295. Port: uint32(serverPort),
  296. User: []*protocol.User{
  297. {
  298. Account: serial.ToTypedMessage(&hysteria2.Account{}),
  299. },
  300. },
  301. },
  302. },
  303. }),
  304. },
  305. },
  306. }
  307. servers, err := InitializeServerConfigs(serverConfig, clientConfig)
  308. if err != nil {
  309. t.Fatal("Failed to initialize all servers: ", err.Error())
  310. }
  311. defer CloseAllServers(servers)
  312. var errg errgroup.Group
  313. for i := 0; i < 10; i++ {
  314. if isUDP {
  315. errg.Go(testUDPConn(clientPort, 1500, time.Second*4))
  316. } else {
  317. errg.Go(testTCPConn(clientPort, 10240*1024, time.Second*40))
  318. }
  319. }
  320. if err := errg.Wait(); err != nil {
  321. t.Error(err)
  322. }
  323. }
  324. func TestHysteria2OnTCP(t *testing.T) {
  325. tcpServer := tcp.Server{
  326. MsgProcessor: xor,
  327. }
  328. dest, err := tcpServer.Start()
  329. common.Must(err)
  330. defer tcpServer.Close()
  331. serverPort := udp.PickPort()
  332. serverConfig := &core.Config{
  333. App: []*anypb.Any{
  334. serial.ToTypedMessage(&log.Config{
  335. Error: &log.LogSpecification{Level: clog.Severity_Debug, Type: log.LogType_Console},
  336. }),
  337. },
  338. Inbound: []*core.InboundHandlerConfig{
  339. {
  340. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  341. PortRange: net.SinglePortRange(serverPort),
  342. Listen: net.NewIPOrDomain(net.LocalHostIP),
  343. StreamSettings: &internet.StreamConfig{
  344. SecurityType: serial.GetMessageType(&tls.Config{}),
  345. SecuritySettings: []*anypb.Any{
  346. serial.ToTypedMessage(
  347. &tls.Config{
  348. Certificate: []*tls.Certificate{tls.ParseCertificate(cert.MustGenerate(nil))},
  349. },
  350. ),
  351. },
  352. TransportSettings: []*internet.TransportConfig{
  353. {
  354. Protocol: internet.TransportProtocol_TCP,
  355. Settings: serial.ToTypedMessage(&tcpTransport.Config{
  356. HeaderSettings: serial.ToTypedMessage(&http.Config{}),
  357. }),
  358. },
  359. },
  360. },
  361. }),
  362. ProxySettings: serial.ToTypedMessage(&hysteria2.ServerConfig{}),
  363. },
  364. },
  365. Outbound: []*core.OutboundHandlerConfig{
  366. {
  367. ProxySettings: serial.ToTypedMessage(&freedom.Config{}),
  368. },
  369. },
  370. }
  371. clientPort := tcp.PickPort()
  372. clientConfig := &core.Config{
  373. App: []*anypb.Any{
  374. serial.ToTypedMessage(&log.Config{
  375. Error: &log.LogSpecification{Level: clog.Severity_Debug, Type: log.LogType_Console},
  376. }),
  377. },
  378. Inbound: []*core.InboundHandlerConfig{
  379. {
  380. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  381. PortRange: net.SinglePortRange(clientPort),
  382. Listen: net.NewIPOrDomain(net.LocalHostIP),
  383. }),
  384. ProxySettings: serial.ToTypedMessage(&dokodemo.Config{
  385. Address: net.NewIPOrDomain(dest.Address),
  386. Port: uint32(dest.Port),
  387. NetworkList: &net.NetworkList{
  388. Network: []net.Network{net.Network_TCP},
  389. },
  390. }),
  391. },
  392. },
  393. Outbound: []*core.OutboundHandlerConfig{
  394. {
  395. SenderSettings: serial.ToTypedMessage(&proxyman.SenderConfig{
  396. StreamSettings: &internet.StreamConfig{
  397. SecurityType: serial.GetMessageType(&tls.Config{}),
  398. SecuritySettings: []*anypb.Any{
  399. serial.ToTypedMessage(
  400. &tls.Config{
  401. ServerName: "www.v2fly.org",
  402. AllowInsecure: true,
  403. },
  404. ),
  405. },
  406. TransportSettings: []*internet.TransportConfig{
  407. {
  408. Protocol: internet.TransportProtocol_TCP,
  409. Settings: serial.ToTypedMessage(&tcpTransport.Config{
  410. HeaderSettings: serial.ToTypedMessage(&http.Config{}),
  411. }),
  412. },
  413. },
  414. },
  415. }),
  416. ProxySettings: serial.ToTypedMessage(&hysteria2.ClientConfig{
  417. Server: []*protocol.ServerEndpoint{
  418. {
  419. Address: net.NewIPOrDomain(net.LocalHostIP),
  420. Port: uint32(serverPort),
  421. User: []*protocol.User{
  422. {
  423. Account: serial.ToTypedMessage(&hysteria2.Account{}),
  424. },
  425. },
  426. },
  427. },
  428. }),
  429. },
  430. },
  431. }
  432. servers, err := InitializeServerConfigs(serverConfig, clientConfig)
  433. if err != nil {
  434. t.Fatal("Failed to initialize all servers: ", err.Error())
  435. }
  436. defer CloseAllServers(servers)
  437. var errg errgroup.Group
  438. for i := 0; i < 1; i++ {
  439. errg.Go(testTCPConn(clientPort, 10240*1024, time.Second*40))
  440. }
  441. if err := errg.Wait(); err != nil {
  442. t.Error(err)
  443. }
  444. }