socks_test.go 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177
  1. package protocol
  2. import (
  3. "bytes"
  4. "io"
  5. "testing"
  6. "v2ray.com/core/common/buf"
  7. "v2ray.com/core/common/crypto"
  8. v2net "v2ray.com/core/common/net"
  9. "v2ray.com/core/proxy"
  10. "v2ray.com/core/testing/assert"
  11. )
  12. func TestHasAuthenticationMethod(t *testing.T) {
  13. assert := assert.On(t)
  14. request := Socks5AuthenticationRequest{
  15. version: socksVersion,
  16. nMethods: byte(0x02),
  17. authMethods: [256]byte{0x01, 0x02},
  18. }
  19. assert.Bool(request.HasAuthMethod(byte(0x01))).IsTrue()
  20. request.authMethods[0] = byte(0x03)
  21. assert.Bool(request.HasAuthMethod(byte(0x01))).IsFalse()
  22. }
  23. func TestAuthenticationRequestRead(t *testing.T) {
  24. assert := assert.On(t)
  25. buffer := buf.New()
  26. buffer.AppendBytes(
  27. 0x05, // version
  28. 0x01, // nMethods
  29. 0x02, // methods
  30. )
  31. request, _, err := ReadAuthentication(buffer)
  32. assert.Error(err).IsNil()
  33. assert.Byte(request.version).Equals(0x05)
  34. assert.Byte(request.nMethods).Equals(0x01)
  35. assert.Byte(request.authMethods[0]).Equals(0x02)
  36. }
  37. func TestAuthenticationResponseWrite(t *testing.T) {
  38. assert := assert.On(t)
  39. response := NewAuthenticationResponse(byte(0x05))
  40. buffer := bytes.NewBuffer(make([]byte, 0, 10))
  41. WriteAuthentication(buffer, response)
  42. assert.Bytes(buffer.Bytes()).Equals([]byte{socksVersion, byte(0x05)})
  43. }
  44. func TestRequestRead(t *testing.T) {
  45. assert := assert.On(t)
  46. rawRequest := []byte{
  47. 0x05, // version
  48. 0x01, // cmd connect
  49. 0x00, // reserved
  50. 0x01, // ipv4 type
  51. 0x72, 0x72, 0x72, 0x72, // 114.114.114.114
  52. 0x00, 0x35, // port 53
  53. }
  54. request, err := ReadRequest(bytes.NewReader(rawRequest))
  55. assert.Error(err).IsNil()
  56. assert.Byte(request.Version).Equals(0x05)
  57. assert.Byte(request.Command).Equals(0x01)
  58. assert.Byte(request.AddrType).Equals(0x01)
  59. assert.Bytes(request.IPv4[:]).Equals([]byte{0x72, 0x72, 0x72, 0x72})
  60. assert.Port(request.Port).Equals(v2net.Port(53))
  61. }
  62. func TestResponseWrite(t *testing.T) {
  63. assert := assert.On(t)
  64. response := Socks5Response{
  65. socksVersion,
  66. ErrorSuccess,
  67. AddrTypeIPv4,
  68. [4]byte{0x72, 0x72, 0x72, 0x72},
  69. "",
  70. [16]byte{},
  71. v2net.Port(53),
  72. }
  73. buffer := buf.NewLocal(2048)
  74. defer buffer.Release()
  75. response.Write(buffer)
  76. expectedBytes := []byte{
  77. socksVersion,
  78. ErrorSuccess,
  79. byte(0x00),
  80. AddrTypeIPv4,
  81. 0x72, 0x72, 0x72, 0x72,
  82. byte(0x00), byte(0x035),
  83. }
  84. assert.Bytes(buffer.Bytes()).Equals(expectedBytes)
  85. }
  86. func TestSetIPv6(t *testing.T) {
  87. assert := assert.On(t)
  88. response := NewSocks5Response()
  89. response.SetIPv6([]byte{0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15})
  90. buffer := buf.NewLocal(2048)
  91. defer buffer.Release()
  92. response.Write(buffer)
  93. assert.Bytes(buffer.Bytes()).Equals([]byte{
  94. socksVersion, 0, 0, AddrTypeIPv6, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 0, 0})
  95. }
  96. func TestSetDomain(t *testing.T) {
  97. assert := assert.On(t)
  98. response := NewSocks5Response()
  99. response.SetDomain("v2ray.com")
  100. buffer := buf.NewLocal(2048)
  101. defer buffer.Release()
  102. response.Write(buffer)
  103. assert.Bytes(buffer.Bytes()).Equals([]byte{
  104. socksVersion, 0, 0, AddrTypeDomain, 9, 118, 50, 114, 97, 121, 46, 99, 111, 109, 0, 0})
  105. }
  106. func TestEmptyAuthRequest(t *testing.T) {
  107. assert := assert.On(t)
  108. _, _, err := ReadAuthentication(buf.New())
  109. assert.Error(err).Equals(io.EOF)
  110. }
  111. func TestSingleByteAuthRequest(t *testing.T) {
  112. assert := assert.On(t)
  113. _, _, err := ReadAuthentication(bytes.NewReader(make([]byte, 1)))
  114. assert.Error(err).IsNotNil()
  115. }
  116. func TestZeroAuthenticationMethod(t *testing.T) {
  117. assert := assert.On(t)
  118. buffer := buf.New()
  119. buffer.AppendBytes(5, 0)
  120. _, _, err := ReadAuthentication(buffer)
  121. assert.Error(err).Equals(crypto.ErrAuthenticationFailed)
  122. }
  123. func TestWrongProtocolVersion(t *testing.T) {
  124. assert := assert.On(t)
  125. buffer := buf.New()
  126. buffer.AppendBytes(6, 1, 0)
  127. _, _, err := ReadAuthentication(buffer)
  128. assert.Error(err).Equals(proxy.ErrInvalidProtocolVersion)
  129. }
  130. func TestEmptyRequest(t *testing.T) {
  131. assert := assert.On(t)
  132. _, err := ReadRequest(buf.New())
  133. assert.Error(err).Equals(io.EOF)
  134. }
  135. func TestIPv6Request(t *testing.T) {
  136. assert := assert.On(t)
  137. b := buf.New()
  138. b.AppendBytes(5, 1, 0, 4, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 0, 8)
  139. request, err := ReadRequest(b)
  140. assert.Error(err).IsNil()
  141. assert.Byte(request.Command).Equals(1)
  142. assert.Bytes(request.IPv6[:]).Equals([]byte{1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6})
  143. assert.Port(request.Port).Equals(8)
  144. }