mirror of
https://github.com/v2fly/v2ray-core.git
synced 2025-01-17 14:57:44 -05:00
massive refactoring against unit test lib
This commit is contained in:
parent
cee85bdf26
commit
0a2e4343bc
@ -6,11 +6,12 @@ import (
|
|||||||
|
|
||||||
v2net "github.com/v2ray/v2ray-core/common/net"
|
v2net "github.com/v2ray/v2ray-core/common/net"
|
||||||
v2nettesting "github.com/v2ray/v2ray-core/common/net/testing"
|
v2nettesting "github.com/v2ray/v2ray-core/common/net/testing"
|
||||||
"github.com/v2ray/v2ray-core/testing/unit"
|
v2testing "github.com/v2ray/v2ray-core/testing"
|
||||||
|
"github.com/v2ray/v2ray-core/testing/assert"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestStringListParsingList(t *testing.T) {
|
func TestStringListParsingList(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
rawJson := `["a", "b", "c", "d"]`
|
rawJson := `["a", "b", "c", "d"]`
|
||||||
var strList StringList
|
var strList StringList
|
||||||
@ -20,7 +21,7 @@ func TestStringListParsingList(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestStringListParsingString(t *testing.T) {
|
func TestStringListParsingString(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
rawJson := `"abcd"`
|
rawJson := `"abcd"`
|
||||||
var strList StringList
|
var strList StringList
|
||||||
@ -30,7 +31,7 @@ func TestStringListParsingString(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestDomainMatching(t *testing.T) {
|
func TestDomainMatching(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
rule := &FieldRule{
|
rule := &FieldRule{
|
||||||
Domain: NewStringList("v2ray.com"),
|
Domain: NewStringList("v2ray.com"),
|
||||||
@ -40,7 +41,7 @@ func TestDomainMatching(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestPortMatching(t *testing.T) {
|
func TestPortMatching(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
rule := &FieldRule{
|
rule := &FieldRule{
|
||||||
Port: &v2nettesting.PortRange{
|
Port: &v2nettesting.PortRange{
|
||||||
@ -53,7 +54,7 @@ func TestPortMatching(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestIPMatching(t *testing.T) {
|
func TestIPMatching(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
rawJson := `{
|
rawJson := `{
|
||||||
"type": "field",
|
"type": "field",
|
||||||
@ -66,7 +67,7 @@ func TestIPMatching(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestIPListMatching(t *testing.T) {
|
func TestIPListMatching(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
rawJson := `{
|
rawJson := `{
|
||||||
"type": "field",
|
"type": "field",
|
||||||
@ -79,7 +80,7 @@ func TestIPListMatching(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestPortNotMatching(t *testing.T) {
|
func TestPortNotMatching(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
rawJson := `{
|
rawJson := `{
|
||||||
"type": "field",
|
"type": "field",
|
||||||
@ -92,7 +93,7 @@ func TestPortNotMatching(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestDomainNotMatching(t *testing.T) {
|
func TestDomainNotMatching(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
rawJson := `{
|
rawJson := `{
|
||||||
"type": "field",
|
"type": "field",
|
||||||
@ -105,7 +106,7 @@ func TestDomainNotMatching(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestDomainNotMatchingDomain(t *testing.T) {
|
func TestDomainNotMatchingDomain(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
rawJson := `{
|
rawJson := `{
|
||||||
"type": "field",
|
"type": "field",
|
||||||
|
@ -6,11 +6,12 @@ import (
|
|||||||
"github.com/v2ray/v2ray-core/app/router/rules/config"
|
"github.com/v2ray/v2ray-core/app/router/rules/config"
|
||||||
testinconfig "github.com/v2ray/v2ray-core/app/router/rules/config/testing"
|
testinconfig "github.com/v2ray/v2ray-core/app/router/rules/config/testing"
|
||||||
v2net "github.com/v2ray/v2ray-core/common/net"
|
v2net "github.com/v2ray/v2ray-core/common/net"
|
||||||
"github.com/v2ray/v2ray-core/testing/unit"
|
v2testing "github.com/v2ray/v2ray-core/testing"
|
||||||
|
"github.com/v2ray/v2ray-core/testing/assert"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestSimpleRouter(t *testing.T) {
|
func TestSimpleRouter(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
router := &Router{
|
router := &Router{
|
||||||
rules: []config.Rule{
|
rules: []config.Rule{
|
||||||
|
@ -3,11 +3,12 @@ package alloc
|
|||||||
import (
|
import (
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/v2ray/v2ray-core/testing/unit"
|
v2testing "github.com/v2ray/v2ray-core/testing"
|
||||||
|
"github.com/v2ray/v2ray-core/testing/assert"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestBufferClear(t *testing.T) {
|
func TestBufferClear(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
buffer := NewBuffer().Clear()
|
buffer := NewBuffer().Clear()
|
||||||
defer buffer.Release()
|
defer buffer.Release()
|
||||||
@ -21,7 +22,7 @@ func TestBufferClear(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestBufferIsFull(t *testing.T) {
|
func TestBufferIsFull(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
buffer := NewBuffer()
|
buffer := NewBuffer()
|
||||||
defer buffer.Release()
|
defer buffer.Release()
|
||||||
|
@ -4,11 +4,12 @@ import (
|
|||||||
"testing"
|
"testing"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/v2ray/v2ray-core/testing/unit"
|
v2testing "github.com/v2ray/v2ray-core/testing"
|
||||||
|
"github.com/v2ray/v2ray-core/testing/assert"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestTimedQueue(t *testing.T) {
|
func TestTimedQueue(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
removed := make(map[string]bool)
|
removed := make(map[string]bool)
|
||||||
|
|
||||||
|
@ -7,11 +7,12 @@ import (
|
|||||||
"testing"
|
"testing"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/v2ray/v2ray-core/testing/unit"
|
v2testing "github.com/v2ray/v2ray-core/testing"
|
||||||
|
"github.com/v2ray/v2ray-core/testing/assert"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestAccessLog(t *testing.T) {
|
func TestAccessLog(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
filename := "/tmp/test_access_log.log"
|
filename := "/tmp/test_access_log.log"
|
||||||
InitAccessLogger(filename)
|
InitAccessLogger(filename)
|
||||||
|
@ -5,11 +5,12 @@ import (
|
|||||||
"log"
|
"log"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/v2ray/v2ray-core/testing/unit"
|
v2testing "github.com/v2ray/v2ray-core/testing"
|
||||||
|
"github.com/v2ray/v2ray-core/testing/assert"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestLogLevelSetting(t *testing.T) {
|
func TestLogLevelSetting(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
assert.Pointer(debugLogger).Equals(noOpLoggerInstance)
|
assert.Pointer(debugLogger).Equals(noOpLoggerInstance)
|
||||||
SetLogLevel(DebugLevel)
|
SetLogLevel(DebugLevel)
|
||||||
@ -21,7 +22,7 @@ func TestLogLevelSetting(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestStreamLogger(t *testing.T) {
|
func TestStreamLogger(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
buffer := bytes.NewBuffer(make([]byte, 0, 1024))
|
buffer := bytes.NewBuffer(make([]byte, 0, 1024))
|
||||||
logger := &streamLogger{
|
logger := &streamLogger{
|
||||||
|
@ -4,11 +4,12 @@ import (
|
|||||||
"net"
|
"net"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/v2ray/v2ray-core/testing/unit"
|
v2testing "github.com/v2ray/v2ray-core/testing"
|
||||||
|
"github.com/v2ray/v2ray-core/testing/assert"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestIPv4Address(t *testing.T) {
|
func TestIPv4Address(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
ip := []byte{byte(1), byte(2), byte(3), byte(4)}
|
ip := []byte{byte(1), byte(2), byte(3), byte(4)}
|
||||||
port := NewPort(80)
|
port := NewPort(80)
|
||||||
@ -23,7 +24,7 @@ func TestIPv4Address(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestIPv6Address(t *testing.T) {
|
func TestIPv6Address(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
ip := []byte{
|
ip := []byte{
|
||||||
byte(1), byte(2), byte(3), byte(4),
|
byte(1), byte(2), byte(3), byte(4),
|
||||||
@ -43,7 +44,7 @@ func TestIPv6Address(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestDomainAddress(t *testing.T) {
|
func TestDomainAddress(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
domain := "v2ray.com"
|
domain := "v2ray.com"
|
||||||
port := NewPort(443)
|
port := NewPort(443)
|
||||||
@ -58,7 +59,7 @@ func TestDomainAddress(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestNetIPv4Address(t *testing.T) {
|
func TestNetIPv4Address(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
ip := net.IPv4(1, 2, 3, 4)
|
ip := net.IPv4(1, 2, 3, 4)
|
||||||
port := NewPort(80)
|
port := NewPort(80)
|
||||||
|
@ -3,11 +3,12 @@ package net
|
|||||||
import (
|
import (
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/v2ray/v2ray-core/testing/unit"
|
v2testing "github.com/v2ray/v2ray-core/testing"
|
||||||
|
"github.com/v2ray/v2ray-core/testing/assert"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestTCPDestination(t *testing.T) {
|
func TestTCPDestination(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
dest := NewTCPDestination(IPAddress([]byte{1, 2, 3, 4}, 80))
|
dest := NewTCPDestination(IPAddress([]byte{1, 2, 3, 4}, 80))
|
||||||
assert.Bool(dest.IsTCP()).IsTrue()
|
assert.Bool(dest.IsTCP()).IsTrue()
|
||||||
@ -16,7 +17,7 @@ func TestTCPDestination(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestUDPDestination(t *testing.T) {
|
func TestUDPDestination(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
dest := NewUDPDestination(IPAddress([]byte{0x20, 0x01, 0x48, 0x60, 0x48, 0x60, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x88, 0x88}, 53))
|
dest := NewUDPDestination(IPAddress([]byte{0x20, 0x01, 0x48, 0x60, 0x48, 0x60, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x88, 0x88}, 53))
|
||||||
assert.Bool(dest.IsTCP()).IsFalse()
|
assert.Bool(dest.IsTCP()).IsFalse()
|
||||||
|
@ -4,11 +4,12 @@ import (
|
|||||||
"encoding/json"
|
"encoding/json"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/v2ray/v2ray-core/testing/unit"
|
v2testing "github.com/v2ray/v2ray-core/testing"
|
||||||
|
"github.com/v2ray/v2ray-core/testing/assert"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestArrayNetworkList(t *testing.T) {
|
func TestArrayNetworkList(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
var list NetworkList
|
var list NetworkList
|
||||||
err := json.Unmarshal([]byte("[\"Tcp\"]"), &list)
|
err := json.Unmarshal([]byte("[\"Tcp\"]"), &list)
|
||||||
@ -18,7 +19,7 @@ func TestArrayNetworkList(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestStringNetworkList(t *testing.T) {
|
func TestStringNetworkList(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
var list NetworkList
|
var list NetworkList
|
||||||
err := json.Unmarshal([]byte("\"TCP, ip\""), &list)
|
err := json.Unmarshal([]byte("\"TCP, ip\""), &list)
|
||||||
|
@ -4,11 +4,12 @@ import (
|
|||||||
"encoding/json"
|
"encoding/json"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/v2ray/v2ray-core/testing/unit"
|
v2testing "github.com/v2ray/v2ray-core/testing"
|
||||||
|
"github.com/v2ray/v2ray-core/testing/assert"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestIntPort(t *testing.T) {
|
func TestIntPort(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
var portRange PortRange
|
var portRange PortRange
|
||||||
err := json.Unmarshal([]byte("1234"), &portRange)
|
err := json.Unmarshal([]byte("1234"), &portRange)
|
||||||
@ -19,7 +20,7 @@ func TestIntPort(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestOverRangeIntPort(t *testing.T) {
|
func TestOverRangeIntPort(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
var portRange PortRange
|
var portRange PortRange
|
||||||
err := json.Unmarshal([]byte("70000"), &portRange)
|
err := json.Unmarshal([]byte("70000"), &portRange)
|
||||||
@ -30,7 +31,7 @@ func TestOverRangeIntPort(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestSingleStringPort(t *testing.T) {
|
func TestSingleStringPort(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
var portRange PortRange
|
var portRange PortRange
|
||||||
err := json.Unmarshal([]byte("\"1234\""), &portRange)
|
err := json.Unmarshal([]byte("\"1234\""), &portRange)
|
||||||
@ -41,7 +42,7 @@ func TestSingleStringPort(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestStringPairPort(t *testing.T) {
|
func TestStringPairPort(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
var portRange PortRange
|
var portRange PortRange
|
||||||
err := json.Unmarshal([]byte("\"1234-5678\""), &portRange)
|
err := json.Unmarshal([]byte("\"1234-5678\""), &portRange)
|
||||||
@ -52,7 +53,7 @@ func TestStringPairPort(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestOverRangeStringPort(t *testing.T) {
|
func TestOverRangeStringPort(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
var portRange PortRange
|
var portRange PortRange
|
||||||
err := json.Unmarshal([]byte("\"65536\""), &portRange)
|
err := json.Unmarshal([]byte("\"65536\""), &portRange)
|
||||||
|
46
common/net/testing/assert/portsubject.go
Normal file
46
common/net/testing/assert/portsubject.go
Normal file
@ -0,0 +1,46 @@
|
|||||||
|
package unit
|
||||||
|
|
||||||
|
import (
|
||||||
|
v2net "github.com/v2ray/v2ray-core/common/net"
|
||||||
|
"github.com/v2ray/v2ray-core/testing/assert"
|
||||||
|
)
|
||||||
|
|
||||||
|
func Port(value v2net.Port) *PortSubject {
|
||||||
|
return &PortSubject{value: value}
|
||||||
|
}
|
||||||
|
|
||||||
|
type PortSubject struct {
|
||||||
|
*assert.Subject
|
||||||
|
value v2net.Port
|
||||||
|
}
|
||||||
|
|
||||||
|
func (subject *PortSubject) Named(name string) *PortSubject {
|
||||||
|
subject.Subject.Named(name)
|
||||||
|
return subject
|
||||||
|
}
|
||||||
|
|
||||||
|
func (subject *PortSubject) Fail(verb string, other v2net.Port) {
|
||||||
|
subject.FailWithMessage("Not true that " + subject.DisplayString() + " " + verb + " <" + other.String() + ">.")
|
||||||
|
}
|
||||||
|
|
||||||
|
func (subject *PortSubject) DisplayString() string {
|
||||||
|
return subject.Subject.DisplayString(subject.value.String())
|
||||||
|
}
|
||||||
|
|
||||||
|
func (subject *PortSubject) Equals(expectation v2net.Port) {
|
||||||
|
if subject.value.Value() != expectation.Value() {
|
||||||
|
subject.Fail("is equal to", expectation)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (subject *PortSubject) GreaterThan(expectation v2net.Port) {
|
||||||
|
if subject.value.Value() <= expectation.Value() {
|
||||||
|
subject.Fail("is greater than", expectation)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (subject *PortSubject) LessThan(expectation v2net.Port) {
|
||||||
|
if subject.value.Value() >= expectation.Value() {
|
||||||
|
subject.Fail("is less than", expectation)
|
||||||
|
}
|
||||||
|
}
|
@ -8,11 +8,12 @@ import (
|
|||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/v2ray/v2ray-core/common/alloc"
|
"github.com/v2ray/v2ray-core/common/alloc"
|
||||||
"github.com/v2ray/v2ray-core/testing/unit"
|
v2testing "github.com/v2ray/v2ray-core/testing"
|
||||||
|
"github.com/v2ray/v2ray-core/testing/assert"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestReaderAndWrite(t *testing.T) {
|
func TestReaderAndWrite(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
size := 1024 * 1024
|
size := 1024 * 1024
|
||||||
buffer := make([]byte, size)
|
buffer := make([]byte, size)
|
||||||
|
@ -5,7 +5,8 @@ import (
|
|||||||
"testing"
|
"testing"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/v2ray/v2ray-core/testing/unit"
|
v2testing "github.com/v2ray/v2ray-core/testing"
|
||||||
|
"github.com/v2ray/v2ray-core/testing/assert"
|
||||||
)
|
)
|
||||||
|
|
||||||
var (
|
var (
|
||||||
@ -13,7 +14,7 @@ var (
|
|||||||
)
|
)
|
||||||
|
|
||||||
func TestNoRetry(t *testing.T) {
|
func TestNoRetry(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
startTime := time.Now().Unix()
|
startTime := time.Now().Unix()
|
||||||
err := Timed(10, 100000).On(func() error {
|
err := Timed(10, 100000).On(func() error {
|
||||||
@ -26,7 +27,7 @@ func TestNoRetry(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestRetryOnce(t *testing.T) {
|
func TestRetryOnce(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
startTime := time.Now()
|
startTime := time.Now()
|
||||||
called := 0
|
called := 0
|
||||||
@ -44,7 +45,7 @@ func TestRetryOnce(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestRetryMultiple(t *testing.T) {
|
func TestRetryMultiple(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
startTime := time.Now()
|
startTime := time.Now()
|
||||||
called := 0
|
called := 0
|
||||||
@ -62,7 +63,7 @@ func TestRetryMultiple(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestRetryExhausted(t *testing.T) {
|
func TestRetryExhausted(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
startTime := time.Now()
|
startTime := time.Now()
|
||||||
called := 0
|
called := 0
|
||||||
|
@ -4,11 +4,11 @@ import (
|
|||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/v2ray/v2ray-core/proxy/common/config"
|
"github.com/v2ray/v2ray-core/proxy/common/config"
|
||||||
"github.com/v2ray/v2ray-core/testing/unit"
|
"github.com/v2ray/v2ray-core/testing/assert"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestRegisterInboundConfig(t *testing.T) {
|
func TestRegisterInboundConfig(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
initializeConfigCache()
|
initializeConfigCache()
|
||||||
|
|
||||||
protocol := "test_protocol"
|
protocol := "test_protocol"
|
||||||
@ -27,7 +27,7 @@ func TestRegisterInboundConfig(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestRegisterOutboundConfig(t *testing.T) {
|
func TestRegisterOutboundConfig(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
initializeConfigCache()
|
initializeConfigCache()
|
||||||
|
|
||||||
protocol := "test_protocol"
|
protocol := "test_protocol"
|
||||||
|
@ -10,13 +10,14 @@ import (
|
|||||||
_ "github.com/v2ray/v2ray-core/proxy/freedom"
|
_ "github.com/v2ray/v2ray-core/proxy/freedom"
|
||||||
"github.com/v2ray/v2ray-core/shell/point"
|
"github.com/v2ray/v2ray-core/shell/point"
|
||||||
"github.com/v2ray/v2ray-core/shell/point/config/testing/mocks"
|
"github.com/v2ray/v2ray-core/shell/point/config/testing/mocks"
|
||||||
|
v2testing "github.com/v2ray/v2ray-core/testing"
|
||||||
|
"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/testing/servers/udp"
|
"github.com/v2ray/v2ray-core/testing/servers/udp"
|
||||||
"github.com/v2ray/v2ray-core/testing/unit"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestDokodemoTCP(t *testing.T) {
|
func TestDokodemoTCP(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
port := v2nettesting.PickPort()
|
port := v2nettesting.PickPort()
|
||||||
|
|
||||||
@ -78,7 +79,7 @@ func TestDokodemoTCP(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestDokodemoUDP(t *testing.T) {
|
func TestDokodemoUDP(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
port := v2nettesting.PickPort()
|
port := v2nettesting.PickPort()
|
||||||
|
|
||||||
|
@ -18,13 +18,14 @@ import (
|
|||||||
proxymocks "github.com/v2ray/v2ray-core/proxy/testing/mocks"
|
proxymocks "github.com/v2ray/v2ray-core/proxy/testing/mocks"
|
||||||
"github.com/v2ray/v2ray-core/shell/point"
|
"github.com/v2ray/v2ray-core/shell/point"
|
||||||
"github.com/v2ray/v2ray-core/shell/point/config/testing/mocks"
|
"github.com/v2ray/v2ray-core/shell/point/config/testing/mocks"
|
||||||
|
v2testing "github.com/v2ray/v2ray-core/testing"
|
||||||
|
"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/testing/servers/udp"
|
"github.com/v2ray/v2ray-core/testing/servers/udp"
|
||||||
"github.com/v2ray/v2ray-core/testing/unit"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestUDPSend(t *testing.T) {
|
func TestUDPSend(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
data2Send := "Data to be sent to remote"
|
data2Send := "Data to be sent to remote"
|
||||||
|
|
||||||
@ -76,7 +77,7 @@ func TestUDPSend(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestSocksTcpConnect(t *testing.T) {
|
func TestSocksTcpConnect(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
port := v2nettesting.PickPort()
|
port := v2nettesting.PickPort()
|
||||||
|
|
||||||
data2Send := "Data to be sent to remote"
|
data2Send := "Data to be sent to remote"
|
||||||
|
@ -7,11 +7,11 @@ import (
|
|||||||
|
|
||||||
"github.com/v2ray/v2ray-core/proxy/common/config"
|
"github.com/v2ray/v2ray-core/proxy/common/config"
|
||||||
jsonconfig "github.com/v2ray/v2ray-core/proxy/common/config/json"
|
jsonconfig "github.com/v2ray/v2ray-core/proxy/common/config/json"
|
||||||
"github.com/v2ray/v2ray-core/testing/unit"
|
"github.com/v2ray/v2ray-core/testing/assert"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestAccountMapParsing(t *testing.T) {
|
func TestAccountMapParsing(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
var accountMap SocksAccountMap
|
var accountMap SocksAccountMap
|
||||||
err := json.Unmarshal([]byte("[{\"user\": \"a\", \"pass\":\"b\"}, {\"user\": \"c\", \"pass\":\"d\"}]"), &accountMap)
|
err := json.Unmarshal([]byte("[{\"user\": \"a\", \"pass\":\"b\"}, {\"user\": \"c\", \"pass\":\"d\"}]"), &accountMap)
|
||||||
@ -24,14 +24,14 @@ func TestAccountMapParsing(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestDefaultIPAddress(t *testing.T) {
|
func TestDefaultIPAddress(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
socksConfig := jsonconfig.CreateConfig("socks", config.TypeInbound).(*SocksConfig)
|
socksConfig := jsonconfig.CreateConfig("socks", config.TypeInbound).(*SocksConfig)
|
||||||
assert.String(socksConfig.IP().String()).Equals("127.0.0.1")
|
assert.String(socksConfig.IP().String()).Equals("127.0.0.1")
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestIPAddressParsing(t *testing.T) {
|
func TestIPAddressParsing(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
var ipAddress IPAddress
|
var ipAddress IPAddress
|
||||||
err := json.Unmarshal([]byte("\"1.2.3.4\""), &ipAddress)
|
err := json.Unmarshal([]byte("\"1.2.3.4\""), &ipAddress)
|
||||||
@ -40,7 +40,7 @@ func TestIPAddressParsing(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestNoAuthConfig(t *testing.T) {
|
func TestNoAuthConfig(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
var config SocksConfig
|
var config SocksConfig
|
||||||
err := json.Unmarshal([]byte("{\"auth\":\"noauth\", \"ip\":\"8.8.8.8\"}"), &config)
|
err := json.Unmarshal([]byte("{\"auth\":\"noauth\", \"ip\":\"8.8.8.8\"}"), &config)
|
||||||
@ -52,7 +52,7 @@ func TestNoAuthConfig(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestUserPassConfig(t *testing.T) {
|
func TestUserPassConfig(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
var config SocksConfig
|
var config SocksConfig
|
||||||
err := json.Unmarshal([]byte("{\"auth\":\"password\", \"accounts\":[{\"user\":\"x\", \"pass\":\"y\"}], \"udp\":true}"), &config)
|
err := json.Unmarshal([]byte("{\"auth\":\"password\", \"accounts\":[{\"user\":\"x\", \"pass\":\"y\"}], \"udp\":true}"), &config)
|
||||||
|
@ -5,11 +5,12 @@ import (
|
|||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/v2ray/v2ray-core/common/alloc"
|
"github.com/v2ray/v2ray-core/common/alloc"
|
||||||
"github.com/v2ray/v2ray-core/testing/unit"
|
v2testing "github.com/v2ray/v2ray-core/testing"
|
||||||
|
"github.com/v2ray/v2ray-core/testing/assert"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestSocks4AuthenticationRequestRead(t *testing.T) {
|
func TestSocks4AuthenticationRequestRead(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
rawRequest := []byte{
|
rawRequest := []byte{
|
||||||
0x04, // version
|
0x04, // version
|
||||||
@ -26,7 +27,7 @@ func TestSocks4AuthenticationRequestRead(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestSocks4AuthenticationResponseToBytes(t *testing.T) {
|
func TestSocks4AuthenticationResponseToBytes(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
response := NewSocks4AuthenticationResponse(byte(0x10), 443, []byte{1, 2, 3, 4})
|
response := NewSocks4AuthenticationResponse(byte(0x10), 443, []byte{1, 2, 3, 4})
|
||||||
|
|
||||||
|
@ -6,12 +6,13 @@ import (
|
|||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/v2ray/v2ray-core/common/alloc"
|
"github.com/v2ray/v2ray-core/common/alloc"
|
||||||
"github.com/v2ray/v2ray-core/testing/unit"
|
v2testing "github.com/v2ray/v2ray-core/testing"
|
||||||
|
"github.com/v2ray/v2ray-core/testing/assert"
|
||||||
"github.com/v2ray/v2ray-core/transport"
|
"github.com/v2ray/v2ray-core/transport"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestHasAuthenticationMethod(t *testing.T) {
|
func TestHasAuthenticationMethod(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
request := Socks5AuthenticationRequest{
|
request := Socks5AuthenticationRequest{
|
||||||
version: socksVersion,
|
version: socksVersion,
|
||||||
@ -26,7 +27,7 @@ func TestHasAuthenticationMethod(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestAuthenticationRequestRead(t *testing.T) {
|
func TestAuthenticationRequestRead(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
rawRequest := []byte{
|
rawRequest := []byte{
|
||||||
0x05, // version
|
0x05, // version
|
||||||
@ -41,7 +42,7 @@ func TestAuthenticationRequestRead(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestAuthenticationResponseWrite(t *testing.T) {
|
func TestAuthenticationResponseWrite(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
response := NewAuthenticationResponse(byte(0x05))
|
response := NewAuthenticationResponse(byte(0x05))
|
||||||
|
|
||||||
@ -51,7 +52,7 @@ func TestAuthenticationResponseWrite(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestRequestRead(t *testing.T) {
|
func TestRequestRead(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
rawRequest := []byte{
|
rawRequest := []byte{
|
||||||
0x05, // version
|
0x05, // version
|
||||||
@ -71,7 +72,7 @@ func TestRequestRead(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestResponseWrite(t *testing.T) {
|
func TestResponseWrite(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
response := Socks5Response{
|
response := Socks5Response{
|
||||||
socksVersion,
|
socksVersion,
|
||||||
@ -98,14 +99,14 @@ func TestResponseWrite(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestEOF(t *testing.T) {
|
func TestEOF(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
_, _, err := ReadAuthentication(bytes.NewReader(make([]byte, 0)))
|
_, _, err := ReadAuthentication(bytes.NewReader(make([]byte, 0)))
|
||||||
assert.Error(err).Equals(io.EOF)
|
assert.Error(err).Equals(io.EOF)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestSignleByte(t *testing.T) {
|
func TestSignleByte(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
_, _, err := ReadAuthentication(bytes.NewReader(make([]byte, 1)))
|
_, _, err := ReadAuthentication(bytes.NewReader(make([]byte, 1)))
|
||||||
assert.Error(err).Equals(transport.CorruptedPacket)
|
assert.Error(err).Equals(transport.CorruptedPacket)
|
||||||
|
@ -3,12 +3,12 @@ package protocol
|
|||||||
import (
|
import (
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/v2ray/v2ray-core/testing/unit"
|
"github.com/v2ray/v2ray-core/testing/assert"
|
||||||
"github.com/v2ray/v2ray-core/transport"
|
"github.com/v2ray/v2ray-core/transport"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestSingleByteRequest(t *testing.T) {
|
func TestSingleByteRequest(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
request, err := ReadUDPRequest(make([]byte, 1))
|
request, err := ReadUDPRequest(make([]byte, 1))
|
||||||
if request != nil {
|
if request != nil {
|
||||||
@ -18,7 +18,7 @@ func TestSingleByteRequest(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestDomainAddressRequest(t *testing.T) {
|
func TestDomainAddressRequest(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
payload := make([]byte, 0, 1024)
|
payload := make([]byte, 0, 1024)
|
||||||
payload = append(payload, 0, 0, 1, AddrTypeDomain, byte(len("v2ray.com")))
|
payload = append(payload, 0, 0, 1, AddrTypeDomain, byte(len("v2ray.com")))
|
||||||
|
@ -15,11 +15,12 @@ import (
|
|||||||
proxymocks "github.com/v2ray/v2ray-core/proxy/testing/mocks"
|
proxymocks "github.com/v2ray/v2ray-core/proxy/testing/mocks"
|
||||||
"github.com/v2ray/v2ray-core/shell/point"
|
"github.com/v2ray/v2ray-core/shell/point"
|
||||||
"github.com/v2ray/v2ray-core/shell/point/config/testing/mocks"
|
"github.com/v2ray/v2ray-core/shell/point/config/testing/mocks"
|
||||||
"github.com/v2ray/v2ray-core/testing/unit"
|
v2testing "github.com/v2ray/v2ray-core/testing"
|
||||||
|
"github.com/v2ray/v2ray-core/testing/assert"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestSocksTcpConnect(t *testing.T) {
|
func TestSocksTcpConnect(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
port := v2nettesting.PickPort()
|
port := v2nettesting.PickPort()
|
||||||
|
|
||||||
connInput := []byte("The data to be returned to socks server.")
|
connInput := []byte("The data to be returned to socks server.")
|
||||||
@ -74,7 +75,7 @@ func TestSocksTcpConnect(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestSocksTcpConnectWithUserPass(t *testing.T) {
|
func TestSocksTcpConnectWithUserPass(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
port := v2nettesting.PickPort()
|
port := v2nettesting.PickPort()
|
||||||
|
|
||||||
connInput := []byte("The data to be returned to socks server.")
|
connInput := []byte("The data to be returned to socks server.")
|
||||||
@ -132,7 +133,7 @@ func TestSocksTcpConnectWithUserPass(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestSocksTcpConnectWithWrongUserPass(t *testing.T) {
|
func TestSocksTcpConnectWithWrongUserPass(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
port := v2nettesting.PickPort()
|
port := v2nettesting.PickPort()
|
||||||
|
|
||||||
connInput := []byte("The data to be returned to socks server.")
|
connInput := []byte("The data to be returned to socks server.")
|
||||||
@ -176,7 +177,7 @@ func TestSocksTcpConnectWithWrongUserPass(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestSocksTcpConnectWithWrongAuthMethod(t *testing.T) {
|
func TestSocksTcpConnectWithWrongAuthMethod(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
port := v2nettesting.PickPort()
|
port := v2nettesting.PickPort()
|
||||||
|
|
||||||
connInput := []byte("The data to be returned to socks server.")
|
connInput := []byte("The data to be returned to socks server.")
|
||||||
@ -220,7 +221,7 @@ func TestSocksTcpConnectWithWrongAuthMethod(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestSocksUdpSend(t *testing.T) {
|
func TestSocksUdpSend(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
port := v2nettesting.PickPort()
|
port := v2nettesting.PickPort()
|
||||||
|
|
||||||
connInput := []byte("The data to be returned to socks server.")
|
connInput := []byte("The data to be returned to socks server.")
|
||||||
|
@ -3,11 +3,11 @@ package config
|
|||||||
import (
|
import (
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/v2ray/v2ray-core/testing/unit"
|
"github.com/v2ray/v2ray-core/testing/assert"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestUUIDToID(t *testing.T) {
|
func TestUUIDToID(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
uuid := "2418d087-648d-4990-86e8-19dca1d006d3"
|
uuid := "2418d087-648d-4990-86e8-19dca1d006d3"
|
||||||
expectedBytes := []byte{0x24, 0x18, 0xd0, 0x87, 0x64, 0x8d, 0x49, 0x90, 0x86, 0xe8, 0x19, 0xdc, 0xa1, 0xd0, 0x06, 0xd3}
|
expectedBytes := []byte{0x24, 0x18, 0xd0, 0x87, 0x64, 0x8d, 0x49, 0x90, 0x86, 0xe8, 0x19, 0xdc, 0xa1, 0xd0, 0x06, 0xd3}
|
||||||
|
@ -4,11 +4,11 @@ import (
|
|||||||
"testing"
|
"testing"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/v2ray/v2ray-core/testing/unit"
|
"github.com/v2ray/v2ray-core/testing/assert"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestGenerateRandomInt64InRange(t *testing.T) {
|
func TestGenerateRandomInt64InRange(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
base := time.Now().Unix()
|
base := time.Now().Unix()
|
||||||
delta := 100
|
delta := 100
|
||||||
|
|
||||||
|
@ -10,7 +10,8 @@ import (
|
|||||||
"github.com/v2ray/v2ray-core/proxy/vmess/config"
|
"github.com/v2ray/v2ray-core/proxy/vmess/config"
|
||||||
"github.com/v2ray/v2ray-core/proxy/vmess/protocol/user"
|
"github.com/v2ray/v2ray-core/proxy/vmess/protocol/user"
|
||||||
"github.com/v2ray/v2ray-core/proxy/vmess/protocol/user/testing/mocks"
|
"github.com/v2ray/v2ray-core/proxy/vmess/protocol/user/testing/mocks"
|
||||||
"github.com/v2ray/v2ray-core/testing/unit"
|
v2testing "github.com/v2ray/v2ray-core/testing"
|
||||||
|
"github.com/v2ray/v2ray-core/testing/assert"
|
||||||
)
|
)
|
||||||
|
|
||||||
type TestUser struct {
|
type TestUser struct {
|
||||||
@ -27,7 +28,7 @@ func (this *TestUser) Level() config.UserLevel {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestVMessSerialization(t *testing.T) {
|
func TestVMessSerialization(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
userId, err := config.NewID("2b2966ac-16aa-4fbf-8d81-c5f172a3da51")
|
userId, err := config.NewID("2b2966ac-16aa-4fbf-8d81-c5f172a3da51")
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@ -81,7 +82,7 @@ func TestVMessSerialization(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestReadSingleByte(t *testing.T) {
|
func TestReadSingleByte(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
reader := NewVMessRequestReader(nil)
|
reader := NewVMessRequestReader(nil)
|
||||||
_, err := reader.Read(bytes.NewReader(make([]byte, 1)))
|
_, err := reader.Read(bytes.NewReader(make([]byte, 1)))
|
||||||
|
@ -12,11 +12,12 @@ import (
|
|||||||
"github.com/v2ray/v2ray-core/proxy/vmess/config/json"
|
"github.com/v2ray/v2ray-core/proxy/vmess/config/json"
|
||||||
"github.com/v2ray/v2ray-core/shell/point"
|
"github.com/v2ray/v2ray-core/shell/point"
|
||||||
"github.com/v2ray/v2ray-core/shell/point/config/testing/mocks"
|
"github.com/v2ray/v2ray-core/shell/point/config/testing/mocks"
|
||||||
"github.com/v2ray/v2ray-core/testing/unit"
|
v2testing "github.com/v2ray/v2ray-core/testing"
|
||||||
|
"github.com/v2ray/v2ray-core/testing/assert"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestVMessInAndOut(t *testing.T) {
|
func TestVMessInAndOut(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
testAccount, err := config.NewID("ad937d9d-6e23-4a5a-ba23-bce5092a7c51")
|
testAccount, err := config.NewID("ad937d9d-6e23-4a5a-ba23-bce5092a7c51")
|
||||||
assert.Error(err).IsNil()
|
assert.Error(err).IsNil()
|
||||||
|
@ -10,11 +10,12 @@ import (
|
|||||||
_ "github.com/v2ray/v2ray-core/proxy/vmess/config/json"
|
_ "github.com/v2ray/v2ray-core/proxy/vmess/config/json"
|
||||||
"github.com/v2ray/v2ray-core/shell/point/config/json"
|
"github.com/v2ray/v2ray-core/shell/point/config/json"
|
||||||
|
|
||||||
"github.com/v2ray/v2ray-core/testing/unit"
|
v2testing "github.com/v2ray/v2ray-core/testing"
|
||||||
|
"github.com/v2ray/v2ray-core/testing/assert"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestClientSampleConfig(t *testing.T) {
|
func TestClientSampleConfig(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
// TODO: fix for Windows
|
// TODO: fix for Windows
|
||||||
baseDir := "$GOPATH/src/github.com/v2ray/v2ray-core/release/config"
|
baseDir := "$GOPATH/src/github.com/v2ray/v2ray-core/release/config"
|
||||||
@ -34,7 +35,7 @@ func TestClientSampleConfig(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestServerSampleConfig(t *testing.T) {
|
func TestServerSampleConfig(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
// TODO: fix for Windows
|
// TODO: fix for Windows
|
||||||
baseDir := "$GOPATH/src/github.com/v2ray/v2ray-core/release/config"
|
baseDir := "$GOPATH/src/github.com/v2ray/v2ray-core/release/config"
|
||||||
@ -54,7 +55,7 @@ func TestServerSampleConfig(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestDetourConfig(t *testing.T) {
|
func TestDetourConfig(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
// TODO: fix for Windows
|
// TODO: fix for Windows
|
||||||
baseDir := "$GOPATH/src/github.com/v2ray/v2ray-core/release/config"
|
baseDir := "$GOPATH/src/github.com/v2ray/v2ray-core/release/config"
|
||||||
|
@ -1,19 +1,16 @@
|
|||||||
package unit
|
package assert
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"strconv"
|
"strconv"
|
||||||
)
|
)
|
||||||
|
|
||||||
type BoolSubject struct {
|
func Bool(value bool) *BoolSubject {
|
||||||
*Subject
|
return &BoolSubject{value: value}
|
||||||
value bool
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewBoolSubject(base *Subject, value bool) *BoolSubject {
|
type BoolSubject struct {
|
||||||
return &BoolSubject{
|
Subject
|
||||||
Subject: base,
|
value bool
|
||||||
value: value,
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (subject *BoolSubject) Named(name string) *BoolSubject {
|
func (subject *BoolSubject) Named(name string) *BoolSubject {
|
@ -1,20 +1,17 @@
|
|||||||
package unit
|
package assert
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"bytes"
|
"bytes"
|
||||||
"fmt"
|
"fmt"
|
||||||
)
|
)
|
||||||
|
|
||||||
type BytesSubject struct {
|
func Bytes(value []byte) *BytesSubject {
|
||||||
*Subject
|
return &BytesSubject{value: value}
|
||||||
value []byte
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewBytesSubject(base *Subject, value []byte) *BytesSubject {
|
type BytesSubject struct {
|
||||||
return &BytesSubject{
|
Subject
|
||||||
Subject: base,
|
value []byte
|
||||||
value: value,
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (subject *BytesSubject) Named(name string) *BytesSubject {
|
func (subject *BytesSubject) Named(name string) *BytesSubject {
|
@ -1,19 +1,16 @@
|
|||||||
package unit
|
package assert
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"strconv"
|
"strconv"
|
||||||
)
|
)
|
||||||
|
|
||||||
type ByteSubject struct {
|
func Byte(value byte) *ByteSubject {
|
||||||
*Subject
|
return &ByteSubject{value: value}
|
||||||
value byte
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewByteSubject(base *Subject, value byte) *ByteSubject {
|
type ByteSubject struct {
|
||||||
return &ByteSubject{
|
Subject
|
||||||
Subject: base,
|
value byte
|
||||||
value: value,
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (subject *ByteSubject) Named(name string) *ByteSubject {
|
func (subject *ByteSubject) Named(name string) *ByteSubject {
|
@ -1,15 +1,12 @@
|
|||||||
package unit
|
package assert
|
||||||
|
|
||||||
type ErrorSubject struct {
|
func Error(value error) *ErrorSubject {
|
||||||
*Subject
|
return &ErrorSubject{value: value}
|
||||||
value error
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewErrorSubject(base *Subject, value error) *ErrorSubject {
|
type ErrorSubject struct {
|
||||||
return &ErrorSubject{
|
Subject
|
||||||
Subject: base,
|
value error
|
||||||
value: value,
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (subject *ErrorSubject) Named(name string) *ErrorSubject {
|
func (subject *ErrorSubject) Named(name string) *ErrorSubject {
|
@ -1,19 +1,16 @@
|
|||||||
package unit
|
package assert
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"strconv"
|
"strconv"
|
||||||
)
|
)
|
||||||
|
|
||||||
type Int64Subject struct {
|
func Int64(value int64) *Int64Subject {
|
||||||
*Subject
|
return &Int64Subject{value: value}
|
||||||
value int64
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewInt64Subject(base *Subject, value int64) *Int64Subject {
|
type Int64Subject struct {
|
||||||
return &Int64Subject{
|
Subject
|
||||||
Subject: base,
|
value int64
|
||||||
value: value,
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (subject *Int64Subject) Named(name string) *Int64Subject {
|
func (subject *Int64Subject) Named(name string) *Int64Subject {
|
@ -1,21 +1,18 @@
|
|||||||
package unit
|
package assert
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"strconv"
|
"strconv"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
func Int(value int) *IntSubject {
|
||||||
|
return &IntSubject{value: value}
|
||||||
|
}
|
||||||
|
|
||||||
type IntSubject struct {
|
type IntSubject struct {
|
||||||
*Subject
|
*Subject
|
||||||
value int
|
value int
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewIntSubject(base *Subject, value int) *IntSubject {
|
|
||||||
return &IntSubject{
|
|
||||||
Subject: base,
|
|
||||||
value: value,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (subject *IntSubject) Named(name string) *IntSubject {
|
func (subject *IntSubject) Named(name string) *IntSubject {
|
||||||
subject.Subject.Named(name)
|
subject.Subject.Named(name)
|
||||||
return subject
|
return subject
|
@ -1,19 +1,16 @@
|
|||||||
package unit
|
package assert
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
)
|
)
|
||||||
|
|
||||||
type PointerSubject struct {
|
func Pointer(value interface{}) *PointerSubject {
|
||||||
*Subject
|
return &PointerSubject{value: value}
|
||||||
value interface{}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewPointerSubject(base *Subject, value interface{}) *PointerSubject {
|
type PointerSubject struct {
|
||||||
return &PointerSubject{
|
Subject
|
||||||
Subject: base,
|
value interface{}
|
||||||
value: value,
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (subject *PointerSubject) Named(name string) *PointerSubject {
|
func (subject *PointerSubject) Named(name string) *PointerSubject {
|
@ -1,15 +1,12 @@
|
|||||||
package unit
|
package assert
|
||||||
|
|
||||||
type StringSubject struct {
|
func String(value string) *StringSubject {
|
||||||
*Subject
|
return &StringSubject{value: value}
|
||||||
value string
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewStringSubject(base *Subject, value string) *StringSubject {
|
type StringSubject struct {
|
||||||
return &StringSubject{
|
Subject
|
||||||
Subject: base,
|
value string
|
||||||
value: value,
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (subject *StringSubject) Named(name string) *StringSubject {
|
func (subject *StringSubject) Named(name string) *StringSubject {
|
33
testing/assert/subject.go
Normal file
33
testing/assert/subject.go
Normal file
@ -0,0 +1,33 @@
|
|||||||
|
package assert
|
||||||
|
|
||||||
|
import (
|
||||||
|
v2testing "github.com/v2ray/v2ray-core/testing"
|
||||||
|
)
|
||||||
|
|
||||||
|
type Subject struct {
|
||||||
|
name string
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewSubject() *Subject {
|
||||||
|
return &Subject{
|
||||||
|
name: "",
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (subject *Subject) FailWithMessage(message string) {
|
||||||
|
v2testing.Fail(message)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (subject *Subject) Named(name string) {
|
||||||
|
subject.name = name
|
||||||
|
}
|
||||||
|
|
||||||
|
func (subject *Subject) DisplayString(value string) string {
|
||||||
|
if len(value) == 0 {
|
||||||
|
value = "unknown"
|
||||||
|
}
|
||||||
|
if len(subject.name) == 0 {
|
||||||
|
return "<" + value + ">"
|
||||||
|
}
|
||||||
|
return subject.name + "(<" + value + ">)"
|
||||||
|
}
|
@ -1,19 +1,16 @@
|
|||||||
package unit
|
package assert
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"strconv"
|
"strconv"
|
||||||
)
|
)
|
||||||
|
|
||||||
type Uint16Subject struct {
|
func Uint16(value uint16) *Uint16Subject {
|
||||||
*Subject
|
return &Uint16Subject{value: value}
|
||||||
value uint16
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewUint16Subject(base *Subject, value uint16) *Uint16Subject {
|
type Uint16Subject struct {
|
||||||
return &Uint16Subject{
|
Subject
|
||||||
Subject: base,
|
value uint16
|
||||||
value: value,
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (subject *Uint16Subject) Named(name string) *Uint16Subject {
|
func (subject *Uint16Subject) Named(name string) *Uint16Subject {
|
66
testing/global.go
Normal file
66
testing/global.go
Normal file
@ -0,0 +1,66 @@
|
|||||||
|
package unit
|
||||||
|
|
||||||
|
import (
|
||||||
|
"bytes"
|
||||||
|
"fmt"
|
||||||
|
"runtime"
|
||||||
|
"strings"
|
||||||
|
"testing"
|
||||||
|
)
|
||||||
|
|
||||||
|
var tGlobal *testing.T
|
||||||
|
|
||||||
|
func Current(t *testing.T) {
|
||||||
|
tGlobal = t
|
||||||
|
}
|
||||||
|
|
||||||
|
func getCaller() (string, int) {
|
||||||
|
stackLevel := 3
|
||||||
|
for {
|
||||||
|
_, file, line, ok := runtime.Caller(stackLevel)
|
||||||
|
if strings.Contains(file, "assert") {
|
||||||
|
stackLevel++
|
||||||
|
} else {
|
||||||
|
if ok {
|
||||||
|
// Truncate file name at last file name separator.
|
||||||
|
if index := strings.LastIndex(file, "/"); index >= 0 {
|
||||||
|
file = file[index+1:]
|
||||||
|
} else if index = strings.LastIndex(file, "\\"); index >= 0 {
|
||||||
|
file = file[index+1:]
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
file = "???"
|
||||||
|
line = 1
|
||||||
|
}
|
||||||
|
return file, line
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// decorate prefixes the string with the file and line of the call site
|
||||||
|
// and inserts the final newline if needed and indentation tabs for formatting.
|
||||||
|
func decorate(s string) string {
|
||||||
|
file, line := getCaller()
|
||||||
|
buf := new(bytes.Buffer)
|
||||||
|
// Every line is indented at least one tab.
|
||||||
|
buf.WriteString(" ")
|
||||||
|
fmt.Fprintf(buf, "%s:%d: ", file, line)
|
||||||
|
lines := strings.Split(s, "\n")
|
||||||
|
if l := len(lines); l > 1 && lines[l-1] == "" {
|
||||||
|
lines = lines[:l-1]
|
||||||
|
}
|
||||||
|
for i, line := range lines {
|
||||||
|
if i > 0 {
|
||||||
|
// Second and subsequent lines are indented an extra tab.
|
||||||
|
buf.WriteString("\n\t\t")
|
||||||
|
}
|
||||||
|
buf.WriteString(line)
|
||||||
|
}
|
||||||
|
buf.WriteByte('\n')
|
||||||
|
return buf.String()
|
||||||
|
}
|
||||||
|
|
||||||
|
func Fail(message string) {
|
||||||
|
fmt.Println(decorate(message))
|
||||||
|
tGlobal.Fail()
|
||||||
|
}
|
@ -6,13 +6,14 @@ import (
|
|||||||
|
|
||||||
v2net "github.com/v2ray/v2ray-core/common/net"
|
v2net "github.com/v2ray/v2ray-core/common/net"
|
||||||
v2nettesting "github.com/v2ray/v2ray-core/common/net/testing"
|
v2nettesting "github.com/v2ray/v2ray-core/common/net/testing"
|
||||||
|
v2testing "github.com/v2ray/v2ray-core/testing"
|
||||||
|
"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/testing/servers/udp"
|
"github.com/v2ray/v2ray-core/testing/servers/udp"
|
||||||
"github.com/v2ray/v2ray-core/testing/unit"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestTCPConnection(t *testing.T) {
|
func TestTCPConnection(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
targetPort := v2nettesting.PickPort()
|
targetPort := v2nettesting.PickPort()
|
||||||
tcpServer := &tcp.Server{
|
tcpServer := &tcp.Server{
|
||||||
@ -78,7 +79,7 @@ func TestTCPConnection(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestTCPBind(t *testing.T) {
|
func TestTCPBind(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
targetPort := v2nettesting.PickPort()
|
targetPort := v2nettesting.PickPort()
|
||||||
tcpServer := &tcp.Server{
|
tcpServer := &tcp.Server{
|
||||||
@ -125,7 +126,7 @@ func TestTCPBind(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestUDPAssociate(t *testing.T) {
|
func TestUDPAssociate(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
targetPort := v2nettesting.PickPort()
|
targetPort := v2nettesting.PickPort()
|
||||||
udpServer := &udp.Server{
|
udpServer := &udp.Server{
|
||||||
|
@ -1,53 +0,0 @@
|
|||||||
package unit
|
|
||||||
|
|
||||||
import (
|
|
||||||
"testing"
|
|
||||||
)
|
|
||||||
|
|
||||||
// Assertion is an assertion library inspired by Truth.
|
|
||||||
// See http://google.github.io/truth/
|
|
||||||
type Assertion struct {
|
|
||||||
t *testing.T
|
|
||||||
}
|
|
||||||
|
|
||||||
func Assert(t *testing.T) *Assertion {
|
|
||||||
assert := new(Assertion)
|
|
||||||
assert.t = t
|
|
||||||
return assert
|
|
||||||
}
|
|
||||||
|
|
||||||
func (a *Assertion) Int64(value int64) *Int64Subject {
|
|
||||||
return NewInt64Subject(NewSubject(a), value)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (a *Assertion) Int(value int) *IntSubject {
|
|
||||||
return NewIntSubject(NewSubject(a), value)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (a *Assertion) Uint16(value uint16) *Uint16Subject {
|
|
||||||
return NewUint16Subject(NewSubject(a), value)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (a *Assertion) Byte(value byte) *ByteSubject {
|
|
||||||
return NewByteSubject(NewSubject(a), value)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (a *Assertion) Bytes(value []byte) *BytesSubject {
|
|
||||||
return NewBytesSubject(NewSubject(a), value)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (a *Assertion) String(value string) *StringSubject {
|
|
||||||
return NewStringSubject(NewSubject(a), value)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (a *Assertion) Error(value error) *ErrorSubject {
|
|
||||||
return NewErrorSubject(NewSubject(a), value)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (a *Assertion) Bool(value bool) *BoolSubject {
|
|
||||||
return NewBoolSubject(NewSubject(a), value)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (a *Assertion) Pointer(value interface{}) *PointerSubject {
|
|
||||||
return NewPointerSubject(NewSubject(a), value)
|
|
||||||
}
|
|
@ -1,76 +0,0 @@
|
|||||||
package unit
|
|
||||||
|
|
||||||
import (
|
|
||||||
"bytes"
|
|
||||||
"fmt"
|
|
||||||
"runtime"
|
|
||||||
"strings"
|
|
||||||
)
|
|
||||||
|
|
||||||
type Subject struct {
|
|
||||||
assert *Assertion
|
|
||||||
name string
|
|
||||||
}
|
|
||||||
|
|
||||||
func NewSubject(assert *Assertion) *Subject {
|
|
||||||
return &Subject{
|
|
||||||
assert: assert,
|
|
||||||
name: "",
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// decorate prefixes the string with the file and line of the call site
|
|
||||||
// and inserts the final newline if needed and indentation tabs for formatting.
|
|
||||||
func decorate(s string) string {
|
|
||||||
_, file, line, ok := runtime.Caller(3)
|
|
||||||
if strings.Contains(file, "testing") {
|
|
||||||
_, file, line, ok = runtime.Caller(4)
|
|
||||||
}
|
|
||||||
if ok {
|
|
||||||
// Truncate file name at last file name separator.
|
|
||||||
if index := strings.LastIndex(file, "/"); index >= 0 {
|
|
||||||
file = file[index+1:]
|
|
||||||
} else if index = strings.LastIndex(file, "\\"); index >= 0 {
|
|
||||||
file = file[index+1:]
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
file = "???"
|
|
||||||
line = 1
|
|
||||||
}
|
|
||||||
buf := new(bytes.Buffer)
|
|
||||||
// Every line is indented at least one tab.
|
|
||||||
buf.WriteString(" ")
|
|
||||||
fmt.Fprintf(buf, "%s:%d: ", file, line)
|
|
||||||
lines := strings.Split(s, "\n")
|
|
||||||
if l := len(lines); l > 1 && lines[l-1] == "" {
|
|
||||||
lines = lines[:l-1]
|
|
||||||
}
|
|
||||||
for i, line := range lines {
|
|
||||||
if i > 0 {
|
|
||||||
// Second and subsequent lines are indented an extra tab.
|
|
||||||
buf.WriteString("\n\t\t")
|
|
||||||
}
|
|
||||||
buf.WriteString(line)
|
|
||||||
}
|
|
||||||
buf.WriteByte('\n')
|
|
||||||
return buf.String()
|
|
||||||
}
|
|
||||||
|
|
||||||
func (subject *Subject) FailWithMessage(message string) {
|
|
||||||
fmt.Println(decorate(message))
|
|
||||||
subject.assert.t.Fail()
|
|
||||||
}
|
|
||||||
|
|
||||||
func (subject *Subject) Named(name string) {
|
|
||||||
subject.name = name
|
|
||||||
}
|
|
||||||
|
|
||||||
func (subject *Subject) DisplayString(value string) string {
|
|
||||||
if len(value) == 0 {
|
|
||||||
value = "unknown"
|
|
||||||
}
|
|
||||||
if len(subject.name) == 0 {
|
|
||||||
return "<" + value + ">"
|
|
||||||
}
|
|
||||||
return subject.name + "(<" + value + ">)"
|
|
||||||
}
|
|
@ -6,7 +6,7 @@ import (
|
|||||||
"path/filepath"
|
"path/filepath"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/v2ray/v2ray-core/testing/unit"
|
"github.com/v2ray/v2ray-core/testing/assert"
|
||||||
)
|
)
|
||||||
|
|
||||||
func cleanBinPath() {
|
func cleanBinPath() {
|
||||||
@ -31,7 +31,7 @@ func allFilesExists(files ...string) bool {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestBuildMacOS(t *testing.T) {
|
func TestBuildMacOS(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
binPath = filepath.Join(os.Getenv("GOPATH"), "testing")
|
binPath = filepath.Join(os.Getenv("GOPATH"), "testing")
|
||||||
cleanBinPath()
|
cleanBinPath()
|
||||||
|
|
||||||
|
@ -3,11 +3,11 @@ package main
|
|||||||
import (
|
import (
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/v2ray/v2ray-core/testing/unit"
|
"github.com/v2ray/v2ray-core/testing/assert"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestParseOS(t *testing.T) {
|
func TestParseOS(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
assert.Pointer(parseOS("windows")).Equals(Windows)
|
assert.Pointer(parseOS("windows")).Equals(Windows)
|
||||||
assert.Pointer(parseOS("macos")).Equals(MacOS)
|
assert.Pointer(parseOS("macos")).Equals(MacOS)
|
||||||
@ -16,7 +16,7 @@ func TestParseOS(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestParseArch(t *testing.T) {
|
func TestParseArch(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
assert.Pointer(parseArch("x86")).Equals(X86)
|
assert.Pointer(parseArch("x86")).Equals(X86)
|
||||||
assert.Pointer(parseArch("x64")).Equals(Amd64)
|
assert.Pointer(parseArch("x64")).Equals(Amd64)
|
||||||
|
@ -11,11 +11,11 @@ import (
|
|||||||
"testing"
|
"testing"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/v2ray/v2ray-core/testing/unit"
|
"github.com/v2ray/v2ray-core/testing/assert"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestBuildAndRun(t *testing.T) {
|
func TestBuildAndRun(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
gopath := os.Getenv("GOPATH")
|
gopath := os.Getenv("GOPATH")
|
||||||
target := filepath.Join(gopath, "src", "v2ray_test")
|
target := filepath.Join(gopath, "src", "v2ray_test")
|
||||||
|
@ -3,11 +3,11 @@ package git
|
|||||||
import (
|
import (
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/v2ray/v2ray-core/testing/unit"
|
"github.com/v2ray/v2ray-core/testing/assert"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestRevParse(t *testing.T) {
|
func TestRevParse(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
rev, err := RevParse("HEAD")
|
rev, err := RevParse("HEAD")
|
||||||
assert.Error(err).IsNil()
|
assert.Error(err).IsNil()
|
||||||
@ -15,7 +15,7 @@ func TestRevParse(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestRepoVersion(t *testing.T) {
|
func TestRepoVersion(t *testing.T) {
|
||||||
assert := unit.Assert(t)
|
v2testing.Current(t)
|
||||||
|
|
||||||
version, err := RepoVersionHead()
|
version, err := RepoVersionHead()
|
||||||
assert.Error(err).IsNil()
|
assert.Error(err).IsNil()
|
||||||
|
Loading…
Reference in New Issue
Block a user