remove dep on assert lib

pull/1546/head
Darien Raymond 2019-02-03 19:46:53 +01:00
parent 9d7efdd2e1
commit 66a60dbfa3
No known key found for this signature in database
GPG Key ID: 7251FFA14BB18169
14 changed files with 231 additions and 549 deletions

View File

@ -6,26 +6,23 @@ import (
"strings" "strings"
"testing" "testing"
"github.com/google/go-cmp/cmp"
"v2ray.com/core/common" "v2ray.com/core/common"
"v2ray.com/core/common/net" "v2ray.com/core/common/net"
. "v2ray.com/core/common/protocol/http" . "v2ray.com/core/common/protocol/http"
. "v2ray.com/ext/assert"
) )
func TestParseXForwardedFor(t *testing.T) { func TestParseXForwardedFor(t *testing.T) {
assert := With(t)
header := http.Header{} header := http.Header{}
header.Add("X-Forwarded-For", "129.78.138.66, 129.78.64.103") header.Add("X-Forwarded-For", "129.78.138.66, 129.78.64.103")
addrs := ParseXForwardedFor(header) addrs := ParseXForwardedFor(header)
assert(len(addrs), Equals, 2) if r := cmp.Diff(addrs, []net.Address{net.ParseAddress("129.78.138.66"), net.ParseAddress("129.78.64.103")}); r != "" {
assert(addrs[0].String(), Equals, "129.78.138.66") t.Error(r)
assert(addrs[1].String(), Equals, "129.78.64.103") }
} }
func TestHopByHopHeadersRemoving(t *testing.T) { func TestHopByHopHeadersRemoving(t *testing.T) {
assert := With(t)
rawRequest := `GET /pkg/net/http/ HTTP/1.1 rawRequest := `GET /pkg/net/http/ HTTP/1.1
Host: golang.org Host: golang.org
Connection: keep-alive,Foo, Bar Connection: keep-alive,Foo, Bar
@ -42,18 +39,44 @@ Accept-Language: de,en;q=0.7,en-us;q=0.3
b := bufio.NewReader(strings.NewReader(rawRequest)) b := bufio.NewReader(strings.NewReader(rawRequest))
req, err := http.ReadRequest(b) req, err := http.ReadRequest(b)
common.Must(err) common.Must(err)
assert(req.Header.Get("Foo"), Equals, "foo") headers := []struct {
assert(req.Header.Get("Bar"), Equals, "bar") Key string
assert(req.Header.Get("Connection"), Equals, "keep-alive,Foo, Bar") Value string
assert(req.Header.Get("Proxy-Connection"), Equals, "keep-alive") }{
assert(req.Header.Get("Proxy-Authenticate"), Equals, "abc") {
Key: "Foo",
Value: "foo",
},
{
Key: "Bar",
Value: "bar",
},
{
Key: "Connection",
Value: "keep-alive,Foo, Bar",
},
{
Key: "Proxy-Connection",
Value: "keep-alive",
},
{
Key: "Proxy-Authenticate",
Value: "abc",
},
}
for _, header := range headers {
if v := req.Header.Get(header.Key); v != header.Value {
t.Error("header ", header.Key, " = ", v, " want ", header.Value)
}
}
RemoveHopByHopHeaders(req.Header) RemoveHopByHopHeaders(req.Header)
assert(req.Header.Get("Connection"), IsEmpty)
assert(req.Header.Get("Foo"), IsEmpty) for _, header := range []string{"Connection", "Foo", "Bar", "Proxy-Connection", "Proxy-Authenticate"} {
assert(req.Header.Get("Bar"), IsEmpty) if v := req.Header.Get(header); v != "" {
assert(req.Header.Get("Proxy-Connection"), IsEmpty) t.Error("header ", header, " = ", v)
assert(req.Header.Get("Proxy-Authenticate"), IsEmpty) }
}
} }
func TestParseHost(t *testing.T) { func TestParseHost(t *testing.T) {

View File

@ -3,7 +3,6 @@ package scenarios
import ( import (
"context" "context"
"fmt" "fmt"
"io"
"testing" "testing"
"time" "time"
@ -29,12 +28,9 @@ import (
"v2ray.com/core/proxy/vmess/inbound" "v2ray.com/core/proxy/vmess/inbound"
"v2ray.com/core/proxy/vmess/outbound" "v2ray.com/core/proxy/vmess/outbound"
"v2ray.com/core/testing/servers/tcp" "v2ray.com/core/testing/servers/tcp"
. "v2ray.com/ext/assert"
) )
func TestCommanderRemoveHandler(t *testing.T) { func TestCommanderRemoveHandler(t *testing.T) {
assert := With(t)
tcpServer := tcp.Server{ tcpServer := tcp.Server{
MsgProcessor: xor, MsgProcessor: xor,
} }
@ -99,30 +95,10 @@ func TestCommanderRemoveHandler(t *testing.T) {
servers, err := InitializeServerConfigs(clientConfig) servers, err := InitializeServerConfigs(clientConfig)
common.Must(err) common.Must(err)
defer CloseAllServers(servers) defer CloseAllServers(servers)
{ if err := testTCPConn(clientPort, 1024, time.Second*5)(); err != nil {
conn, err := net.DialTCP("tcp", nil, &net.TCPAddr{ t.Fatal(err)
IP: []byte{127, 0, 0, 1},
Port: int(clientPort),
})
if err != nil {
t.Fatal(err)
}
defer conn.Close() // nolint: errcheck
payload := "commander request."
nBytes, err := conn.Write([]byte(payload))
common.Must(err)
assert(nBytes, Equals, len(payload))
response := make([]byte, 1024)
nBytes, err = conn.Read(response)
common.Must(err)
if r := cmp.Diff(response[:nBytes], xor([]byte(payload))); r != "" {
t.Fatal(r)
}
} }
cmdConn, err := grpc.Dial(fmt.Sprintf("127.0.0.1:%d", cmdPort), grpc.WithInsecure(), grpc.WithBlock()) cmdConn, err := grpc.Dial(fmt.Sprintf("127.0.0.1:%d", cmdPort), grpc.WithInsecure(), grpc.WithBlock())
@ -134,20 +110,22 @@ func TestCommanderRemoveHandler(t *testing.T) {
Tag: "d", Tag: "d",
}) })
common.Must(err) common.Must(err)
assert(resp, IsNotNil) if resp == nil {
t.Error("unexpected nil response")
}
{ {
_, err := net.DialTCP("tcp", nil, &net.TCPAddr{ _, err := net.DialTCP("tcp", nil, &net.TCPAddr{
IP: []byte{127, 0, 0, 1}, IP: []byte{127, 0, 0, 1},
Port: int(clientPort), Port: int(clientPort),
}) })
assert(err, IsNotNil) if err == nil {
t.Error("unexpected nil error")
}
} }
} }
func TestCommanderAddRemoveUser(t *testing.T) { func TestCommanderAddRemoveUser(t *testing.T) {
assert := With(t)
tcpServer := tcp.Server{ tcpServer := tcp.Server{
MsgProcessor: xor, MsgProcessor: xor,
} }
@ -284,24 +262,10 @@ func TestCommanderAddRemoveUser(t *testing.T) {
servers, err := InitializeServerConfigs(serverConfig, clientConfig) servers, err := InitializeServerConfigs(serverConfig, clientConfig)
common.Must(err) common.Must(err)
CloseAllServers(servers)
{ if err := testTCPConn(clientPort, 1024, time.Second*5)(); err != nil {
conn, err := net.DialTCP("tcp", nil, &net.TCPAddr{ t.Fatal(err)
IP: []byte{127, 0, 0, 1},
Port: int(clientPort),
})
common.Must(err)
payload := "commander request."
nBytes, err := conn.Write([]byte(payload))
common.Must(err)
assert(nBytes, Equals, len(payload))
response := make([]byte, 1024)
nBytes, err = conn.Read(response)
assert(nBytes, Equals, 0)
assert(err, Equals, io.EOF)
assert(conn.Close(), IsNil)
} }
cmdConn, err := grpc.Dial(fmt.Sprintf("127.0.0.1:%d", cmdPort), grpc.WithInsecure(), grpc.WithBlock()) cmdConn, err := grpc.Dial(fmt.Sprintf("127.0.0.1:%d", cmdPort), grpc.WithInsecure(), grpc.WithBlock())
@ -323,40 +287,25 @@ func TestCommanderAddRemoveUser(t *testing.T) {
}), }),
}) })
common.Must(err) common.Must(err)
assert(resp, IsNotNil) if resp == nil {
t.Fatal("nil response")
}
{ if err := testTCPConn(clientPort, 1024, time.Second*5)(); err != nil {
conn, err := net.DialTCP("tcp", nil, &net.TCPAddr{ t.Fatal(err)
IP: []byte{127, 0, 0, 1},
Port: int(clientPort),
})
common.Must(err)
payload := "commander request."
nBytes, err := conn.Write([]byte(payload))
common.Must(err)
assert(nBytes, Equals, len(payload))
response := make([]byte, 1024)
nBytes, err = conn.Read(response)
common.Must(err)
assert(response[:nBytes], Equals, xor([]byte(payload)))
assert(conn.Close(), IsNil)
} }
resp, err = hsClient.AlterInbound(context.Background(), &command.AlterInboundRequest{ resp, err = hsClient.AlterInbound(context.Background(), &command.AlterInboundRequest{
Tag: "v", Tag: "v",
Operation: serial.ToTypedMessage(&command.RemoveUserOperation{Email: "test@v2ray.com"}), Operation: serial.ToTypedMessage(&command.RemoveUserOperation{Email: "test@v2ray.com"}),
}) })
assert(resp, IsNotNil)
common.Must(err) common.Must(err)
if resp == nil {
CloseAllServers(servers) t.Fatal("nil response")
}
} }
func TestCommanderStats(t *testing.T) { func TestCommanderStats(t *testing.T) {
assert := With(t)
tcpServer := tcp.Server{ tcpServer := tcp.Server{
MsgProcessor: xor, MsgProcessor: xor,
} }
@ -515,20 +464,30 @@ func TestCommanderStats(t *testing.T) {
Reset_: true, Reset_: true,
}) })
common.Must(err) common.Must(err)
assert(sresp.Stat.Name, Equals, name) if r := cmp.Diff(sresp.Stat, &statscmd.Stat{
assert(sresp.Stat.Value, Equals, int64(10240*1024)) Name: name,
Value: 10240 * 1024,
}); r != "" {
t.Error(r)
}
sresp, err = sClient.GetStats(context.Background(), &statscmd.GetStatsRequest{ sresp, err = sClient.GetStats(context.Background(), &statscmd.GetStatsRequest{
Name: name, Name: name,
}) })
common.Must(err) common.Must(err)
assert(sresp.Stat.Name, Equals, name) if r := cmp.Diff(sresp.Stat, &statscmd.Stat{
assert(sresp.Stat.Value, Equals, int64(0)) Name: name,
Value: 0,
}); r != "" {
t.Error(r)
}
sresp, err = sClient.GetStats(context.Background(), &statscmd.GetStatsRequest{ sresp, err = sClient.GetStats(context.Background(), &statscmd.GetStatsRequest{
Name: "inbound>>>vmess>>>traffic>>>uplink", Name: "inbound>>>vmess>>>traffic>>>uplink",
Reset_: true, Reset_: true,
}) })
common.Must(err) common.Must(err)
assert(sresp.Stat.Value, GreaterThan, int64(10240*1024)) if sresp.Stat.Value <= 10240*1024 {
t.Error("value < 10240*1024: ", sresp.Stat.Value)
}
} }

