protocol_test.go 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190
  1. package shadowsocks_test
  2. import (
  3. "testing"
  4. "v2ray.com/core/common"
  5. "v2ray.com/core/common/buf"
  6. "v2ray.com/core/common/net"
  7. "v2ray.com/core/common/protocol"
  8. "v2ray.com/core/common/serial"
  9. . "v2ray.com/core/proxy/shadowsocks"
  10. . "v2ray.com/ext/assert"
  11. )
  12. func toAccount(a *Account) protocol.Account {
  13. account, err := a.AsAccount()
  14. common.Must(err)
  15. return account
  16. }
  17. func TestUDPEncoding(t *testing.T) {
  18. assert := With(t)
  19. request := &protocol.RequestHeader{
  20. Version: Version,
  21. Command: protocol.RequestCommandUDP,
  22. Address: net.LocalHostIP,
  23. Port: 1234,
  24. User: &protocol.MemoryUser{
  25. Email: "love@v2ray.com",
  26. Account: toAccount(&Account{
  27. Password: "shadowsocks-password",
  28. CipherType: CipherType_AES_128_CFB,
  29. Ota: Account_Disabled,
  30. }),
  31. },
  32. }
  33. data := buf.New()
  34. data.AppendSupplier(serial.WriteString("test string"))
  35. encodedData, err := EncodeUDPPacket(request, data.Bytes())
  36. assert(err, IsNil)
  37. decodedRequest, decodedData, err := DecodeUDPPacket(request.User, encodedData)
  38. assert(err, IsNil)
  39. assert(decodedData.Bytes(), Equals, data.Bytes())
  40. assert(decodedRequest.Address, Equals, request.Address)
  41. assert(decodedRequest.Port, Equals, request.Port)
  42. assert(decodedRequest.Command, Equals, request.Command)
  43. }
  44. func TestTCPRequest(t *testing.T) {
  45. assert := With(t)
  46. cases := []struct {
  47. request *protocol.RequestHeader
  48. payload []byte
  49. }{
  50. {
  51. request: &protocol.RequestHeader{
  52. Version: Version,
  53. Command: protocol.RequestCommandTCP,
  54. Address: net.LocalHostIP,
  55. Option: RequestOptionOneTimeAuth,
  56. Port: 1234,
  57. User: &protocol.MemoryUser{
  58. Email: "love@v2ray.com",
  59. Account: toAccount(&Account{
  60. Password: "tcp-password",
  61. CipherType: CipherType_CHACHA20,
  62. }),
  63. },
  64. },
  65. payload: []byte("test string"),
  66. },
  67. {
  68. request: &protocol.RequestHeader{
  69. Version: Version,
  70. Command: protocol.RequestCommandTCP,
  71. Address: net.LocalHostIPv6,
  72. Option: RequestOptionOneTimeAuth,
  73. Port: 1234,
  74. User: &protocol.MemoryUser{
  75. Email: "love@v2ray.com",
  76. Account: toAccount(&Account{
  77. Password: "password",
  78. CipherType: CipherType_AES_256_CFB,
  79. }),
  80. },
  81. },
  82. payload: []byte("test string"),
  83. },
  84. {
  85. request: &protocol.RequestHeader{
  86. Version: Version,
  87. Command: protocol.RequestCommandTCP,
  88. Address: net.DomainAddress("v2ray.com"),
  89. Option: RequestOptionOneTimeAuth,
  90. Port: 1234,
  91. User: &protocol.MemoryUser{
  92. Email: "love@v2ray.com",
  93. Account: toAccount(&Account{
  94. Password: "password",
  95. CipherType: CipherType_CHACHA20_IETF,
  96. }),
  97. },
  98. },
  99. payload: []byte("test string"),
  100. },
  101. }
  102. runTest := func(request *protocol.RequestHeader, payload []byte) {
  103. data := buf.New()
  104. common.Must2(data.Write(payload))
  105. cache := buf.New()
  106. defer cache.Release()
  107. writer, err := WriteTCPRequest(request, cache)
  108. assert(err, IsNil)
  109. assert(writer.WriteMultiBuffer(buf.NewMultiBufferValue(data)), IsNil)
  110. decodedRequest, reader, err := ReadTCPSession(request.User, cache)
  111. assert(err, IsNil)
  112. assert(decodedRequest.Address, Equals, request.Address)
  113. assert(decodedRequest.Port, Equals, request.Port)
  114. assert(decodedRequest.Command, Equals, request.Command)
  115. decodedData, err := reader.ReadMultiBuffer()
  116. assert(err, IsNil)
  117. assert(decodedData[0].String(), Equals, string(payload))
  118. }
  119. for _, test := range cases {
  120. runTest(test.request, test.payload)
  121. }
  122. }
  123. func TestUDPReaderWriter(t *testing.T) {
  124. assert := With(t)
  125. user := &protocol.MemoryUser{
  126. Account: toAccount(&Account{
  127. Password: "test-password",
  128. CipherType: CipherType_CHACHA20_IETF,
  129. }),
  130. }
  131. cache := buf.New()
  132. defer cache.Release()
  133. writer := &buf.SequentialWriter{Writer: &UDPWriter{
  134. Writer: cache,
  135. Request: &protocol.RequestHeader{
  136. Version: Version,
  137. Address: net.DomainAddress("v2ray.com"),
  138. Port: 123,
  139. User: user,
  140. Option: RequestOptionOneTimeAuth,
  141. },
  142. }}
  143. reader := &UDPReader{
  144. Reader: cache,
  145. User: user,
  146. }
  147. {
  148. b := buf.New()
  149. b.AppendSupplier(serial.WriteString("test payload"))
  150. err := writer.WriteMultiBuffer(buf.NewMultiBufferValue(b))
  151. assert(err, IsNil)
  152. payload, err := reader.ReadMultiBuffer()
  153. assert(err, IsNil)
  154. assert(payload[0].String(), Equals, "test payload")
  155. }
  156. {
  157. b := buf.New()
  158. b.AppendSupplier(serial.WriteString("test payload 2"))
  159. err := writer.WriteMultiBuffer(buf.NewMultiBufferValue(b))
  160. assert(err, IsNil)
  161. payload, err := reader.ReadMultiBuffer()
  162. assert(err, IsNil)
  163. assert(payload[0].String(), Equals, "test payload 2")
  164. }
  165. }