mirror of
https://github.com/v2fly/v2ray-core.git
synced 2025-01-02 15:36:41 -05:00
socks4 tests
This commit is contained in:
parent
ed3033e785
commit
5b89c6aada
@ -73,12 +73,12 @@ func (s *ServerSession) Handshake(reader io.Reader, writer io.Writer) (*protocol
|
|||||||
request.Address = address
|
request.Address = address
|
||||||
request.Port = port
|
request.Port = port
|
||||||
request.Version = socks4Version
|
request.Version = socks4Version
|
||||||
if err := writeSocks4Response(writer, socks4RequestGranted, address, port); err != nil {
|
if err := writeSocks4Response(writer, socks4RequestGranted, v2net.AnyIP, v2net.Port(0)); err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
return request, nil
|
return request, nil
|
||||||
default:
|
default:
|
||||||
writeSocks4Response(writer, socks4RequestRejected, address, port)
|
writeSocks4Response(writer, socks4RequestRejected, v2net.AnyIP, v2net.Port(0))
|
||||||
return nil, errors.New("Socks|Server: Unsupported command: ", buffer.Byte(1))
|
return nil, errors.New("Socks|Server: Unsupported command: ", buffer.Byte(1))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -5,6 +5,7 @@ import (
|
|||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
xproxy "golang.org/x/net/proxy"
|
xproxy "golang.org/x/net/proxy"
|
||||||
|
socks4 "h12.me/socks"
|
||||||
"v2ray.com/core"
|
"v2ray.com/core"
|
||||||
v2net "v2ray.com/core/common/net"
|
v2net "v2ray.com/core/common/net"
|
||||||
"v2ray.com/core/common/protocol"
|
"v2ray.com/core/common/protocol"
|
||||||
@ -203,7 +204,7 @@ func TestSocksBridageUDP(t *testing.T) {
|
|||||||
CloseAllServers()
|
CloseAllServers()
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestSocks5conformance(t *testing.T) {
|
func TestSocksConformance(t *testing.T) {
|
||||||
assert := assert.On(t)
|
assert := assert.On(t)
|
||||||
|
|
||||||
tcpServer := tcp.Server{
|
tcpServer := tcp.Server{
|
||||||
@ -287,5 +288,39 @@ func TestSocks5conformance(t *testing.T) {
|
|||||||
assert.Error(conn.Close()).IsNil()
|
assert.Error(conn.Close()).IsNil()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
dialer := socks4.DialSocksProxy(socks4.SOCKS4, v2net.TCPDestination(v2net.LocalHostIP, noAuthPort).NetAddr())
|
||||||
|
conn, err := dialer("tcp", dest.NetAddr())
|
||||||
|
assert.Error(err).IsNil()
|
||||||
|
|
||||||
|
payload := "test payload"
|
||||||
|
nBytes, err := conn.Write([]byte(payload))
|
||||||
|
assert.Error(err).IsNil()
|
||||||
|
assert.Int(nBytes).Equals(len(payload))
|
||||||
|
|
||||||
|
response := make([]byte, 1024)
|
||||||
|
nBytes, err = conn.Read(response)
|
||||||
|
assert.Error(err).IsNil()
|
||||||
|
assert.Bytes(response[:nBytes]).Equals(xor([]byte(payload)))
|
||||||
|
assert.Error(conn.Close()).IsNil()
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
dialer := socks4.DialSocksProxy(socks4.SOCKS4A, v2net.TCPDestination(v2net.LocalHostIP, noAuthPort).NetAddr())
|
||||||
|
conn, err := dialer("tcp", v2net.TCPDestination(v2net.LocalHostDomain, tcpServer.Port).NetAddr())
|
||||||
|
assert.Error(err).IsNil()
|
||||||
|
|
||||||
|
payload := "test payload"
|
||||||
|
nBytes, err := conn.Write([]byte(payload))
|
||||||
|
assert.Error(err).IsNil()
|
||||||
|
assert.Int(nBytes).Equals(len(payload))
|
||||||
|
|
||||||
|
response := make([]byte, 1024)
|
||||||
|
nBytes, err = conn.Read(response)
|
||||||
|
assert.Error(err).IsNil()
|
||||||
|
assert.Bytes(response[:nBytes]).Equals(xor([]byte(payload)))
|
||||||
|
assert.Error(conn.Close()).IsNil()
|
||||||
|
}
|
||||||
|
|
||||||
CloseAllServers()
|
CloseAllServers()
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user