| 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)
 
- }
 
 
  |