tls_test.go 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664
  1. package scenarios
  2. import (
  3. "crypto/rand"
  4. "crypto/x509"
  5. "runtime"
  6. "sync"
  7. "testing"
  8. "time"
  9. "v2ray.com/core"
  10. "v2ray.com/core/app/proxyman"
  11. "v2ray.com/core/common/net"
  12. "v2ray.com/core/common/protocol"
  13. "v2ray.com/core/common/protocol/tls/cert"
  14. "v2ray.com/core/common/serial"
  15. "v2ray.com/core/common/uuid"
  16. "v2ray.com/core/proxy/dokodemo"
  17. "v2ray.com/core/proxy/freedom"
  18. "v2ray.com/core/proxy/vmess"
  19. "v2ray.com/core/proxy/vmess/inbound"
  20. "v2ray.com/core/proxy/vmess/outbound"
  21. "v2ray.com/core/testing/servers/tcp"
  22. "v2ray.com/core/testing/servers/udp"
  23. "v2ray.com/core/transport/internet"
  24. "v2ray.com/core/transport/internet/http"
  25. "v2ray.com/core/transport/internet/tls"
  26. "v2ray.com/core/transport/internet/websocket"
  27. . "v2ray.com/ext/assert"
  28. )
  29. func TestSimpleTLSConnection(t *testing.T) {
  30. assert := With(t)
  31. tcpServer := tcp.Server{
  32. MsgProcessor: xor,
  33. }
  34. dest, err := tcpServer.Start()
  35. assert(err, IsNil)
  36. defer tcpServer.Close()
  37. userID := protocol.NewID(uuid.New())
  38. serverPort := tcp.PickPort()
  39. serverConfig := &core.Config{
  40. Inbound: []*core.InboundHandlerConfig{
  41. {
  42. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  43. PortRange: net.SinglePortRange(serverPort),
  44. Listen: net.NewIPOrDomain(net.LocalHostIP),
  45. StreamSettings: &internet.StreamConfig{
  46. SecurityType: serial.GetMessageType(&tls.Config{}),
  47. SecuritySettings: []*serial.TypedMessage{
  48. serial.ToTypedMessage(&tls.Config{
  49. Certificate: []*tls.Certificate{tls.ParseCertificate(cert.MustGenerate(nil))},
  50. }),
  51. },
  52. },
  53. }),
  54. ProxySettings: serial.ToTypedMessage(&inbound.Config{
  55. User: []*protocol.User{
  56. {
  57. Account: serial.ToTypedMessage(&vmess.Account{
  58. Id: userID.String(),
  59. }),
  60. },
  61. },
  62. }),
  63. },
  64. },
  65. Outbound: []*core.OutboundHandlerConfig{
  66. {
  67. ProxySettings: serial.ToTypedMessage(&freedom.Config{}),
  68. },
  69. },
  70. }
  71. clientPort := tcp.PickPort()
  72. clientConfig := &core.Config{
  73. Inbound: []*core.InboundHandlerConfig{
  74. {
  75. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  76. PortRange: net.SinglePortRange(clientPort),
  77. Listen: net.NewIPOrDomain(net.LocalHostIP),
  78. }),
  79. ProxySettings: serial.ToTypedMessage(&dokodemo.Config{
  80. Address: net.NewIPOrDomain(dest.Address),
  81. Port: uint32(dest.Port),
  82. NetworkList: &net.NetworkList{
  83. Network: []net.Network{net.Network_TCP},
  84. },
  85. }),
  86. },
  87. },
  88. Outbound: []*core.OutboundHandlerConfig{
  89. {
  90. ProxySettings: serial.ToTypedMessage(&outbound.Config{
  91. Receiver: []*protocol.ServerEndpoint{
  92. {
  93. Address: net.NewIPOrDomain(net.LocalHostIP),
  94. Port: uint32(serverPort),
  95. User: []*protocol.User{
  96. {
  97. Account: serial.ToTypedMessage(&vmess.Account{
  98. Id: userID.String(),
  99. }),
  100. },
  101. },
  102. },
  103. },
  104. }),
  105. SenderSettings: serial.ToTypedMessage(&proxyman.SenderConfig{
  106. StreamSettings: &internet.StreamConfig{
  107. SecurityType: serial.GetMessageType(&tls.Config{}),
  108. SecuritySettings: []*serial.TypedMessage{
  109. serial.ToTypedMessage(&tls.Config{
  110. AllowInsecure: true,
  111. }),
  112. },
  113. },
  114. }),
  115. },
  116. },
  117. }
  118. servers, err := InitializeServerConfigs(serverConfig, clientConfig)
  119. assert(err, IsNil)
  120. conn, err := net.DialTCP("tcp", nil, &net.TCPAddr{
  121. IP: []byte{127, 0, 0, 1},
  122. Port: int(clientPort),
  123. })
  124. assert(err, IsNil)
  125. payload := "dokodemo request."
  126. nBytes, err := conn.Write([]byte(payload))
  127. assert(err, IsNil)
  128. assert(nBytes, Equals, len(payload))
  129. response := readFrom(conn, time.Second*2, len(payload))
  130. assert(response, Equals, xor([]byte(payload)))
  131. assert(conn.Close(), IsNil)
  132. CloseAllServers(servers)
  133. }
  134. func TestAutoIssuingCertificate(t *testing.T) {
  135. if runtime.GOOS == "windows" {
  136. // Not supported on Windows yet.
  137. return
  138. }
  139. if runtime.GOARCH == "arm64" {
  140. return
  141. }
  142. assert := With(t)
  143. tcpServer := tcp.Server{
  144. MsgProcessor: xor,
  145. }
  146. dest, err := tcpServer.Start()
  147. assert(err, IsNil)
  148. defer tcpServer.Close()
  149. caCert, err := cert.Generate(nil, cert.Authority(true), cert.KeyUsage(x509.KeyUsageDigitalSignature|x509.KeyUsageKeyEncipherment|x509.KeyUsageCertSign))
  150. assert(err, IsNil)
  151. certPEM, keyPEM := caCert.ToPEM()
  152. userID := protocol.NewID(uuid.New())
  153. serverPort := tcp.PickPort()
  154. serverConfig := &core.Config{
  155. Inbound: []*core.InboundHandlerConfig{
  156. {
  157. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  158. PortRange: net.SinglePortRange(serverPort),
  159. Listen: net.NewIPOrDomain(net.LocalHostIP),
  160. StreamSettings: &internet.StreamConfig{
  161. SecurityType: serial.GetMessageType(&tls.Config{}),
  162. SecuritySettings: []*serial.TypedMessage{
  163. serial.ToTypedMessage(&tls.Config{
  164. Certificate: []*tls.Certificate{{
  165. Certificate: certPEM,
  166. Key: keyPEM,
  167. Usage: tls.Certificate_AUTHORITY_ISSUE,
  168. }},
  169. }),
  170. },
  171. },
  172. }),
  173. ProxySettings: serial.ToTypedMessage(&inbound.Config{
  174. User: []*protocol.User{
  175. {
  176. Account: serial.ToTypedMessage(&vmess.Account{
  177. Id: userID.String(),
  178. }),
  179. },
  180. },
  181. }),
  182. },
  183. },
  184. Outbound: []*core.OutboundHandlerConfig{
  185. {
  186. ProxySettings: serial.ToTypedMessage(&freedom.Config{}),
  187. },
  188. },
  189. }
  190. clientPort := tcp.PickPort()
  191. clientConfig := &core.Config{
  192. Inbound: []*core.InboundHandlerConfig{
  193. {
  194. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  195. PortRange: net.SinglePortRange(clientPort),
  196. Listen: net.NewIPOrDomain(net.LocalHostIP),
  197. }),
  198. ProxySettings: serial.ToTypedMessage(&dokodemo.Config{
  199. Address: net.NewIPOrDomain(dest.Address),
  200. Port: uint32(dest.Port),
  201. NetworkList: &net.NetworkList{
  202. Network: []net.Network{net.Network_TCP},
  203. },
  204. }),
  205. },
  206. },
  207. Outbound: []*core.OutboundHandlerConfig{
  208. {
  209. ProxySettings: serial.ToTypedMessage(&outbound.Config{
  210. Receiver: []*protocol.ServerEndpoint{
  211. {
  212. Address: net.NewIPOrDomain(net.LocalHostIP),
  213. Port: uint32(serverPort),
  214. User: []*protocol.User{
  215. {
  216. Account: serial.ToTypedMessage(&vmess.Account{
  217. Id: userID.String(),
  218. }),
  219. },
  220. },
  221. },
  222. },
  223. }),
  224. SenderSettings: serial.ToTypedMessage(&proxyman.SenderConfig{
  225. StreamSettings: &internet.StreamConfig{
  226. SecurityType: serial.GetMessageType(&tls.Config{}),
  227. SecuritySettings: []*serial.TypedMessage{
  228. serial.ToTypedMessage(&tls.Config{
  229. ServerName: "v2ray.com",
  230. Certificate: []*tls.Certificate{{
  231. Certificate: certPEM,
  232. Usage: tls.Certificate_AUTHORITY_VERIFY,
  233. }},
  234. }),
  235. },
  236. },
  237. }),
  238. },
  239. },
  240. }
  241. servers, err := InitializeServerConfigs(serverConfig, clientConfig)
  242. assert(err, IsNil)
  243. for i := 0; i < 10; i++ {
  244. conn, err := net.DialTCP("tcp", nil, &net.TCPAddr{
  245. IP: []byte{127, 0, 0, 1},
  246. Port: int(clientPort),
  247. })
  248. assert(err, IsNil)
  249. payload := "dokodemo request."
  250. nBytes, err := conn.Write([]byte(payload))
  251. assert(err, IsNil)
  252. assert(nBytes, Equals, len(payload))
  253. response := readFrom(conn, time.Second*2, len(payload))
  254. assert(response, Equals, xor([]byte(payload)))
  255. assert(conn.Close(), IsNil)
  256. }
  257. CloseAllServers(servers)
  258. }
  259. func TestTLSOverKCP(t *testing.T) {
  260. assert := With(t)
  261. tcpServer := tcp.Server{
  262. MsgProcessor: xor,
  263. }
  264. dest, err := tcpServer.Start()
  265. assert(err, IsNil)
  266. defer tcpServer.Close()
  267. userID := protocol.NewID(uuid.New())
  268. serverPort := udp.PickPort()
  269. serverConfig := &core.Config{
  270. Inbound: []*core.InboundHandlerConfig{
  271. {
  272. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  273. PortRange: net.SinglePortRange(serverPort),
  274. Listen: net.NewIPOrDomain(net.LocalHostIP),
  275. StreamSettings: &internet.StreamConfig{
  276. Protocol: internet.TransportProtocol_MKCP,
  277. SecurityType: serial.GetMessageType(&tls.Config{}),
  278. SecuritySettings: []*serial.TypedMessage{
  279. serial.ToTypedMessage(&tls.Config{
  280. Certificate: []*tls.Certificate{tls.ParseCertificate(cert.MustGenerate(nil))},
  281. }),
  282. },
  283. },
  284. }),
  285. ProxySettings: serial.ToTypedMessage(&inbound.Config{
  286. User: []*protocol.User{
  287. {
  288. Account: serial.ToTypedMessage(&vmess.Account{
  289. Id: userID.String(),
  290. }),
  291. },
  292. },
  293. }),
  294. },
  295. },
  296. Outbound: []*core.OutboundHandlerConfig{
  297. {
  298. ProxySettings: serial.ToTypedMessage(&freedom.Config{}),
  299. },
  300. },
  301. }
  302. clientPort := tcp.PickPort()
  303. clientConfig := &core.Config{
  304. Inbound: []*core.InboundHandlerConfig{
  305. {
  306. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  307. PortRange: net.SinglePortRange(clientPort),
  308. Listen: net.NewIPOrDomain(net.LocalHostIP),
  309. }),
  310. ProxySettings: serial.ToTypedMessage(&dokodemo.Config{
  311. Address: net.NewIPOrDomain(dest.Address),
  312. Port: uint32(dest.Port),
  313. NetworkList: &net.NetworkList{
  314. Network: []net.Network{net.Network_TCP},
  315. },
  316. }),
  317. },
  318. },
  319. Outbound: []*core.OutboundHandlerConfig{
  320. {
  321. ProxySettings: serial.ToTypedMessage(&outbound.Config{
  322. Receiver: []*protocol.ServerEndpoint{
  323. {
  324. Address: net.NewIPOrDomain(net.LocalHostIP),
  325. Port: uint32(serverPort),
  326. User: []*protocol.User{
  327. {
  328. Account: serial.ToTypedMessage(&vmess.Account{
  329. Id: userID.String(),
  330. }),
  331. },
  332. },
  333. },
  334. },
  335. }),
  336. SenderSettings: serial.ToTypedMessage(&proxyman.SenderConfig{
  337. StreamSettings: &internet.StreamConfig{
  338. Protocol: internet.TransportProtocol_MKCP,
  339. SecurityType: serial.GetMessageType(&tls.Config{}),
  340. SecuritySettings: []*serial.TypedMessage{
  341. serial.ToTypedMessage(&tls.Config{
  342. AllowInsecure: true,
  343. }),
  344. },
  345. },
  346. }),
  347. },
  348. },
  349. }
  350. servers, err := InitializeServerConfigs(serverConfig, clientConfig)
  351. assert(err, IsNil)
  352. conn, err := net.DialTCP("tcp", nil, &net.TCPAddr{
  353. IP: []byte{127, 0, 0, 1},
  354. Port: int(clientPort),
  355. })
  356. assert(err, IsNil)
  357. payload := "dokodemo request."
  358. nBytes, err := conn.Write([]byte(payload))
  359. assert(err, IsNil)
  360. assert(nBytes, Equals, len(payload))
  361. response := readFrom(conn, time.Second*2, len(payload))
  362. assert(response, Equals, xor([]byte(payload)))
  363. assert(conn.Close(), IsNil)
  364. CloseAllServers(servers)
  365. }
  366. func TestTLSOverWebSocket(t *testing.T) {
  367. assert := With(t)
  368. tcpServer := tcp.Server{
  369. MsgProcessor: xor,
  370. }
  371. dest, err := tcpServer.Start()
  372. assert(err, IsNil)
  373. defer tcpServer.Close()
  374. userID := protocol.NewID(uuid.New())
  375. serverPort := tcp.PickPort()
  376. serverConfig := &core.Config{
  377. Inbound: []*core.InboundHandlerConfig{
  378. {
  379. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  380. PortRange: net.SinglePortRange(serverPort),
  381. Listen: net.NewIPOrDomain(net.LocalHostIP),
  382. StreamSettings: &internet.StreamConfig{
  383. Protocol: internet.TransportProtocol_WebSocket,
  384. SecurityType: serial.GetMessageType(&tls.Config{}),
  385. SecuritySettings: []*serial.TypedMessage{
  386. serial.ToTypedMessage(&tls.Config{
  387. Certificate: []*tls.Certificate{tls.ParseCertificate(cert.MustGenerate(nil))},
  388. }),
  389. },
  390. },
  391. }),
  392. ProxySettings: serial.ToTypedMessage(&inbound.Config{
  393. User: []*protocol.User{
  394. {
  395. Account: serial.ToTypedMessage(&vmess.Account{
  396. Id: userID.String(),
  397. }),
  398. },
  399. },
  400. }),
  401. },
  402. },
  403. Outbound: []*core.OutboundHandlerConfig{
  404. {
  405. ProxySettings: serial.ToTypedMessage(&freedom.Config{}),
  406. },
  407. },
  408. }
  409. clientPort := tcp.PickPort()
  410. clientConfig := &core.Config{
  411. Inbound: []*core.InboundHandlerConfig{
  412. {
  413. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  414. PortRange: net.SinglePortRange(clientPort),
  415. Listen: net.NewIPOrDomain(net.LocalHostIP),
  416. }),
  417. ProxySettings: serial.ToTypedMessage(&dokodemo.Config{
  418. Address: net.NewIPOrDomain(dest.Address),
  419. Port: uint32(dest.Port),
  420. NetworkList: &net.NetworkList{
  421. Network: []net.Network{net.Network_TCP},
  422. },
  423. }),
  424. },
  425. },
  426. Outbound: []*core.OutboundHandlerConfig{
  427. {
  428. ProxySettings: serial.ToTypedMessage(&outbound.Config{
  429. Receiver: []*protocol.ServerEndpoint{
  430. {
  431. Address: net.NewIPOrDomain(net.LocalHostIP),
  432. Port: uint32(serverPort),
  433. User: []*protocol.User{
  434. {
  435. Account: serial.ToTypedMessage(&vmess.Account{
  436. Id: userID.String(),
  437. }),
  438. },
  439. },
  440. },
  441. },
  442. }),
  443. SenderSettings: serial.ToTypedMessage(&proxyman.SenderConfig{
  444. StreamSettings: &internet.StreamConfig{
  445. Protocol: internet.TransportProtocol_WebSocket,
  446. TransportSettings: []*internet.TransportConfig{
  447. {
  448. Protocol: internet.TransportProtocol_WebSocket,
  449. Settings: serial.ToTypedMessage(&websocket.Config{}),
  450. },
  451. },
  452. SecurityType: serial.GetMessageType(&tls.Config{}),
  453. SecuritySettings: []*serial.TypedMessage{
  454. serial.ToTypedMessage(&tls.Config{
  455. AllowInsecure: true,
  456. }),
  457. },
  458. },
  459. }),
  460. },
  461. },
  462. }
  463. servers, err := InitializeServerConfigs(serverConfig, clientConfig)
  464. assert(err, IsNil)
  465. conn, err := net.DialTCP("tcp", nil, &net.TCPAddr{
  466. IP: []byte{127, 0, 0, 1},
  467. Port: int(clientPort),
  468. })
  469. assert(err, IsNil)
  470. payload := make([]byte, 10240*1024)
  471. rand.Read(payload)
  472. nBytes, err := conn.Write([]byte(payload))
  473. assert(err, IsNil)
  474. assert(nBytes, Equals, len(payload))
  475. response := readFrom(conn, time.Second*20, len(payload))
  476. assert(response, Equals, xor([]byte(payload)))
  477. assert(conn.Close(), IsNil)
  478. CloseAllServers(servers)
  479. }
  480. func TestHTTP2(t *testing.T) {
  481. assert := With(t)
  482. tcpServer := tcp.Server{
  483. MsgProcessor: xor,
  484. }
  485. dest, err := tcpServer.Start()
  486. assert(err, IsNil)
  487. defer tcpServer.Close()
  488. userID := protocol.NewID(uuid.New())
  489. serverPort := tcp.PickPort()
  490. serverConfig := &core.Config{
  491. Inbound: []*core.InboundHandlerConfig{
  492. {
  493. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  494. PortRange: net.SinglePortRange(serverPort),
  495. Listen: net.NewIPOrDomain(net.LocalHostIP),
  496. StreamSettings: &internet.StreamConfig{
  497. Protocol: internet.TransportProtocol_HTTP,
  498. TransportSettings: []*internet.TransportConfig{
  499. {
  500. Protocol: internet.TransportProtocol_HTTP,
  501. Settings: serial.ToTypedMessage(&http.Config{
  502. Host: []string{"v2ray.com"},
  503. Path: "/testpath",
  504. }),
  505. },
  506. },
  507. SecurityType: serial.GetMessageType(&tls.Config{}),
  508. SecuritySettings: []*serial.TypedMessage{
  509. serial.ToTypedMessage(&tls.Config{
  510. Certificate: []*tls.Certificate{tls.ParseCertificate(cert.MustGenerate(nil))},
  511. }),
  512. },
  513. },
  514. }),
  515. ProxySettings: serial.ToTypedMessage(&inbound.Config{
  516. User: []*protocol.User{
  517. {
  518. Account: serial.ToTypedMessage(&vmess.Account{
  519. Id: userID.String(),
  520. }),
  521. },
  522. },
  523. }),
  524. },
  525. },
  526. Outbound: []*core.OutboundHandlerConfig{
  527. {
  528. ProxySettings: serial.ToTypedMessage(&freedom.Config{}),
  529. },
  530. },
  531. }
  532. clientPort := tcp.PickPort()
  533. clientConfig := &core.Config{
  534. Inbound: []*core.InboundHandlerConfig{
  535. {
  536. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  537. PortRange: net.SinglePortRange(clientPort),
  538. Listen: net.NewIPOrDomain(net.LocalHostIP),
  539. }),
  540. ProxySettings: serial.ToTypedMessage(&dokodemo.Config{
  541. Address: net.NewIPOrDomain(dest.Address),
  542. Port: uint32(dest.Port),
  543. NetworkList: &net.NetworkList{
  544. Network: []net.Network{net.Network_TCP},
  545. },
  546. }),
  547. },
  548. },
  549. Outbound: []*core.OutboundHandlerConfig{
  550. {
  551. ProxySettings: serial.ToTypedMessage(&outbound.Config{
  552. Receiver: []*protocol.ServerEndpoint{
  553. {
  554. Address: net.NewIPOrDomain(net.LocalHostIP),
  555. Port: uint32(serverPort),
  556. User: []*protocol.User{
  557. {
  558. Account: serial.ToTypedMessage(&vmess.Account{
  559. Id: userID.String(),
  560. }),
  561. },
  562. },
  563. },
  564. },
  565. }),
  566. SenderSettings: serial.ToTypedMessage(&proxyman.SenderConfig{
  567. StreamSettings: &internet.StreamConfig{
  568. Protocol: internet.TransportProtocol_HTTP,
  569. TransportSettings: []*internet.TransportConfig{
  570. {
  571. Protocol: internet.TransportProtocol_HTTP,
  572. Settings: serial.ToTypedMessage(&http.Config{
  573. Host: []string{"v2ray.com"},
  574. Path: "/testpath",
  575. }),
  576. },
  577. },
  578. SecurityType: serial.GetMessageType(&tls.Config{}),
  579. SecuritySettings: []*serial.TypedMessage{
  580. serial.ToTypedMessage(&tls.Config{
  581. AllowInsecure: true,
  582. }),
  583. },
  584. },
  585. }),
  586. },
  587. },
  588. }
  589. servers, err := InitializeServerConfigs(serverConfig, clientConfig)
  590. assert(err, IsNil)
  591. var wg sync.WaitGroup
  592. for i := 0; i < 10; i++ {
  593. wg.Add(1)
  594. go func() {
  595. defer wg.Done()
  596. conn, err := net.DialTCP("tcp", nil, &net.TCPAddr{
  597. IP: []byte{127, 0, 0, 1},
  598. Port: int(clientPort),
  599. })
  600. assert(err, IsNil)
  601. payload := make([]byte, 10240*1024)
  602. rand.Read(payload)
  603. nBytes, err := conn.Write([]byte(payload))
  604. assert(err, IsNil)
  605. assert(nBytes, Equals, len(payload))
  606. response := readFrom(conn, time.Second*20, len(payload))
  607. assert(response, Equals, xor([]byte(payload)))
  608. assert(conn.Close(), IsNil)
  609. }()
  610. }
  611. wg.Wait()
  612. CloseAllServers(servers)
  613. }