2015-09-11 08:12:09 -04:00
|
|
|
package socks
|
|
|
|
|
|
|
|
import (
|
2015-09-19 09:35:20 -04:00
|
|
|
"bytes"
|
|
|
|
"io/ioutil"
|
|
|
|
"net"
|
2015-09-11 08:12:09 -04:00
|
|
|
"testing"
|
|
|
|
|
2015-09-19 09:35:20 -04:00
|
|
|
"golang.org/x/net/proxy"
|
|
|
|
|
2015-10-14 08:56:11 -04:00
|
|
|
"github.com/v2ray/v2ray-core/app/point"
|
|
|
|
v2proxy "github.com/v2ray/v2ray-core/proxy"
|
2015-10-06 17:11:08 -04:00
|
|
|
"github.com/v2ray/v2ray-core/proxy/socks/config/json"
|
2015-09-19 09:35:20 -04:00
|
|
|
"github.com/v2ray/v2ray-core/testing/mocks"
|
|
|
|
"github.com/v2ray/v2ray-core/testing/unit"
|
2015-09-11 08:12:09 -04:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestSocksTcpConnect(t *testing.T) {
|
2015-09-19 09:35:20 -04:00
|
|
|
assert := unit.Assert(t)
|
|
|
|
port := uint16(12385)
|
|
|
|
|
|
|
|
och := &mocks.OutboundConnectionHandler{
|
|
|
|
Data2Send: bytes.NewBuffer(make([]byte, 0, 1024)),
|
|
|
|
Data2Return: []byte("The data to be returned to socks server."),
|
|
|
|
}
|
|
|
|
|
2015-10-14 08:56:11 -04:00
|
|
|
v2proxy.RegisterOutboundConnectionHandlerFactory("mock_och", och)
|
2015-09-19 09:35:20 -04:00
|
|
|
|
|
|
|
config := mocks.Config{
|
|
|
|
PortValue: port,
|
|
|
|
InboundConfigValue: &mocks.ConnectionConfig{
|
|
|
|
ProtocolValue: "socks",
|
2015-10-06 17:11:08 -04:00
|
|
|
SettingsValue: &json.SocksConfig{
|
|
|
|
AuthMethod: "noauth",
|
|
|
|
},
|
2015-09-19 09:35:20 -04:00
|
|
|
},
|
|
|
|
OutboundConfigValue: &mocks.ConnectionConfig{
|
|
|
|
ProtocolValue: "mock_och",
|
2015-10-06 17:11:08 -04:00
|
|
|
SettingsValue: nil,
|
2015-09-19 09:35:20 -04:00
|
|
|
},
|
|
|
|
}
|
|
|
|
|
2015-10-14 08:56:11 -04:00
|
|
|
point, err := point.NewPoint(&config)
|
2015-09-19 09:35:20 -04:00
|
|
|
assert.Error(err).IsNil()
|
|
|
|
|
|
|
|
err = point.Start()
|
|
|
|
assert.Error(err).IsNil()
|
|
|
|
|
|
|
|
socks5Client, err := proxy.SOCKS5("tcp", "127.0.0.1:12385", nil, proxy.Direct)
|
|
|
|
assert.Error(err).IsNil()
|
|
|
|
|
2015-09-19 09:42:46 -04:00
|
|
|
targetServer := "google.com:80"
|
|
|
|
conn, err := socks5Client.Dial("tcp", targetServer)
|
2015-09-19 09:35:20 -04:00
|
|
|
assert.Error(err).IsNil()
|
|
|
|
|
|
|
|
data2Send := "The data to be sent to remote server."
|
|
|
|
conn.Write([]byte(data2Send))
|
|
|
|
if tcpConn, ok := conn.(*net.TCPConn); ok {
|
|
|
|
tcpConn.CloseWrite()
|
|
|
|
}
|
|
|
|
|
|
|
|
dataReturned, err := ioutil.ReadAll(conn)
|
|
|
|
assert.Error(err).IsNil()
|
|
|
|
conn.Close()
|
|
|
|
|
|
|
|
assert.Bytes([]byte(data2Send)).Equals(och.Data2Send.Bytes())
|
|
|
|
assert.Bytes(dataReturned).Equals(och.Data2Return)
|
2015-09-20 10:03:12 -04:00
|
|
|
assert.String(targetServer).Equals(och.Destination.Address().String())
|
2015-09-19 09:42:46 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
func TestSocksTcpConnectWithUserPass(t *testing.T) {
|
|
|
|
assert := unit.Assert(t)
|
|
|
|
port := uint16(12386)
|
|
|
|
|
|
|
|
och := &mocks.OutboundConnectionHandler{
|
|
|
|
Data2Send: bytes.NewBuffer(make([]byte, 0, 1024)),
|
|
|
|
Data2Return: []byte("The data to be returned to socks server."),
|
|
|
|
}
|
|
|
|
|
2015-10-14 08:56:11 -04:00
|
|
|
v2proxy.RegisterOutboundConnectionHandlerFactory("mock_och", och)
|
2015-09-19 09:42:46 -04:00
|
|
|
|
|
|
|
config := mocks.Config{
|
|
|
|
PortValue: port,
|
|
|
|
InboundConfigValue: &mocks.ConnectionConfig{
|
|
|
|
ProtocolValue: "socks",
|
2015-10-06 17:11:08 -04:00
|
|
|
SettingsValue: &json.SocksConfig{
|
2015-10-10 16:31:25 -04:00
|
|
|
AuthMethod: "password",
|
2015-10-10 09:51:35 -04:00
|
|
|
Accounts: []json.SocksAccount{
|
|
|
|
json.SocksAccount{
|
|
|
|
Username: "userx",
|
|
|
|
Password: "passy",
|
|
|
|
},
|
|
|
|
},
|
2015-10-06 17:11:08 -04:00
|
|
|
},
|
2015-09-19 09:42:46 -04:00
|
|
|
},
|
|
|
|
OutboundConfigValue: &mocks.ConnectionConfig{
|
|
|
|
ProtocolValue: "mock_och",
|
2015-10-06 17:11:08 -04:00
|
|
|
SettingsValue: nil,
|
2015-09-19 09:42:46 -04:00
|
|
|
},
|
|
|
|
}
|
|
|
|
|
2015-10-14 08:56:11 -04:00
|
|
|
point, err := point.NewPoint(&config)
|
2015-09-19 09:42:46 -04:00
|
|
|
assert.Error(err).IsNil()
|
|
|
|
|
|
|
|
err = point.Start()
|
|
|
|
assert.Error(err).IsNil()
|
|
|
|
|
|
|
|
socks5Client, err := proxy.SOCKS5("tcp", "127.0.0.1:12386", &proxy.Auth{"userx", "passy"}, proxy.Direct)
|
|
|
|
assert.Error(err).IsNil()
|
|
|
|
|
|
|
|
targetServer := "1.2.3.4:443"
|
|
|
|
conn, err := socks5Client.Dial("tcp", targetServer)
|
|
|
|
assert.Error(err).IsNil()
|
|
|
|
|
|
|
|
data2Send := "The data to be sent to remote server."
|
|
|
|
conn.Write([]byte(data2Send))
|
|
|
|
if tcpConn, ok := conn.(*net.TCPConn); ok {
|
|
|
|
tcpConn.CloseWrite()
|
|
|
|
}
|
|
|
|
|
|
|
|
dataReturned, err := ioutil.ReadAll(conn)
|
|
|
|
assert.Error(err).IsNil()
|
|
|
|
conn.Close()
|
|
|
|
|
|
|
|
assert.Bytes([]byte(data2Send)).Equals(och.Data2Send.Bytes())
|
|
|
|
assert.Bytes(dataReturned).Equals(och.Data2Return)
|
2015-09-20 10:03:12 -04:00
|
|
|
assert.String(targetServer).Equals(och.Destination.Address().String())
|
2015-09-11 08:12:09 -04:00
|
|
|
}
|
2015-10-03 18:44:27 -04:00
|
|
|
|
2015-10-13 15:29:27 -04:00
|
|
|
func TestSocksTcpConnectWithWrongUserPass(t *testing.T) {
|
|
|
|
assert := unit.Assert(t)
|
|
|
|
port := uint16(12389)
|
|
|
|
|
|
|
|
och := &mocks.OutboundConnectionHandler{
|
|
|
|
Data2Send: bytes.NewBuffer(make([]byte, 0, 1024)),
|
|
|
|
Data2Return: []byte("The data to be returned to socks server."),
|
|
|
|
}
|
|
|
|
|
2015-10-14 08:56:11 -04:00
|
|
|
v2proxy.RegisterOutboundConnectionHandlerFactory("mock_och", och)
|
2015-10-13 15:29:27 -04:00
|
|
|
|
|
|
|
config := mocks.Config{
|
|
|
|
PortValue: port,
|
|
|
|
InboundConfigValue: &mocks.ConnectionConfig{
|
|
|
|
ProtocolValue: "socks",
|
|
|
|
SettingsValue: &json.SocksConfig{
|
|
|
|
AuthMethod: "password",
|
|
|
|
Accounts: []json.SocksAccount{
|
|
|
|
json.SocksAccount{
|
|
|
|
Username: "userx",
|
|
|
|
Password: "passy",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
OutboundConfigValue: &mocks.ConnectionConfig{
|
|
|
|
ProtocolValue: "mock_och",
|
|
|
|
SettingsValue: nil,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
2015-10-14 08:56:11 -04:00
|
|
|
point, err := point.NewPoint(&config)
|
2015-10-13 15:29:27 -04:00
|
|
|
assert.Error(err).IsNil()
|
|
|
|
|
|
|
|
err = point.Start()
|
|
|
|
assert.Error(err).IsNil()
|
|
|
|
|
|
|
|
socks5Client, err := proxy.SOCKS5("tcp", "127.0.0.1:12389", &proxy.Auth{"userx", "passz"}, proxy.Direct)
|
|
|
|
assert.Error(err).IsNil()
|
|
|
|
|
|
|
|
targetServer := "1.2.3.4:443"
|
|
|
|
_, err = socks5Client.Dial("tcp", targetServer)
|
|
|
|
assert.Error(err).IsNotNil()
|
|
|
|
}
|
|
|
|
|
2015-10-13 15:55:12 -04:00
|
|
|
func TestSocksTcpConnectWithWrongAuthMethod(t *testing.T) {
|
|
|
|
assert := unit.Assert(t)
|
|
|
|
port := uint16(38405)
|
|
|
|
|
|
|
|
och := &mocks.OutboundConnectionHandler{
|
|
|
|
Data2Send: bytes.NewBuffer(make([]byte, 0, 1024)),
|
|
|
|
Data2Return: []byte("The data to be returned to socks server."),
|
|
|
|
}
|
|
|
|
|
2015-10-14 08:56:11 -04:00
|
|
|
v2proxy.RegisterOutboundConnectionHandlerFactory("mock_och", och)
|
2015-10-13 15:55:12 -04:00
|
|
|
|
|
|
|
config := mocks.Config{
|
|
|
|
PortValue: port,
|
|
|
|
InboundConfigValue: &mocks.ConnectionConfig{
|
|
|
|
ProtocolValue: "socks",
|
|
|
|
SettingsValue: &json.SocksConfig{
|
|
|
|
AuthMethod: "password",
|
|
|
|
Accounts: []json.SocksAccount{
|
|
|
|
json.SocksAccount{
|
|
|
|
Username: "userx",
|
|
|
|
Password: "passy",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
OutboundConfigValue: &mocks.ConnectionConfig{
|
|
|
|
ProtocolValue: "mock_och",
|
|
|
|
SettingsValue: nil,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
2015-10-14 08:56:11 -04:00
|
|
|
point, err := point.NewPoint(&config)
|
2015-10-13 15:55:12 -04:00
|
|
|
assert.Error(err).IsNil()
|
|
|
|
|
|
|
|
err = point.Start()
|
|
|
|
assert.Error(err).IsNil()
|
|
|
|
|
|
|
|
socks5Client, err := proxy.SOCKS5("tcp", "127.0.0.1:38405", nil, proxy.Direct)
|
|
|
|
assert.Error(err).IsNil()
|
|
|
|
|
|
|
|
targetServer := "1.2.3.4:443"
|
|
|
|
_, err = socks5Client.Dial("tcp", targetServer)
|
|
|
|
assert.Error(err).IsNotNil()
|
|
|
|
}
|
|
|
|
|
2015-10-03 18:44:27 -04:00
|
|
|
func TestSocksUdpSend(t *testing.T) {
|
|
|
|
assert := unit.Assert(t)
|
|
|
|
port := uint16(12372)
|
|
|
|
|
|
|
|
och := &mocks.OutboundConnectionHandler{
|
|
|
|
Data2Send: bytes.NewBuffer(make([]byte, 0, 1024)),
|
|
|
|
Data2Return: []byte("The data to be returned to socks server."),
|
|
|
|
}
|
|
|
|
|
2015-10-14 08:56:11 -04:00
|
|
|
v2proxy.RegisterOutboundConnectionHandlerFactory("mock_och", och)
|
2015-10-03 18:44:27 -04:00
|
|
|
|
|
|
|
config := mocks.Config{
|
|
|
|
PortValue: port,
|
|
|
|
InboundConfigValue: &mocks.ConnectionConfig{
|
|
|
|
ProtocolValue: "socks",
|
2015-10-06 17:11:08 -04:00
|
|
|
SettingsValue: &json.SocksConfig{
|
|
|
|
AuthMethod: "noauth",
|
|
|
|
UDPEnabled: true,
|
|
|
|
},
|
2015-10-03 18:44:27 -04:00
|
|
|
},
|
|
|
|
OutboundConfigValue: &mocks.ConnectionConfig{
|
|
|
|
ProtocolValue: "mock_och",
|
2015-10-06 17:11:08 -04:00
|
|
|
SettingsValue: nil,
|
2015-10-03 18:44:27 -04:00
|
|
|
},
|
|
|
|
}
|
|
|
|
|
2015-10-14 08:56:11 -04:00
|
|
|
point, err := point.NewPoint(&config)
|
2015-10-03 18:44:27 -04:00
|
|
|
assert.Error(err).IsNil()
|
|
|
|
|
|
|
|
err = point.Start()
|
|
|
|
assert.Error(err).IsNil()
|
|
|
|
|
|
|
|
conn, err := net.DialUDP("udp", nil, &net.UDPAddr{
|
|
|
|
IP: []byte{127, 0, 0, 1},
|
|
|
|
Port: int(port),
|
|
|
|
Zone: "",
|
|
|
|
})
|
|
|
|
|
|
|
|
assert.Error(err).IsNil()
|
|
|
|
|
|
|
|
data2Send := []byte("Fake DNS request")
|
|
|
|
|
|
|
|
buffer := make([]byte, 0, 1024)
|
|
|
|
buffer = append(buffer, 0, 0, 0)
|
|
|
|
buffer = append(buffer, 1, 8, 8, 4, 4, 0, 53)
|
|
|
|
buffer = append(buffer, data2Send...)
|
|
|
|
|
|
|
|
conn.Write(buffer)
|
|
|
|
|
|
|
|
response := make([]byte, 1024)
|
|
|
|
nBytes, err := conn.Read(response)
|
|
|
|
|
|
|
|
assert.Error(err).IsNil()
|
2015-10-05 11:03:26 -04:00
|
|
|
assert.Bytes(response[10:nBytes]).Equals(och.Data2Return)
|
2015-10-03 18:44:27 -04:00
|
|
|
assert.Bytes(data2Send).Equals(och.Data2Send.Bytes())
|
|
|
|
assert.String(och.Destination.String()).Equals("udp:8.8.4.4:53")
|
|
|
|
}
|