1
0
mirror of https://github.com/v2fly/v2ray-core.git synced 2024-09-28 23:06:14 -04:00

more test cases for freedom

This commit is contained in:
Darien Raymond 2016-02-04 10:11:11 +00:00
parent 6e8b65551c
commit b18693a9c4

View File

@ -1,27 +1,22 @@
package freedom package freedom_test
import ( import (
"fmt"
"net"
"testing" "testing"
"golang.org/x/net/proxy" "github.com/v2ray/v2ray-core/common/alloc"
v2net "github.com/v2ray/v2ray-core/common/net"
v2io "github.com/v2ray/v2ray-core/common/io"
v2nettesting "github.com/v2ray/v2ray-core/common/net/testing" v2nettesting "github.com/v2ray/v2ray-core/common/net/testing"
_ "github.com/v2ray/v2ray-core/proxy/socks" . "github.com/v2ray/v2ray-core/proxy/freedom"
"github.com/v2ray/v2ray-core/shell/point"
v2testing "github.com/v2ray/v2ray-core/testing" v2testing "github.com/v2ray/v2ray-core/testing"
"github.com/v2ray/v2ray-core/testing/assert" "github.com/v2ray/v2ray-core/testing/assert"
"github.com/v2ray/v2ray-core/testing/servers/tcp" "github.com/v2ray/v2ray-core/testing/servers/tcp"
"github.com/v2ray/v2ray-core/transport/ray"
) )
func TestSocksTcpConnect(t *testing.T) { func TestSinglePacket(t *testing.T) {
v2testing.Current(t) v2testing.Current(t)
port := v2nettesting.PickPort() port := v2nettesting.PickPort()
data2Send := "Data to be sent to remote"
tcpServer := &tcp.Server{ tcpServer := &tcp.Server{
Port: port, Port: port,
MsgProcessor: func(data []byte) []byte { MsgProcessor: func(data []byte) []byte {
@ -34,40 +29,38 @@ func TestSocksTcpConnect(t *testing.T) {
_, err := tcpServer.Start() _, err := tcpServer.Start()
assert.Error(err).IsNil() assert.Error(err).IsNil()
pointPort := v2nettesting.PickPort() freedom := &FreedomConnection{}
config := &point.Config{ traffic := ray.NewRay()
Port: pointPort, data2Send := "Data to be sent to remote"
InboundConfig: &point.ConnectionConfig{ payload := alloc.NewSmallBuffer().Clear().Append([]byte(data2Send))
Protocol: "socks", packet := v2net.NewPacket(v2net.TCPDestination(v2net.IPAddress([]byte{127, 0, 0, 1}), port), payload, false)
Settings: []byte(`{"auth": "noauth"}`),
},
OutboundConfig: &point.ConnectionConfig{
Protocol: "freedom",
Settings: nil,
},
}
point, err := point.NewPoint(config) err = freedom.Dispatch(packet, traffic)
assert.Error(err).IsNil() assert.Error(err).IsNil()
close(traffic.InboundInput())
err = point.Start() respPayload := <-traffic.InboundOutput()
assert.Error(err).IsNil() defer respPayload.Release()
assert.Bytes(respPayload.Value).Equals([]byte("Processed: Data to be sent to remote"))
socks5Client, err := proxy.SOCKS5("tcp", fmt.Sprintf("127.0.0.1:%d", pointPort), nil, proxy.Direct) _, open := <-traffic.InboundOutput()
assert.Error(err).IsNil() assert.Bool(open).IsFalse()
targetServer := fmt.Sprintf("127.0.0.1:%d", port) tcpServer.Close()
conn, err := socks5Client.Dial("tcp", targetServer) }
assert.Error(err).IsNil()
func TestUnreachableDestination(t *testing.T) {
conn.Write([]byte(data2Send)) v2testing.Current(t)
if tcpConn, ok := conn.(*net.TCPConn); ok {
tcpConn.CloseWrite() freedom := &FreedomConnection{}
} traffic := ray.NewRay()
data2Send := "Data to be sent to remote"
dataReturned, err := v2io.ReadFrom(conn, nil) payload := alloc.NewSmallBuffer().Clear().Append([]byte(data2Send))
assert.Error(err).IsNil() packet := v2net.NewPacket(v2net.TCPDestination(v2net.IPAddress([]byte{127, 0, 0, 2}), 80), payload, false)
conn.Close()
err := freedom.Dispatch(packet, traffic)
assert.Bytes(dataReturned.Value).Equals([]byte("Processed: Data to be sent to remote")) assert.Error(err).IsNotNil()
_, open := <-traffic.InboundOutput()
assert.Bool(open).IsFalse()
} }