test case for UDP in freedom

pull/40/head
V2Ray 2015-10-04 20:22:52 +02:00
parent 1d1708ea3c
commit afb5448ffe
4 changed files with 155 additions and 33 deletions

View File

@ -40,9 +40,6 @@ func (vconn *FreedomConnection) Start(ray core.OutboundRay) error {
} }
if !vconn.packet.MoreChunks() { if !vconn.packet.MoreChunks() {
if ray != nil {
close(ray.OutboundOutput())
}
writeMutex.Unlock() writeMutex.Unlock()
} else { } else {
go dumpInput(conn, input, &writeMutex) go dumpInput(conn, input, &writeMutex)

View File

@ -1,53 +1,88 @@
package freedom package freedom
import ( import (
"bytes"
"io/ioutil" "io/ioutil"
"net" "net"
"sync"
"testing" "testing"
"golang.org/x/net/proxy" "golang.org/x/net/proxy"
"github.com/v2ray/v2ray-core" "github.com/v2ray/v2ray-core"
v2net "github.com/v2ray/v2ray-core/common/net"
_ "github.com/v2ray/v2ray-core/proxy/socks" _ "github.com/v2ray/v2ray-core/proxy/socks"
"github.com/v2ray/v2ray-core/testing/mocks" "github.com/v2ray/v2ray-core/testing/mocks"
"github.com/v2ray/v2ray-core/testing/servers/tcp"
"github.com/v2ray/v2ray-core/testing/servers/udp"
"github.com/v2ray/v2ray-core/testing/unit" "github.com/v2ray/v2ray-core/testing/unit"
) )
func TestSocksTcpConnect(t *testing.T) { func TestUDPSend(t *testing.T) {
assert := unit.Assert(t) assert := unit.Assert(t)
port := 48274
data2Send := "Data to be sent to remote" data2Send := "Data to be sent to remote"
data2Return := "Data to be returned to local"
var serverReady sync.Mutex udpServer := &udp.Server{
serverReady.Lock() Port: 0,
MsgProcessor: func(data []byte) []byte {
buffer := make([]byte, 0, 2048)
buffer = append(buffer, []byte("Processed: ")...)
buffer = append(buffer, data...)
return buffer
},
}
go func() { udpServerAddr, err := udpServer.Start()
listener, err := net.ListenTCP("tcp", &net.TCPAddr{ assert.Error(err).IsNil()
IP: []byte{0, 0, 0, 0},
Port: port,
Zone: "",
})
assert.Error(err).IsNil()
serverReady.Unlock() ich := &mocks.InboundConnectionHandler{
conn, err := listener.Accept() Data2Send: []byte("Not Used"),
assert.Error(err).IsNil() DataReturned: bytes.NewBuffer(make([]byte, 0, 1024)),
}
buffer := make([]byte, 1024) core.RegisterInboundConnectionHandlerFactory("mock_ich", ich)
nBytes, err := conn.Read(buffer)
assert.Error(err).IsNil()
if string(buffer[:nBytes]) == data2Send { pointPort := uint16(38724)
_, err = conn.Write([]byte(data2Return)) config := mocks.Config{
assert.Error(err).IsNil() PortValue: pointPort,
} InboundConfigValue: &mocks.ConnectionConfig{
ProtocolValue: "mock_ich",
ContentValue: nil,
},
OutboundConfigValue: &mocks.ConnectionConfig{
ProtocolValue: "freedom",
ContentValue: nil,
},
}
conn.Close() point, err := core.NewPoint(&config)
listener.Close() assert.Error(err).IsNil()
}()
err = point.Start()
assert.Error(err).IsNil()
dest := v2net.NewUDPDestination(udpServerAddr)
ich.Communicate(v2net.NewPacket(dest, []byte(data2Send), false))
assert.Bytes(ich.DataReturned.Bytes()).Equals([]byte("Processed: Data to be sent to remote"))
}
func TestSocksTcpConnect(t *testing.T) {
assert := unit.Assert(t)
port := uint16(38293)
data2Send := "Data to be sent to remote"
tcpServer := &tcp.Server{
Port: port,
MsgProcessor: func(data []byte) []byte {
buffer := make([]byte, 0, 2048)
buffer = append(buffer, []byte("Processed: ")...)
buffer = append(buffer, data...)
return buffer
},
}
_, err := tcpServer.Start()
assert.Error(err).IsNil()
pointPort := uint16(38724) pointPort := uint16(38724)
config := mocks.Config{ config := mocks.Config{
@ -71,9 +106,7 @@ func TestSocksTcpConnect(t *testing.T) {
socks5Client, err := proxy.SOCKS5("tcp", "127.0.0.1:38724", nil, proxy.Direct) socks5Client, err := proxy.SOCKS5("tcp", "127.0.0.1:38724", nil, proxy.Direct)
assert.Error(err).IsNil() assert.Error(err).IsNil()
serverReady.Lock() targetServer := "127.0.0.1:38293"
targetServer := "127.0.0.1:48274"
conn, err := socks5Client.Dial("tcp", targetServer) conn, err := socks5Client.Dial("tcp", targetServer)
assert.Error(err).IsNil() assert.Error(err).IsNil()
@ -86,5 +119,5 @@ func TestSocksTcpConnect(t *testing.T) {
assert.Error(err).IsNil() assert.Error(err).IsNil()
conn.Close() conn.Close()
assert.Bytes(dataReturned).Equals([]byte(data2Return)) assert.Bytes(dataReturned).Equals([]byte("Processed: Data to be sent to remote"))
} }

View File

@ -0,0 +1,51 @@
package tcp
import (
"fmt"
"io/ioutil"
"net"
v2net "github.com/v2ray/v2ray-core/common/net"
)
type Server struct {
Port uint16
MsgProcessor func(msg []byte) []byte
}
func (server *Server) Start() (v2net.Address, error) {
listener, err := net.ListenTCP("tcp", &net.TCPAddr{
IP: []byte{0, 0, 0, 0},
Port: int(server.Port),
Zone: "",
})
if err != nil {
return nil, err
}
go server.acceptConnections(listener)
localAddr := listener.Addr().(*net.TCPAddr)
return v2net.IPAddress(localAddr.IP, uint16(localAddr.Port)), nil
}
func (server *Server) acceptConnections(listener *net.TCPListener) {
for {
conn, err := listener.Accept()
if err != nil {
fmt.Printf("Failed accept TCP connection: %v", err)
continue
}
go server.handleConnection(conn)
}
}
func (server *Server) handleConnection(conn net.Conn) {
request, err := ioutil.ReadAll(conn)
if err != nil {
fmt.Printf("Failed to read request: %v", err)
return
}
response := server.MsgProcessor(request)
conn.Write(response)
conn.Close()
}

View File

@ -0,0 +1,41 @@
package udp
import (
"fmt"
"net"
v2net "github.com/v2ray/v2ray-core/common/net"
)
type Server struct {
Port uint16
MsgProcessor func(msg []byte) []byte
}
func (server *Server) Start() (v2net.Address, error) {
conn, err := net.ListenUDP("udp", &net.UDPAddr{
IP: []byte{0, 0, 0, 0},
Port: int(server.Port),
Zone: "",
})
if err != nil {
return nil, err
}
go server.handleConnection(conn)
localAddr := conn.LocalAddr().(*net.UDPAddr)
return v2net.IPAddress(localAddr.IP, uint16(localAddr.Port)), nil
}
func (server *Server) handleConnection(conn *net.UDPConn) {
for {
buffer := make([]byte, 2*1024)
nBytes, addr, err := conn.ReadFromUDP(buffer)
if err != nil {
fmt.Printf("Failed to read from UDP: %v\n", err)
continue
}
response := server.MsgProcessor(buffer[:nBytes])
conn.WriteToUDP(response, addr)
}
}