View File

@ -160,6 +160,27 @@ func testTCPConn(port net.Port, payloadSize int, timeout time.Duration) func() e
} }
defer conn.Close() defer conn.Close()
return testTCPConn2(conn, payloadSize, timeout)()
}
}
func testUDPConn(port net.Port, payloadSize int, timeout time.Duration) func() error {
return func() error {
conn, err := net.DialUDP("udp", nil, &net.UDPAddr{
IP: []byte{127, 0, 0, 1},
Port: int(port),
})
if err != nil {
return err
}
defer conn.Close()
return testTCPConn2(conn, payloadSize, timeout)()
}
}
func testTCPConn2(conn net.Conn, payloadSize int, timeout time.Duration) func() error {
return func() error {
payload := make([]byte, payloadSize) payload := make([]byte, payloadSize)
common.Must2(rand.Read(payload)) common.Must2(rand.Read(payload))

View File

@ -3,6 +3,7 @@ package scenarios
import ( import (
"fmt" "fmt"
"testing" "testing"
"time"
xproxy "golang.org/x/net/proxy" xproxy "golang.org/x/net/proxy"
"v2ray.com/core" "v2ray.com/core"
@ -16,12 +17,9 @@ import (
"v2ray.com/core/proxy/freedom" "v2ray.com/core/proxy/freedom"
"v2ray.com/core/proxy/socks" "v2ray.com/core/proxy/socks"
"v2ray.com/core/testing/servers/tcp" "v2ray.com/core/testing/servers/tcp"
. "v2ray.com/ext/assert"
) )
func TestResolveIP(t *testing.T) { func TestResolveIP(t *testing.T) {
assert := With(t)
tcpServer := tcp.Server{ tcpServer := tcp.Server{
MsgProcessor: xor, MsgProcessor: xor,
} }
@ -85,24 +83,17 @@ func TestResolveIP(t *testing.T) {
servers, err := InitializeServerConfigs(serverConfig) servers, err := InitializeServerConfigs(serverConfig)
common.Must(err) common.Must(err)
defer CloseAllServers(servers)
{ {
noAuthDialer, err := xproxy.SOCKS5("tcp", net.TCPDestination(net.LocalHostIP, serverPort).NetAddr(), nil, xproxy.Direct) noAuthDialer, err := xproxy.SOCKS5("tcp", net.TCPDestination(net.LocalHostIP, serverPort).NetAddr(), nil, xproxy.Direct)
common.Must(err) common.Must(err)
conn, err := noAuthDialer.Dial("tcp", fmt.Sprintf("google.com:%d", dest.Port)) conn, err := noAuthDialer.Dial("tcp", fmt.Sprintf("google.com:%d", dest.Port))
common.Must(err) common.Must(err)
defer conn.Close()
payload := "test payload" if err := testTCPConn2(conn, 1024, time.Second*5)(); err != nil {
nBytes, err := conn.Write([]byte(payload)) t.Error(err)
common.Must(err) }
assert(nBytes, Equals, len(payload))
response := make([]byte, 1024)
nBytes, err = conn.Read(response)
common.Must(err)
assert(response[:nBytes], Equals, xor([]byte(payload)))
assert(conn.Close(), IsNil)
} }
CloseAllServers(servers)
} }

View File

@ -4,6 +4,8 @@ import (
"testing" "testing"
"time" "time"
"golang.org/x/sync/errgroup"
"v2ray.com/core" "v2ray.com/core"
"v2ray.com/core/app/log" "v2ray.com/core/app/log"
"v2ray.com/core/app/proxyman" "v2ray.com/core/app/proxyman"
@ -20,7 +22,6 @@ import (
"v2ray.com/core/proxy/vmess/outbound" "v2ray.com/core/proxy/vmess/outbound"
"v2ray.com/core/testing/servers/tcp" "v2ray.com/core/testing/servers/tcp"
"v2ray.com/core/testing/servers/udp" "v2ray.com/core/testing/servers/udp"
. "v2ray.com/ext/assert"
) )
func TestDokodemoTCP(t *testing.T) { func TestDokodemoTCP(t *testing.T) {
@ -121,8 +122,6 @@ func TestDokodemoTCP(t *testing.T) {
} }
func TestDokodemoUDP(t *testing.T) { func TestDokodemoUDP(t *testing.T) {
assert := With(t)
udpServer := udp.Server{ udpServer := udp.Server{
MsgProcessor: xor, MsgProcessor: xor,
} }
@ -198,25 +197,13 @@ func TestDokodemoUDP(t *testing.T) {
servers, err := InitializeServerConfigs(serverConfig, clientConfig) servers, err := InitializeServerConfigs(serverConfig, clientConfig)
common.Must(err) common.Must(err)
defer CloseAllServers(servers)
var errg errgroup.Group
for port := clientPort; port <= clientPort+clientPortRange; port++ { for port := clientPort; port <= clientPort+clientPortRange; port++ {
conn, err := net.DialUDP("udp", nil, &net.UDPAddr{ errg.Go(testUDPConn(net.Port(port), 1024, time.Second*5))
IP: []byte{127, 0, 0, 1}, }
Port: int(port), if err := errg.Wait(); err != nil {
}) t.Error(err)
common.Must(err)
payload := "dokodemo request."
nBytes, err := conn.Write([]byte(payload))
common.Must(err)
assert(nBytes, Equals, len(payload))
response := make([]byte, 1024)
nBytes, err = conn.Read(response)
common.Must(err)
assert(response[:nBytes], Equals, xor([]byte(payload)))
assert(conn.Close(), IsNil)
} }
CloseAllServers(servers)
} }

View File

@ -33,12 +33,9 @@ import (
"v2ray.com/core/testing/servers/tcp" "v2ray.com/core/testing/servers/tcp"
"v2ray.com/core/testing/servers/udp" "v2ray.com/core/testing/servers/udp"
"v2ray.com/core/transport/internet" "v2ray.com/core/transport/internet"
. "v2ray.com/ext/assert"
) )
func TestPassiveConnection(t *testing.T) { func TestPassiveConnection(t *testing.T) {
assert := With(t)
tcpServer := tcp.Server{ tcpServer := tcp.Server{
MsgProcessor: xor, MsgProcessor: xor,
SendFirst: []byte("send first"), SendFirst: []byte("send first"),
@ -73,6 +70,7 @@ func TestPassiveConnection(t *testing.T) {
servers, err := InitializeServerConfigs(serverConfig) servers, err := InitializeServerConfigs(serverConfig)
common.Must(err) common.Must(err)
defer CloseAllServers(servers)
conn, err := net.DialTCP("tcp", nil, &net.TCPAddr{ conn, err := net.DialTCP("tcp", nil, &net.TCPAddr{
IP: []byte{127, 0, 0, 1}, IP: []byte{127, 0, 0, 1},
@ -84,27 +82,14 @@ func TestPassiveConnection(t *testing.T) {
response := make([]byte, 1024) response := make([]byte, 1024)
nBytes, err := conn.Read(response) nBytes, err := conn.Read(response)
common.Must(err) common.Must(err)
assert(string(response[:nBytes]), Equals, "send first") if string(response[:nBytes]) != "send first" {
t.Error("unexpected first response: ", string(response[:nBytes]))
}
} }
payload := "dokodemo request." if err := testTCPConn2(conn, 1024, time.Second*5)(); err != nil {
{ t.Error(err)
nBytes, err := conn.Write([]byte(payload))
common.Must(err)
assert(nBytes, Equals, len(payload))
} }
{
response := make([]byte, 1024)
nBytes, err := conn.Read(response)
common.Must(err)
assert(response[:nBytes], Equals, xor([]byte(payload)))
}
assert(conn.Close(), IsNil)
CloseAllServers(servers)
} }
func TestProxy(t *testing.T) { func TestProxy(t *testing.T) {
@ -240,8 +225,6 @@ func TestProxy(t *testing.T) {
} }
func TestProxyOverKCP(t *testing.T) { func TestProxyOverKCP(t *testing.T) {
assert := With(t)
tcpServer := tcp.Server{ tcpServer := tcp.Server{
MsgProcessor: xor, MsgProcessor: xor,
} }
@ -377,30 +360,14 @@ func TestProxyOverKCP(t *testing.T) {
servers, err := InitializeServerConfigs(serverConfig, proxyConfig, clientConfig) servers, err := InitializeServerConfigs(serverConfig, proxyConfig, clientConfig)
common.Must(err) common.Must(err)
defer CloseAllServers(servers)
conn, err := net.DialTCP("tcp", nil, &net.TCPAddr{ if err := testTCPConn(clientPort, 1024, time.Second*5)(); err != nil {
IP: []byte{127, 0, 0, 1}, t.Error(err)
Port: int(clientPort), }
})
common.Must(err)
payload := "dokodemo request."
nBytes, err := conn.Write([]byte(payload))
common.Must(err)
assert(nBytes, Equals, len(payload))
response := make([]byte, 1024)
nBytes, err = conn.Read(response)
common.Must(err)
assert(response[:nBytes], Equals, xor([]byte(payload)))
assert(conn.Close(), IsNil)
CloseAllServers(servers)
} }
func TestBlackhole(t *testing.T) { func TestBlackhole(t *testing.T) {
assert := With(t)
tcpServer := tcp.Server{ tcpServer := tcp.Server{
MsgProcessor: xor, MsgProcessor: xor,
} }
@ -472,35 +439,14 @@ func TestBlackhole(t *testing.T) {
servers, err := InitializeServerConfigs(serverConfig) servers, err := InitializeServerConfigs(serverConfig)
common.Must(err) common.Must(err)
defer CloseAllServers(servers)
conn, err := net.DialTCP("tcp", nil, &net.TCPAddr{ if err := testTCPConn(serverPort2, 1024, time.Second*5)(); err != nil {
IP: []byte{127, 0, 0, 1}, t.Error(err)
Port: int(serverPort2),
})
common.Must(err)
payload := "dokodemo request."
{
nBytes, err := conn.Write([]byte(payload))
common.Must(err)
assert(nBytes, Equals, len(payload))
} }
{
response := make([]byte, 1024)
_, err := conn.Read(response)
assert(err, IsNotNil)
}
assert(conn.Close(), IsNil)
CloseAllServers(servers)
} }
func TestForward(t *testing.T) { func TestForward(t *testing.T) {
assert := With(t)
tcpServer := tcp.Server{ tcpServer := tcp.Server{
MsgProcessor: xor, MsgProcessor: xor,
} }
@ -542,31 +488,22 @@ func TestForward(t *testing.T) {
servers, err := InitializeServerConfigs(serverConfig) servers, err := InitializeServerConfigs(serverConfig)
common.Must(err) common.Must(err)
defer CloseAllServers(servers)
{ {
noAuthDialer, err := xproxy.SOCKS5("tcp", net.TCPDestination(net.LocalHostIP, serverPort).NetAddr(), nil, xproxy.Direct) noAuthDialer, err := xproxy.SOCKS5("tcp", net.TCPDestination(net.LocalHostIP, serverPort).NetAddr(), nil, xproxy.Direct)
common.Must(err) common.Must(err)
conn, err := noAuthDialer.Dial("tcp", "google.com:80") conn, err := noAuthDialer.Dial("tcp", "google.com:80")
common.Must(err) common.Must(err)
defer conn.Close()
payload := "test payload" if err := testTCPConn2(conn, 1024, time.Second*5)(); err != nil {
nBytes, err := conn.Write([]byte(payload)) t.Error(err)
common.Must(err) }
assert(nBytes, Equals, len(payload))
response := make([]byte, 1024)
nBytes, err = conn.Read(response)
common.Must(err)
assert(response[:nBytes], Equals, xor([]byte(payload)))
assert(conn.Close(), IsNil)
} }
CloseAllServers(servers)
} }
func TestUDPConnection(t *testing.T) { func TestUDPConnection(t *testing.T) {
assert := With(t)
udpServer := udp.Server{ udpServer := udp.Server{
MsgProcessor: xor, MsgProcessor: xor,
} }
@ -600,56 +537,20 @@ func TestUDPConnection(t *testing.T) {
servers, err := InitializeServerConfigs(clientConfig) servers, err := InitializeServerConfigs(clientConfig)
common.Must(err) common.Must(err)
CloseAllServers(servers)
{ if err := testUDPConn(clientPort, 1024, time.Second*5)(); err != nil {
conn, err := net.DialUDP("udp", nil, &net.UDPAddr{ t.Error(err)
IP: []byte{127, 0, 0, 1},
Port: int(clientPort),
})
common.Must(err)
payload := "dokodemo request."
for i := 0; i < 5; i++ {
nBytes, err := conn.Write([]byte(payload))
common.Must(err)
assert(nBytes, Equals, len(payload))
response := make([]byte, 1024)
nBytes, err = conn.Read(response)
common.Must(err)
assert(response[:nBytes], Equals, xor([]byte(payload)))
}
assert(conn.Close(), IsNil)
} }
time.Sleep(20 * time.Second) time.Sleep(20 * time.Second)
{ if err := testUDPConn(clientPort, 1024, time.Second*5)(); err != nil {
conn, err := net.DialUDP("udp", nil, &net.UDPAddr{ t.Error(err)
IP: []byte{127, 0, 0, 1},
Port: int(clientPort),
})
common.Must(err)
payload := "dokodemo request."
nBytes, err := conn.Write([]byte(payload))
common.Must(err)
assert(nBytes, Equals, len(payload))
response := make([]byte, 1024)
nBytes, err = conn.Read(response)
common.Must(err)
assert(response[:nBytes], Equals, xor([]byte(payload)))
assert(conn.Close(), IsNil)
} }
CloseAllServers(servers)
} }
func TestDomainSniffing(t *testing.T) { func TestDomainSniffing(t *testing.T) {
assert := With(t)
sniffingPort := tcp.PickPort() sniffingPort := tcp.PickPort()
httpPort := tcp.PickPort() httpPort := tcp.PickPort()
serverConfig := &core.Config{ serverConfig := &core.Config{
@ -722,6 +623,7 @@ func TestDomainSniffing(t *testing.T) {
servers, err := InitializeServerConfigs(serverConfig) servers, err := InitializeServerConfigs(serverConfig)
common.Must(err) common.Must(err)
defer CloseAllServers(servers)
{ {
transport := &http.Transport{ transport := &http.Transport{
@ -736,17 +638,14 @@ func TestDomainSniffing(t *testing.T) {
resp, err := client.Get("https://www.github.com/") resp, err := client.Get("https://www.github.com/")
common.Must(err) common.Must(err)
assert(resp.StatusCode, Equals, 200) if resp.StatusCode != 200 {
t.Error("unexpected status code: ", resp.StatusCode)
assert(resp.Write(ioutil.Discard), IsNil) }
common.Must(resp.Write(ioutil.Discard))
} }
CloseAllServers(servers)
} }
func TestDialV2Ray(t *testing.T) { func TestDialV2Ray(t *testing.T) {
assert := With(t)
tcpServer := tcp.Server{ tcpServer := tcp.Server{
MsgProcessor: xor, MsgProcessor: xor,
} }
@ -822,23 +721,16 @@ func TestDialV2Ray(t *testing.T) {
servers, err := InitializeServerConfigs(serverConfig) servers, err := InitializeServerConfigs(serverConfig)
common.Must(err) common.Must(err)
defer CloseAllServers(servers)
client, err := core.New(clientConfig) client, err := core.New(clientConfig)
common.Must(err) common.Must(err)
conn, err := core.Dial(context.Background(), client, dest) conn, err := core.Dial(context.Background(), client, dest)
common.Must(err) common.Must(err)
defer conn.Close()
payload := "commander request." if err := testTCPConn2(conn, 1024, time.Second*5)(); err != nil {
nBytes, err := conn.Write([]byte(payload)) t.Error(err)
common.Must(err) }
assert(nBytes, Equals, len(payload))
response := make([]byte, 1024)
nBytes, err = conn.Read(response)
common.Must(err)
assert(response[:nBytes], Equals, xor([]byte(payload)))
assert(conn.Close(), IsNil)
CloseAllServers(servers)
} }

View File

@ -2,7 +2,6 @@ package scenarios
import ( import (
"crypto/rand" "crypto/rand"
"sync"
"testing" "testing"
"time" "time"
@ -23,7 +22,6 @@ import (
"v2ray.com/core/proxy/shadowsocks" "v2ray.com/core/proxy/shadowsocks"
"v2ray.com/core/testing/servers/tcp" "v2ray.com/core/testing/servers/tcp"
"v2ray.com/core/testing/servers/udp" "v2ray.com/core/testing/servers/udp"
. "v2ray.com/ext/assert"
) )
func TestShadowsocksAES256TCP(t *testing.T) { func TestShadowsocksAES256TCP(t *testing.T) {
@ -538,8 +536,6 @@ func TestShadowsocksAES256GCMTCP(t *testing.T) {
} }
func TestShadowsocksAES128GCMUDP(t *testing.T) { func TestShadowsocksAES128GCMUDP(t *testing.T) {
assert := With(t)
udpServer := udp.Server{ udpServer := udp.Server{
MsgProcessor: xor, MsgProcessor: xor,
} }
@ -626,38 +622,18 @@ func TestShadowsocksAES128GCMUDP(t *testing.T) {
servers, err := InitializeServerConfigs(serverConfig, clientConfig) servers, err := InitializeServerConfigs(serverConfig, clientConfig)
common.Must(err) common.Must(err)
defer CloseAllServers(servers)
var wg sync.WaitGroup var errg errgroup.Group
wg.Add(10)
for i := 0; i < 10; i++ { for i := 0; i < 10; i++ {
go func() { errg.Go(testUDPConn(clientPort, 1024, time.Second*5))
conn, err := net.DialUDP("udp", nil, &net.UDPAddr{ }
IP: []byte{127, 0, 0, 1}, if err := errg.Wait(); err != nil {
Port: int(clientPort), t.Error(err)
})
common.Must(err)
payload := make([]byte, 1024)
rand.Read(payload)
nBytes, err := conn.Write([]byte(payload))
common.Must(err)
assert(nBytes, Equals, len(payload))
response := readFrom(conn, time.Second*5, 1024)
assert(response, Equals, xor([]byte(payload)))
assert(conn.Close(), IsNil)
wg.Done()
}()
} }
wg.Wait()
CloseAllServers(servers)
} }
func TestShadowsocksAES128GCMUDPMux(t *testing.T) { func TestShadowsocksAES128GCMUDPMux(t *testing.T) {
assert := With(t)
udpServer := udp.Server{ udpServer := udp.Server{
MsgProcessor: xor, MsgProcessor: xor,
} }
@ -750,33 +726,15 @@ func TestShadowsocksAES128GCMUDPMux(t *testing.T) {
servers, err := InitializeServerConfigs(serverConfig, clientConfig) servers, err := InitializeServerConfigs(serverConfig, clientConfig)
common.Must(err) common.Must(err)
defer CloseAllServers(servers)
var wg sync.WaitGroup var errg errgroup.Group
wg.Add(10)
for i := 0; i < 10; i++ { for i := 0; i < 10; i++ {
go func() { errg.Go(testUDPConn(clientPort, 1024, time.Second*5))
conn, err := net.DialUDP("udp", nil, &net.UDPAddr{ }
IP: []byte{127, 0, 0, 1}, if err := errg.Wait(); err != nil {
Port: int(clientPort), t.Error(err)
})
common.Must(err)
payload := make([]byte, 1024)
rand.Read(payload)
nBytes, err := conn.Write([]byte(payload))
common.Must(err)
assert(nBytes, Equals, len(payload))
response := readFrom(conn, time.Second*5, 1024)
assert(response, Equals, xor([]byte(payload)))
assert(conn.Close(), IsNil)
wg.Done()
}()
} }
wg.Wait()
CloseAllServers(servers)
} }
func TestShadowsocksNone(t *testing.T) { func TestShadowsocksNone(t *testing.T) {

View File

@ -20,7 +20,6 @@ import (
"v2ray.com/core/proxy/socks" "v2ray.com/core/proxy/socks"
"v2ray.com/core/testing/servers/tcp" "v2ray.com/core/testing/servers/tcp"
"v2ray.com/core/testing/servers/udp" "v2ray.com/core/testing/servers/udp"
. "v2ray.com/ext/assert"
) )
func TestSocksBridgeTCP(t *testing.T) { func TestSocksBridgeTCP(t *testing.T) {
@ -105,8 +104,6 @@ func TestSocksBridgeTCP(t *testing.T) {
} }
func TestSocksBridageUDP(t *testing.T) { func TestSocksBridageUDP(t *testing.T) {
assert := With(t)
udpServer := udp.Server{ udpServer := udp.Server{
MsgProcessor: xor, MsgProcessor: xor,
} }
@ -180,30 +177,14 @@ func TestSocksBridageUDP(t *testing.T) {
servers, err := InitializeServerConfigs(serverConfig, clientConfig) servers, err := InitializeServerConfigs(serverConfig, clientConfig)
common.Must(err) common.Must(err)
defer CloseAllServers(servers)
conn, err := net.DialUDP("udp", nil, &net.UDPAddr{ if err := testUDPConn(clientPort, 1024, time.Second*5)(); err != nil {
IP: []byte{127, 0, 0, 1}, t.Error(err)
Port: int(clientPort), }
})
common.Must(err)
payload := "dokodemo request."
nBytes, err := conn.Write([]byte(payload))
common.Must(err)
assert(nBytes, Equals, len(payload))
response := make([]byte, 1024)
nBytes, err = conn.Read(response)
common.Must(err)
assert(response[:nBytes], Equals, xor([]byte(payload)))
assert(conn.Close(), IsNil)
CloseAllServers(servers)
} }
func TestSocksBridageUDPWithRouting(t *testing.T) { func TestSocksBridageUDPWithRouting(t *testing.T) {
assert := With(t)
udpServer := udp.Server{ udpServer := udp.Server{
MsgProcessor: xor, MsgProcessor: xor,
} }
@ -283,30 +264,14 @@ func TestSocksBridageUDPWithRouting(t *testing.T) {
servers, err := InitializeServerConfigs(serverConfig, clientConfig) servers, err := InitializeServerConfigs(serverConfig, clientConfig)
common.Must(err) common.Must(err)
defer CloseAllServers(servers)
conn, err := net.DialUDP("udp", nil, &net.UDPAddr{ if err := testUDPConn(clientPort, 1024, time.Second*5)(); err != nil {
IP: []byte{127, 0, 0, 1}, t.Error(err)
Port: int(clientPort), }
})
common.Must(err)
payload := "dokodemo request."
nBytes, err := conn.Write([]byte(payload))
common.Must(err)
assert(nBytes, Equals, len(payload))
response := make([]byte, 1024)
nBytes, err = conn.Read(response)
common.Must(err)
assert(response[:nBytes], Equals, xor([]byte(payload)))
assert(conn.Close(), IsNil)
CloseAllServers(servers)
} }
func TestSocksConformance(t *testing.T) { func TestSocksConformance(t *testing.T) {
assert := With(t)
tcpServer := tcp.Server{ tcpServer := tcp.Server{
MsgProcessor: xor, MsgProcessor: xor,
} }
@ -356,23 +321,18 @@ func TestSocksConformance(t *testing.T) {
servers, err := InitializeServerConfigs(serverConfig) servers, err := InitializeServerConfigs(serverConfig)
common.Must(err) common.Must(err)
defer CloseAllServers(servers)
{ {
noAuthDialer, err := xproxy.SOCKS5("tcp", net.TCPDestination(net.LocalHostIP, noAuthPort).NetAddr(), nil, xproxy.Direct) noAuthDialer, err := xproxy.SOCKS5("tcp", net.TCPDestination(net.LocalHostIP, noAuthPort).NetAddr(), nil, xproxy.Direct)
common.Must(err) common.Must(err)
conn, err := noAuthDialer.Dial("tcp", dest.NetAddr()) conn, err := noAuthDialer.Dial("tcp", dest.NetAddr())
common.Must(err) common.Must(err)
defer conn.Close()
payload := "test payload" if err := testTCPConn2(conn, 1024, time.Second*5)(); err != nil {
nBytes, err := conn.Write([]byte(payload)) t.Error(err)
common.Must(err) }
assert(nBytes, Equals, len(payload))
response := make([]byte, 1024)
nBytes, err = conn.Read(response)
common.Must(err)
assert(response[:nBytes], Equals, xor([]byte(payload)))
assert(conn.Close(), IsNil)
} }
{ {
@ -380,52 +340,32 @@ func TestSocksConformance(t *testing.T) {
common.Must(err) common.Must(err)
conn, err := authDialer.Dial("tcp", dest.NetAddr()) conn, err := authDialer.Dial("tcp", dest.NetAddr())
common.Must(err) common.Must(err)
defer conn.Close()
payload := "test payload" if err := testTCPConn2(conn, 1024, time.Second*5)(); err != nil {
nBytes, err := conn.Write([]byte(payload)) t.Error(err)
common.Must(err) }
assert(nBytes, Equals, len(payload))
response := make([]byte, 1024)
nBytes, err = conn.Read(response)
common.Must(err)
assert(response[:nBytes], Equals, xor([]byte(payload)))
assert(conn.Close(), IsNil)
} }
{ {
dialer := socks4.DialSocksProxy(socks4.SOCKS4, net.TCPDestination(net.LocalHostIP, noAuthPort).NetAddr()) dialer := socks4.DialSocksProxy(socks4.SOCKS4, net.TCPDestination(net.LocalHostIP, noAuthPort).NetAddr())
conn, err := dialer("tcp", dest.NetAddr()) conn, err := dialer("tcp", dest.NetAddr())
common.Must(err) common.Must(err)
defer conn.Close()
payload := "test payload" if err := testTCPConn2(conn, 1024, time.Second*5)(); err != nil {
nBytes, err := conn.Write([]byte(payload)) t.Error(err)
common.Must(err) }
assert(nBytes, Equals, len(payload))
response := make([]byte, 1024)
nBytes, err = conn.Read(response)
common.Must(err)
assert(response[:nBytes], Equals, xor([]byte(payload)))
assert(conn.Close(), IsNil)
} }
{ {
dialer := socks4.DialSocksProxy(socks4.SOCKS4A, net.TCPDestination(net.LocalHostIP, noAuthPort).NetAddr()) dialer := socks4.DialSocksProxy(socks4.SOCKS4A, net.TCPDestination(net.LocalHostIP, noAuthPort).NetAddr())
conn, err := dialer("tcp", net.TCPDestination(net.LocalHostDomain, tcpServer.Port).NetAddr()) conn, err := dialer("tcp", net.TCPDestination(net.LocalHostDomain, tcpServer.Port).NetAddr())
common.Must(err) common.Must(err)
defer conn.Close()
payload := "test payload" if err := testTCPConn2(conn, 1024, time.Second*5)(); err != nil {
nBytes, err := conn.Write([]byte(payload)) t.Error(err)
common.Must(err) }
assert(nBytes, Equals, len(payload))
response := make([]byte, 1024)
nBytes, err = conn.Read(response)
common.Must(err)
assert(response[:nBytes], Equals, xor([]byte(payload)))
assert(conn.Close(), IsNil)
} }
CloseAllServers(servers)
} }

View File

@ -1,9 +1,7 @@
package scenarios package scenarios
import ( import (
"crypto/rand"
"os" "os"
"sync"
"testing" "testing"
"time" "time"
@ -26,7 +24,6 @@ import (
"v2ray.com/core/testing/servers/udp" "v2ray.com/core/testing/servers/udp"
"v2ray.com/core/transport/internet" "v2ray.com/core/transport/internet"
"v2ray.com/core/transport/internet/kcp" "v2ray.com/core/transport/internet/kcp"
. "v2ray.com/ext/assert"
) )
func TestVMessDynamicPort(t *testing.T) { func TestVMessDynamicPort(t *testing.T) {
@ -364,8 +361,6 @@ func TestVMessGCMReadv(t *testing.T) {
} }
func TestVMessGCMUDP(t *testing.T) { func TestVMessGCMUDP(t *testing.T) {
assert := With(t)
udpServer := udp.Server{ udpServer := udp.Server{
MsgProcessor: xor, MsgProcessor: xor,
} }
@ -457,43 +452,15 @@ func TestVMessGCMUDP(t *testing.T) {
servers, err := InitializeServerConfigs(serverConfig, clientConfig) servers, err := InitializeServerConfigs(serverConfig, clientConfig)
common.Must(err) common.Must(err)
var wg sync.WaitGroup
wg.Add(10)
for i := 0; i < 10; i++ {
go func() {
conn, err := net.DialUDP("udp", nil, &net.UDPAddr{
IP: []byte{127, 0, 0, 1},
Port: int(clientPort),
})
common.Must(err)
payload := make([]byte, 1024)
rand.Read(payload)
nBytes, err := conn.Write([]byte(payload))
common.Must(err)
assert(nBytes, Equals, len(payload))
payload1 := make([]byte, 1024)
rand.Read(payload1)
nBytes, err = conn.Write([]byte(payload1))
common.Must(err)
assert(nBytes, Equals, len(payload1))
response := readFrom(conn, time.Second*5, 1024)
assert(response, Equals, xor([]byte(payload)))
response = readFrom(conn, time.Second*5, 1024)
assert(response, Equals, xor([]byte(payload1)))
assert(conn.Close(), IsNil)
wg.Done()
}()
}
wg.Wait()
CloseAllServers(servers) CloseAllServers(servers)
var errg errgroup.Group
for i := 0; i < 10; i++ {
errg.Go(testTCPConn(clientPort, 1024, time.Second*5))
}
if err := errg.Wait(); err != nil {
t.Error(err)
}
} }
func TestVMessChacha20(t *testing.T) { func TestVMessChacha20(t *testing.T) {
@ -1076,8 +1043,6 @@ func TestVMessGCMMux(t *testing.T) {
} }
func TestVMessGCMMuxUDP(t *testing.T) { func TestVMessGCMMuxUDP(t *testing.T) {
assert := With(t)
tcpServer := tcp.Server{ tcpServer := tcp.Server{
MsgProcessor: xor, MsgProcessor: xor,
} }
@ -1196,71 +1161,17 @@ func TestVMessGCMMuxUDP(t *testing.T) {
servers, err := InitializeServerConfigs(serverConfig, clientConfig) servers, err := InitializeServerConfigs(serverConfig, clientConfig)
common.Must(err) common.Must(err)
defer CloseAllServers(servers)
for range "abcd" { for range "abcd" {
var wg sync.WaitGroup var errg errgroup.Group
const nConnection = 16 for i := 0; i < 16; i++ {
wg.Add(nConnection * 2) errg.Go(testTCPConn(clientPort, 10240, time.Second*20))
for i := 0; i < nConnection; i++ { errg.Go(testUDPConn(clientUDPPort, 1024, time.Second*10))
go func() {
conn, err := net.DialTCP("tcp", nil, &net.TCPAddr{
IP: []byte{127, 0, 0, 1},
Port: int(clientPort),
})
common.Must(err)
payload := make([]byte, 10240)
rand.Read(payload)
xorpayload := xor(payload)
nBytes, err := conn.Write(payload)
common.Must(err)
assert(nBytes, Equals, len(payload))
response := readFrom(conn, time.Second*20, 10240)
assert(response, Equals, xorpayload)
assert(conn.Close(), IsNil)
wg.Done()
}()
} }
for i := 0; i < nConnection; i++ { if err := errg.Wait(); err != nil {
go func() { t.Error(err)
conn, err := net.DialUDP("udp", nil, &net.UDPAddr{
IP: []byte{127, 0, 0, 1},
Port: int(clientUDPPort),
})
common.Must(err)
conn.SetDeadline(time.Now().Add(time.Second * 10))
payload := make([]byte, 1024)
rand.Read(payload)
xorpayload := xor(payload)
for j := 0; j < 2; j++ {
nBytes, _, err := conn.WriteMsgUDP(payload, nil, nil)
common.Must(err)
assert(nBytes, Equals, len(payload))
}
response := make([]byte, 1024)
oob := make([]byte, 16)
for j := 0; j < 2; j++ {
nBytes, _, _, _, err := conn.ReadMsgUDP(response, oob)
common.Must(err)
assert(nBytes, Equals, 1024)
assert(response, Equals, xorpayload)
}
assert(conn.Close(), IsNil)
wg.Done()
}()
} }
wg.Wait()
time.Sleep(time.Second) time.Sleep(time.Second)
} }
CloseAllServers(servers)
} }

View File

@ -11,31 +11,30 @@ import (
"v2ray.com/core/common/buf" "v2ray.com/core/common/buf"
"v2ray.com/core/common/net" "v2ray.com/core/common/net"
. "v2ray.com/core/transport/internet/headers/http" . "v2ray.com/core/transport/internet/headers/http"
. "v2ray.com/ext/assert"
) )
func TestReaderWriter(t *testing.T) { func TestReaderWriter(t *testing.T) {
assert := With(t)
cache := buf.New() cache := buf.New()
b := buf.New() b := buf.New()
common.Must2(b.WriteString("abcd" + ENDING)) common.Must2(b.WriteString("abcd" + ENDING))
writer := NewHeaderWriter(b) writer := NewHeaderWriter(b)
err := writer.Write(cache) err := writer.Write(cache)
common.Must(err) common.Must(err)
assert(cache.Len(), Equals, int32(8)) if v := cache.Len(); v != 8 {
t.Error("cache len: ", v)
}
_, err = cache.Write([]byte{'e', 'f', 'g'}) _, err = cache.Write([]byte{'e', 'f', 'g'})
common.Must(err) common.Must(err)
reader := &HeaderReader{} reader := &HeaderReader{}
buffer, err := reader.Read(cache) buffer, err := reader.Read(cache)
common.Must(err) common.Must(err)
assert(buffer.Bytes(), Equals, []byte{'e', 'f', 'g'}) if buffer.String() != "efg" {
t.Error("buffer: ", buffer.String())
}
} }
func TestRequestHeader(t *testing.T) { func TestRequestHeader(t *testing.T) {
assert := With(t)
auth, err := NewHttpAuthenticator(context.Background(), &Config{ auth, err := NewHttpAuthenticator(context.Background(), &Config{
Request: &RequestConfig{ Request: &RequestConfig{
Uri: []string{"/"}, Uri: []string{"/"},
@ -53,7 +52,9 @@ func TestRequestHeader(t *testing.T) {
err = auth.GetClientWriter().Write(cache) err = auth.GetClientWriter().Write(cache)
common.Must(err) common.Must(err)
assert(cache.String(), Equals, "GET / HTTP/1.1\r\nTest: Value\r\n\r\n") if cache.String() != "GET / HTTP/1.1\r\nTest: Value\r\n\r\n" {
t.Error("cache: ", cache.String())
}
} }
func TestLongRequestHeader(t *testing.T) { func TestLongRequestHeader(t *testing.T) {
@ -71,8 +72,6 @@ func TestLongRequestHeader(t *testing.T) {
} }
func TestConnection(t *testing.T) { func TestConnection(t *testing.T) {
assert := With(t)
auth, err := NewHttpAuthenticator(context.Background(), &Config{ auth, err := NewHttpAuthenticator(context.Background(), &Config{
Request: &RequestConfig{ Request: &RequestConfig{
Method: &Method{Value: "Post"}, Method: &Method{Value: "Post"},
@ -110,7 +109,9 @@ func TestConnection(t *testing.T) {
b := make([]byte, 256) b := make([]byte, 256)
for { for {
n, err := authConn.Read(b) n, err := authConn.Read(b)
common.Must(err) if err != nil {
break
}
_, err = authConn.Write(b[:n]) _, err = authConn.Write(b[:n])
common.Must(err) common.Must(err)
} }
@ -120,6 +121,8 @@ func TestConnection(t *testing.T) {
common.Must(err) common.Must(err)
authConn := auth.Client(conn) authConn := auth.Client(conn)
defer authConn.Close()
authConn.Write([]byte("Test payload")) authConn.Write([]byte("Test payload"))
authConn.Write([]byte("Test payload 2")) authConn.Write([]byte("Test payload 2"))
@ -136,5 +139,7 @@ func TestConnection(t *testing.T) {
} }
} }
assert(string(actualResponse[:totalBytes]), Equals, expectedResponse) if string(actualResponse[:totalBytes]) != expectedResponse {
t.Error("response: ", string(actualResponse[:totalBytes]))
}
} }

View File

@ -7,12 +7,9 @@ import (
"v2ray.com/core/common" "v2ray.com/core/common"
"v2ray.com/core/common/buf" "v2ray.com/core/common/buf"
. "v2ray.com/core/transport/internet/headers/tls" . "v2ray.com/core/transport/internet/headers/tls"
. "v2ray.com/ext/assert"
) )
func TestDTLSWrite(t *testing.T) { func TestDTLSWrite(t *testing.T) {
assert := With(t)
content := []byte{'a', 'b', 'c', 'd', 'e', 'f', 'g'} content := []byte{'a', 'b', 'c', 'd', 'e', 'f', 'g'}
dtlsRaw, err := New(context.Background(), &PacketConfig{}) dtlsRaw, err := New(context.Background(), &PacketConfig{})
common.Must(err) common.Must(err)
@ -23,5 +20,7 @@ func TestDTLSWrite(t *testing.T) {
dtls.Serialize(payload.Extend(dtls.Size())) dtls.Serialize(payload.Extend(dtls.Size()))
payload.Write(content) payload.Write(content)
assert(payload.Len(), Equals, int32(len(content))+dtls.Size()) if payload.Len() != int32(len(content))+dtls.Size() {
t.Error("payload len: ", payload.Len(), " want ", int32(len(content))+dtls.Size())
}
} }

View File

@ -7,7 +7,6 @@ import (
"v2ray.com/core/common/buf" "v2ray.com/core/common/buf"
. "v2ray.com/core/transport/internet/kcp" . "v2ray.com/core/transport/internet/kcp"
. "v2ray.com/ext/assert"
) )
type NoOpCloser int type NoOpCloser int
@ -17,8 +16,6 @@ func (NoOpCloser) Close() error {
} }
func TestConnectionReadTimeout(t *testing.T) { func TestConnectionReadTimeout(t *testing.T) {
assert := With(t)
conn := NewConnection(ConnMetadata{Conversation: 1}, &KCPPacketWriter{ conn := NewConnection(ConnMetadata{Conversation: 1}, &KCPPacketWriter{
Writer: buf.DiscardBytes, Writer: buf.DiscardBytes,
}, NoOpCloser(0), &Config{}) }, NoOpCloser(0), &Config{})
@ -26,17 +23,16 @@ func TestConnectionReadTimeout(t *testing.T) {
b := make([]byte, 1024) b := make([]byte, 1024)
nBytes, err := conn.Read(b) nBytes, err := conn.Read(b)
assert(nBytes, Equals, 0) if nBytes != 0 || err == nil {
assert(err, IsNotNil) t.Error("unexpected read: ", nBytes, err)
}
conn.Terminate() conn.Terminate()
} }
func TestConnectionInterface(t *testing.T) { func TestConnectionInterface(t *testing.T) {
assert := With(t) _ = (io.Writer)(new(Connection))
_ = (io.Reader)(new(Connection))
assert((*Connection)(nil), Implements, (*io.Writer)(nil)) _ = (buf.Reader)(new(Connection))
assert((*Connection)(nil), Implements, (*io.Reader)(nil)) _ = (buf.Writer)(new(Connection))
assert((*Connection)(nil), Implements, (*buf.Reader)(nil))
assert((*Connection)(nil), Implements, (*buf.Writer)(nil))
} }

View File

@ -11,12 +11,9 @@ import (
"v2ray.com/core/testing/servers/tcp" "v2ray.com/core/testing/servers/tcp"
"v2ray.com/core/transport/internet" "v2ray.com/core/transport/internet"
. "v2ray.com/core/transport/internet/tcp" . "v2ray.com/core/transport/internet/tcp"
. "v2ray.com/ext/assert"
) )
func TestGetOriginalDestination(t *testing.T) { func TestGetOriginalDestination(t *testing.T) {
assert := With(t)
tcpServer := tcp.Server{} tcpServer := tcp.Server{}
dest, err := tcpServer.Start() dest, err := tcpServer.Start()
common.Must(err) common.Must(err)
@ -29,5 +26,7 @@ func TestGetOriginalDestination(t *testing.T) {
defer conn.Close() defer conn.Close()
originalDest, err := GetOriginalDestination(conn) originalDest, err := GetOriginalDestination(conn)
assert(dest == originalDest || strings.Contains(err.Error(), "failed to call getsockopt"), IsTrue) if !(dest == originalDest || strings.Contains(err.Error(), "failed to call getsockopt")) {
t.Error("unexpected state")
}
} }

View File

@ -14,7 +14,6 @@ import (
"v2ray.com/core/transport" "v2ray.com/core/transport"
. "v2ray.com/core/transport/internet/udp" . "v2ray.com/core/transport/internet/udp"
"v2ray.com/core/transport/pipe" "v2ray.com/core/transport/pipe"
. "v2ray.com/ext/assert"
) )
type TestDispatcher struct { type TestDispatcher struct {
@ -38,8 +37,6 @@ func (*TestDispatcher) Type() interface{} {
} }
func TestSameDestinationDispatching(t *testing.T) { func TestSameDestinationDispatching(t *testing.T) {
assert := With(t)
ctx, cancel := context.WithCancel(context.Background()) ctx, cancel := context.WithCancel(context.Background())
uplinkReader, uplinkWriter := pipe.New(pipe.WithSizeLimit(1024)) uplinkReader, uplinkWriter := pipe.New(pipe.WithSizeLimit(1024))
downlinkReader, downlinkWriter := pipe.New(pipe.WithSizeLimit(1024)) downlinkReader, downlinkWriter := pipe.New(pipe.WithSizeLimit(1024))
@ -80,6 +77,10 @@ func TestSameDestinationDispatching(t *testing.T) {
time.Sleep(time.Second) time.Sleep(time.Second)
cancel() cancel()
assert(count, Equals, uint32(1)) if count != 1 {
assert(atomic.LoadUint32(&msgCount), Equals, uint32(6)) t.Error("count: ", count)
}
if v := atomic.LoadUint32(&msgCount); v != 6 {
t.Error("msgCount: ", v)
}
} }