shadowsocks_test.go 9.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376
  1. package scenarios
  2. import (
  3. "crypto/rand"
  4. "sync"
  5. "testing"
  6. "time"
  7. "v2ray.com/core"
  8. "v2ray.com/core/app/log"
  9. "v2ray.com/core/app/proxyman"
  10. "v2ray.com/core/common/net"
  11. "v2ray.com/core/common/protocol"
  12. "v2ray.com/core/common/serial"
  13. "v2ray.com/core/proxy/dokodemo"
  14. "v2ray.com/core/proxy/freedom"
  15. "v2ray.com/core/proxy/shadowsocks"
  16. "v2ray.com/core/testing/assert"
  17. "v2ray.com/core/testing/servers/tcp"
  18. "v2ray.com/core/testing/servers/udp"
  19. )
  20. func TestShadowsocksAES256TCP(t *testing.T) {
  21. assert := assert.On(t)
  22. tcpServer := tcp.Server{
  23. MsgProcessor: xor,
  24. }
  25. dest, err := tcpServer.Start()
  26. assert.Error(err).IsNil()
  27. defer tcpServer.Close()
  28. account := serial.ToTypedMessage(&shadowsocks.Account{
  29. Password: "shadowsocks-password",
  30. CipherType: shadowsocks.CipherType_AES_256_CFB,
  31. Ota: shadowsocks.Account_Enabled,
  32. })
  33. serverPort := pickPort()
  34. serverConfig := &core.Config{
  35. Inbound: []*proxyman.InboundHandlerConfig{
  36. {
  37. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  38. PortRange: net.SinglePortRange(serverPort),
  39. Listen: net.NewIPOrDomain(net.LocalHostIP),
  40. }),
  41. ProxySettings: serial.ToTypedMessage(&shadowsocks.ServerConfig{
  42. User: &protocol.User{
  43. Account: account,
  44. Level: 1,
  45. },
  46. }),
  47. },
  48. },
  49. Outbound: []*proxyman.OutboundHandlerConfig{
  50. {
  51. ProxySettings: serial.ToTypedMessage(&freedom.Config{}),
  52. },
  53. },
  54. App: []*serial.TypedMessage{
  55. serial.ToTypedMessage(&log.Config{
  56. ErrorLogLevel: log.LogLevel_Debug,
  57. ErrorLogType: log.LogType_Console,
  58. }),
  59. },
  60. }
  61. clientPort := pickPort()
  62. clientConfig := &core.Config{
  63. Inbound: []*proxyman.InboundHandlerConfig{
  64. {
  65. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  66. PortRange: net.SinglePortRange(clientPort),
  67. Listen: net.NewIPOrDomain(net.LocalHostIP),
  68. }),
  69. ProxySettings: serial.ToTypedMessage(&dokodemo.Config{
  70. Address: net.NewIPOrDomain(dest.Address),
  71. Port: uint32(dest.Port),
  72. NetworkList: &net.NetworkList{
  73. Network: []net.Network{net.Network_TCP},
  74. },
  75. }),
  76. },
  77. },
  78. Outbound: []*proxyman.OutboundHandlerConfig{
  79. {
  80. ProxySettings: serial.ToTypedMessage(&shadowsocks.ClientConfig{
  81. Server: []*protocol.ServerEndpoint{
  82. {
  83. Address: net.NewIPOrDomain(net.LocalHostIP),
  84. Port: uint32(serverPort),
  85. User: []*protocol.User{
  86. {
  87. Account: account,
  88. },
  89. },
  90. },
  91. },
  92. }),
  93. },
  94. },
  95. App: []*serial.TypedMessage{
  96. serial.ToTypedMessage(&log.Config{
  97. ErrorLogLevel: log.LogLevel_Debug,
  98. ErrorLogType: log.LogType_Console,
  99. }),
  100. },
  101. }
  102. servers, err := InitializeServerConfigs(serverConfig, clientConfig)
  103. assert.Error(err).IsNil()
  104. var wg sync.WaitGroup
  105. wg.Add(10)
  106. for i := 0; i < 10; i++ {
  107. go func() {
  108. conn, err := net.DialTCP("tcp", nil, &net.TCPAddr{
  109. IP: []byte{127, 0, 0, 1},
  110. Port: int(clientPort),
  111. })
  112. assert.Error(err).IsNil()
  113. payload := make([]byte, 10240*1024)
  114. rand.Read(payload)
  115. nBytes, err := conn.Write([]byte(payload))
  116. assert.Error(err).IsNil()
  117. assert.Int(nBytes).Equals(len(payload))
  118. response := readFrom(conn, time.Second*20, 10240*1024)
  119. assert.Bytes(response).Equals(xor([]byte(payload)))
  120. assert.Error(conn.Close()).IsNil()
  121. wg.Done()
  122. }()
  123. }
  124. wg.Wait()
  125. CloseAllServers(servers)
  126. }
  127. func TestShadowsocksAES128UDP(t *testing.T) {
  128. assert := assert.On(t)
  129. udpServer := udp.Server{
  130. MsgProcessor: xor,
  131. }
  132. dest, err := udpServer.Start()
  133. assert.Error(err).IsNil()
  134. defer udpServer.Close()
  135. account := serial.ToTypedMessage(&shadowsocks.Account{
  136. Password: "shadowsocks-password",
  137. CipherType: shadowsocks.CipherType_AES_128_CFB,
  138. Ota: shadowsocks.Account_Enabled,
  139. })
  140. serverPort := pickPort()
  141. serverConfig := &core.Config{
  142. Inbound: []*proxyman.InboundHandlerConfig{
  143. {
  144. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  145. PortRange: net.SinglePortRange(serverPort),
  146. Listen: net.NewIPOrDomain(net.LocalHostIP),
  147. }),
  148. ProxySettings: serial.ToTypedMessage(&shadowsocks.ServerConfig{
  149. UdpEnabled: true,
  150. User: &protocol.User{
  151. Account: account,
  152. Level: 1,
  153. },
  154. }),
  155. },
  156. },
  157. Outbound: []*proxyman.OutboundHandlerConfig{
  158. {
  159. ProxySettings: serial.ToTypedMessage(&freedom.Config{}),
  160. },
  161. },
  162. App: []*serial.TypedMessage{
  163. serial.ToTypedMessage(&log.Config{
  164. ErrorLogLevel: log.LogLevel_Debug,
  165. ErrorLogType: log.LogType_Console,
  166. }),
  167. },
  168. }
  169. clientPort := pickPort()
  170. clientConfig := &core.Config{
  171. Inbound: []*proxyman.InboundHandlerConfig{
  172. {
  173. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  174. PortRange: net.SinglePortRange(clientPort),
  175. Listen: net.NewIPOrDomain(net.LocalHostIP),
  176. }),
  177. ProxySettings: serial.ToTypedMessage(&dokodemo.Config{
  178. Address: net.NewIPOrDomain(dest.Address),
  179. Port: uint32(dest.Port),
  180. NetworkList: &net.NetworkList{
  181. Network: []net.Network{net.Network_UDP},
  182. },
  183. }),
  184. },
  185. },
  186. Outbound: []*proxyman.OutboundHandlerConfig{
  187. {
  188. ProxySettings: serial.ToTypedMessage(&shadowsocks.ClientConfig{
  189. Server: []*protocol.ServerEndpoint{
  190. {
  191. Address: net.NewIPOrDomain(net.LocalHostIP),
  192. Port: uint32(serverPort),
  193. User: []*protocol.User{
  194. {
  195. Account: account,
  196. },
  197. },
  198. },
  199. },
  200. }),
  201. },
  202. },
  203. App: []*serial.TypedMessage{
  204. serial.ToTypedMessage(&log.Config{
  205. ErrorLogLevel: log.LogLevel_Debug,
  206. ErrorLogType: log.LogType_Console,
  207. }),
  208. },
  209. }
  210. servers, err := InitializeServerConfigs(serverConfig, clientConfig)
  211. assert.Error(err).IsNil()
  212. var wg sync.WaitGroup
  213. wg.Add(10)
  214. for i := 0; i < 10; i++ {
  215. go func() {
  216. conn, err := net.DialUDP("udp", nil, &net.UDPAddr{
  217. IP: []byte{127, 0, 0, 1},
  218. Port: int(clientPort),
  219. })
  220. assert.Error(err).IsNil()
  221. payload := make([]byte, 1024)
  222. rand.Read(payload)
  223. nBytes, err := conn.Write([]byte(payload))
  224. assert.Error(err).IsNil()
  225. assert.Int(nBytes).Equals(len(payload))
  226. response := readFrom(conn, time.Second*5, 1024)
  227. assert.Bytes(response).Equals(xor([]byte(payload)))
  228. assert.Error(conn.Close()).IsNil()
  229. wg.Done()
  230. }()
  231. }
  232. wg.Wait()
  233. CloseAllServers(servers)
  234. }
  235. func TestShadowsocksChacha20TCP(t *testing.T) {
  236. assert := assert.On(t)
  237. tcpServer := tcp.Server{
  238. MsgProcessor: xor,
  239. }
  240. dest, err := tcpServer.Start()
  241. assert.Error(err).IsNil()
  242. defer tcpServer.Close()
  243. account := serial.ToTypedMessage(&shadowsocks.Account{
  244. Password: "shadowsocks-password",
  245. CipherType: shadowsocks.CipherType_CHACHA20_IETF,
  246. Ota: shadowsocks.Account_Enabled,
  247. })
  248. serverPort := pickPort()
  249. serverConfig := &core.Config{
  250. Inbound: []*proxyman.InboundHandlerConfig{
  251. {
  252. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  253. PortRange: net.SinglePortRange(serverPort),
  254. Listen: net.NewIPOrDomain(net.LocalHostIP),
  255. }),
  256. ProxySettings: serial.ToTypedMessage(&shadowsocks.ServerConfig{
  257. User: &protocol.User{
  258. Account: account,
  259. Level: 1,
  260. },
  261. }),
  262. },
  263. },
  264. Outbound: []*proxyman.OutboundHandlerConfig{
  265. {
  266. ProxySettings: serial.ToTypedMessage(&freedom.Config{}),
  267. },
  268. },
  269. App: []*serial.TypedMessage{
  270. serial.ToTypedMessage(&log.Config{
  271. ErrorLogLevel: log.LogLevel_Debug,
  272. ErrorLogType: log.LogType_Console,
  273. }),
  274. },
  275. }
  276. clientPort := pickPort()
  277. clientConfig := &core.Config{
  278. Inbound: []*proxyman.InboundHandlerConfig{
  279. {
  280. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  281. PortRange: net.SinglePortRange(clientPort),
  282. Listen: net.NewIPOrDomain(net.LocalHostIP),
  283. }),
  284. ProxySettings: serial.ToTypedMessage(&dokodemo.Config{
  285. Address: net.NewIPOrDomain(dest.Address),
  286. Port: uint32(dest.Port),
  287. NetworkList: &net.NetworkList{
  288. Network: []net.Network{net.Network_TCP},
  289. },
  290. }),
  291. },
  292. },
  293. Outbound: []*proxyman.OutboundHandlerConfig{
  294. {
  295. ProxySettings: serial.ToTypedMessage(&shadowsocks.ClientConfig{
  296. Server: []*protocol.ServerEndpoint{
  297. {
  298. Address: net.NewIPOrDomain(net.LocalHostIP),
  299. Port: uint32(serverPort),
  300. User: []*protocol.User{
  301. {
  302. Account: account,
  303. },
  304. },
  305. },
  306. },
  307. }),
  308. },
  309. },
  310. App: []*serial.TypedMessage{
  311. serial.ToTypedMessage(&log.Config{
  312. ErrorLogLevel: log.LogLevel_Debug,
  313. ErrorLogType: log.LogType_Console,
  314. }),
  315. },
  316. }
  317. servers, err := InitializeServerConfigs(serverConfig, clientConfig)
  318. assert.Error(err).IsNil()
  319. var wg sync.WaitGroup
  320. wg.Add(10)
  321. for i := 0; i < 10; i++ {
  322. go func() {
  323. conn, err := net.DialTCP("tcp", nil, &net.TCPAddr{
  324. IP: []byte{127, 0, 0, 1},
  325. Port: int(clientPort),
  326. })
  327. assert.Error(err).IsNil()
  328. payload := make([]byte, 10240*1024)
  329. rand.Read(payload)
  330. nBytes, err := conn.Write([]byte(payload))
  331. assert.Error(err).IsNil()
  332. assert.Int(nBytes).Equals(len(payload))
  333. response := readFrom(conn, time.Second*20, 10240*1024)
  334. assert.Bytes(response).Equals(xor([]byte(payload)))
  335. assert.Error(conn.Close()).IsNil()
  336. wg.Done()
  337. }()
  338. }
  339. wg.Wait()
  340. CloseAllServers(servers)
  341. }