| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177 |
- package protocol
- import (
- "bytes"
- "io"
- "testing"
- "v2ray.com/core/common/buf"
- "v2ray.com/core/common/crypto"
- v2net "v2ray.com/core/common/net"
- "v2ray.com/core/proxy"
- "v2ray.com/core/testing/assert"
- )
- func TestHasAuthenticationMethod(t *testing.T) {
- assert := assert.On(t)
- request := Socks5AuthenticationRequest{
- version: socksVersion,
- nMethods: byte(0x02),
- authMethods: [256]byte{0x01, 0x02},
- }
- assert.Bool(request.HasAuthMethod(byte(0x01))).IsTrue()
- request.authMethods[0] = byte(0x03)
- assert.Bool(request.HasAuthMethod(byte(0x01))).IsFalse()
- }
- func TestAuthenticationRequestRead(t *testing.T) {
- assert := assert.On(t)
- buffer := buf.New()
- buffer.AppendBytes(
- 0x05, // version
- 0x01, // nMethods
- 0x02, // methods
- )
- request, _, err := ReadAuthentication(buffer)
- assert.Error(err).IsNil()
- assert.Byte(request.version).Equals(0x05)
- assert.Byte(request.nMethods).Equals(0x01)
- assert.Byte(request.authMethods[0]).Equals(0x02)
- }
- func TestAuthenticationResponseWrite(t *testing.T) {
- assert := assert.On(t)
- response := NewAuthenticationResponse(byte(0x05))
- buffer := bytes.NewBuffer(make([]byte, 0, 10))
- WriteAuthentication(buffer, response)
- assert.Bytes(buffer.Bytes()).Equals([]byte{socksVersion, byte(0x05)})
- }
- func TestRequestRead(t *testing.T) {
- assert := assert.On(t)
- rawRequest := []byte{
- 0x05, // version
- 0x01, // cmd connect
- 0x00, // reserved
- 0x01, // ipv4 type
- 0x72, 0x72, 0x72, 0x72, // 114.114.114.114
- 0x00, 0x35, // port 53
- }
- request, err := ReadRequest(bytes.NewReader(rawRequest))
- assert.Error(err).IsNil()
- assert.Byte(request.Version).Equals(0x05)
- assert.Byte(request.Command).Equals(0x01)
- assert.Byte(request.AddrType).Equals(0x01)
- assert.Bytes(request.IPv4[:]).Equals([]byte{0x72, 0x72, 0x72, 0x72})
- assert.Port(request.Port).Equals(v2net.Port(53))
- }
- func TestResponseWrite(t *testing.T) {
- assert := assert.On(t)
- response := Socks5Response{
- socksVersion,
- ErrorSuccess,
- AddrTypeIPv4,
- [4]byte{0x72, 0x72, 0x72, 0x72},
- "",
- [16]byte{},
- v2net.Port(53),
- }
- buffer := buf.NewLocal(2048)
- defer buffer.Release()
- response.Write(buffer)
- expectedBytes := []byte{
- socksVersion,
- ErrorSuccess,
- byte(0x00),
- AddrTypeIPv4,
- 0x72, 0x72, 0x72, 0x72,
- byte(0x00), byte(0x035),
- }
- assert.Bytes(buffer.Bytes()).Equals(expectedBytes)
- }
- func TestSetIPv6(t *testing.T) {
- assert := assert.On(t)
- response := NewSocks5Response()
- response.SetIPv6([]byte{0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15})
- buffer := buf.NewLocal(2048)
- defer buffer.Release()
- response.Write(buffer)
- assert.Bytes(buffer.Bytes()).Equals([]byte{
- socksVersion, 0, 0, AddrTypeIPv6, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 0, 0})
- }
- func TestSetDomain(t *testing.T) {
- assert := assert.On(t)
- response := NewSocks5Response()
- response.SetDomain("v2ray.com")
- buffer := buf.NewLocal(2048)
- defer buffer.Release()
- response.Write(buffer)
- assert.Bytes(buffer.Bytes()).Equals([]byte{
- socksVersion, 0, 0, AddrTypeDomain, 9, 118, 50, 114, 97, 121, 46, 99, 111, 109, 0, 0})
- }
- func TestEmptyAuthRequest(t *testing.T) {
- assert := assert.On(t)
- _, _, err := ReadAuthentication(buf.New())
- assert.Error(err).Equals(io.EOF)
- }
- func TestSingleByteAuthRequest(t *testing.T) {
- assert := assert.On(t)
- _, _, err := ReadAuthentication(bytes.NewReader(make([]byte, 1)))
- assert.Error(err).IsNotNil()
- }
- func TestZeroAuthenticationMethod(t *testing.T) {
- assert := assert.On(t)
- buffer := buf.New()
- buffer.AppendBytes(5, 0)
- _, _, err := ReadAuthentication(buffer)
- assert.Error(err).Equals(crypto.ErrAuthenticationFailed)
- }
- func TestWrongProtocolVersion(t *testing.T) {
- assert := assert.On(t)
- buffer := buf.New()
- buffer.AppendBytes(6, 1, 0)
- _, _, err := ReadAuthentication(buffer)
- assert.Error(err).Equals(proxy.ErrInvalidProtocolVersion)
- }
- func TestEmptyRequest(t *testing.T) {
- assert := assert.On(t)
- _, err := ReadRequest(buf.New())
- assert.Error(err).Equals(io.EOF)
- }
- func TestIPv6Request(t *testing.T) {
- assert := assert.On(t)
- b := buf.New()
- b.AppendBytes(5, 1, 0, 4, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 0, 8)
- request, err := ReadRequest(b)
- assert.Error(err).IsNil()
- assert.Byte(request.Command).Equals(1)
- assert.Bytes(request.IPv6[:]).Equals([]byte{1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6})
- assert.Port(request.Port).Equals(8)
- }
|