mirror of https://github.com/v2ray/v2ray-core
				
				
				
			massive refactoring against unit test lib
							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) | ||||||
|  |  | ||||||
|  | @ -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,17 +1,14 @@ | ||||||
| package unit | package assert | ||||||
|  | 
 | ||||||
|  | func Error(value error) *ErrorSubject { | ||||||
|  | 	return &ErrorSubject{value: value} | ||||||
|  | } | ||||||
| 
 | 
 | ||||||
| type ErrorSubject struct { | type ErrorSubject struct { | ||||||
| 	*Subject | 	Subject | ||||||
| 	value error | 	value error | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func NewErrorSubject(base *Subject, value error) *ErrorSubject { |  | ||||||
| 	return &ErrorSubject{ |  | ||||||
| 		Subject: base, |  | ||||||
| 		value:   value, |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| func (subject *ErrorSubject) Named(name string) *ErrorSubject { | func (subject *ErrorSubject) Named(name string) *ErrorSubject { | ||||||
| 	subject.Subject.Named(name) | 	subject.Subject.Named(name) | ||||||
| 	return subject | 	return subject | ||||||
|  | @ -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,17 +1,14 @@ | ||||||
| package unit | package assert | ||||||
|  | 
 | ||||||
|  | func String(value string) *StringSubject { | ||||||
|  | 	return &StringSubject{value: value} | ||||||
|  | } | ||||||
| 
 | 
 | ||||||
| type StringSubject struct { | type StringSubject struct { | ||||||
| 	*Subject | 	Subject | ||||||
| 	value string | 	value string | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func NewStringSubject(base *Subject, value string) *StringSubject { |  | ||||||
| 	return &StringSubject{ |  | ||||||
| 		Subject: base, |  | ||||||
| 		value:   value, |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| func (subject *StringSubject) Named(name string) *StringSubject { | func (subject *StringSubject) Named(name string) *StringSubject { | ||||||
| 	subject.Subject.Named(name) | 	subject.Subject.Named(name) | ||||||
| 	return subject | 	return subject | ||||||
|  | @ -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 { | ||||||
|  | @ -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
	
	 Darien Raymond
						Darien Raymond