mirror of
https://github.com/v2fly/v2ray-core.git
synced 2025-01-04 16:37:12 -05:00
Unit test library to simplify test writing
This commit is contained in:
parent
526c3d3a9b
commit
08a96e5fe1
@ -3,9 +3,13 @@ package socks
|
|||||||
import (
|
import (
|
||||||
"bytes"
|
"bytes"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
|
"github.com/v2ray/v2ray-core/testing/unit"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestAuthenticationRequestRead(t *testing.T) {
|
func TestAuthenticationRequestRead(t *testing.T) {
|
||||||
|
assert := unit.Assert(t)
|
||||||
|
|
||||||
rawRequest := []byte{
|
rawRequest := []byte{
|
||||||
0x05, // version
|
0x05, // version
|
||||||
0x01, // nMethods
|
0x01, // nMethods
|
||||||
@ -15,31 +19,26 @@ func TestAuthenticationRequestRead(t *testing.T) {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
t.Errorf("Unexpected error %v", err)
|
t.Errorf("Unexpected error %v", err)
|
||||||
}
|
}
|
||||||
if request.version != 0x05 {
|
assert.Byte(request.version).Named("Version").Equals(0x05)
|
||||||
t.Errorf("Expected version 5, but got %d", request.version)
|
assert.Byte(request.nMethods).Named("#Methods").Equals(0x01)
|
||||||
}
|
assert.Byte(request.authMethods[0]).Named("Auth Method").Equals(0x02)
|
||||||
if request.nMethods != 0x01 {
|
|
||||||
t.Errorf("Expected nMethod 1, but got %d", request.nMethods)
|
|
||||||
}
|
|
||||||
if request.authMethods[0] != 0x02 {
|
|
||||||
t.Errorf("Expected method 2, but got %d", request.authMethods[0])
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestAuthenticationResponseToBytes(t *testing.T) {
|
func TestAuthenticationResponseToBytes(t *testing.T) {
|
||||||
|
assert := unit.Assert(t)
|
||||||
|
|
||||||
socksVersion := uint8(5)
|
socksVersion := uint8(5)
|
||||||
authMethod := uint8(1)
|
authMethod := uint8(1)
|
||||||
response := Socks5AuthenticationResponse{socksVersion, authMethod}
|
response := Socks5AuthenticationResponse{socksVersion, authMethod}
|
||||||
bytes := response.ToBytes()
|
bytes := response.ToBytes()
|
||||||
if bytes[0] != socksVersion {
|
|
||||||
t.Errorf("Unexpected Socks version %d", bytes[0])
|
assert.Byte(bytes[0]).Named("Version").Equals(socksVersion)
|
||||||
}
|
assert.Byte(bytes[1]).Named("Auth Method").Equals(authMethod)
|
||||||
if bytes[1] != authMethod {
|
|
||||||
t.Errorf("Unexpected Socks auth method %d", bytes[1])
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestRequestRead(t *testing.T) {
|
func TestRequestRead(t *testing.T) {
|
||||||
|
assert := unit.Assert(t)
|
||||||
|
|
||||||
rawRequest := []byte{
|
rawRequest := []byte{
|
||||||
0x05, // version
|
0x05, // version
|
||||||
0x01, // cmd connect
|
0x01, // cmd connect
|
||||||
@ -52,24 +51,16 @@ func TestRequestRead(t *testing.T) {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
t.Errorf("Unexpected error %v", err)
|
t.Errorf("Unexpected error %v", err)
|
||||||
}
|
}
|
||||||
if request.Version != 0x05 {
|
assert.Byte(request.Version).Named("Version").Equals(0x05)
|
||||||
t.Errorf("Expected version 5, but got %d", request.Version)
|
assert.Byte(request.Command).Named("Command").Equals(0x01)
|
||||||
}
|
assert.Byte(request.AddrType).Named("Address Type").Equals(0x01)
|
||||||
if request.Command != 0x01 {
|
assert.Bytes(request.IPv4[:]).Named("IPv4").Equals([]byte{0x72, 0x72, 0x72, 0x72})
|
||||||
t.Errorf("Expected command 1, but got %d", request.Command)
|
assert.Uint16(request.Port).Named("Port").Equals(53)
|
||||||
}
|
|
||||||
if request.AddrType != 0x01 {
|
|
||||||
t.Errorf("Expected addresstype 1, but got %d", request.AddrType)
|
|
||||||
}
|
|
||||||
if !bytes.Equal([]byte{0x72, 0x72, 0x72, 0x72}, request.IPv4[:]) {
|
|
||||||
t.Errorf("Expected IPv4 address 114.114.114.114, but got %v", request.IPv4[:])
|
|
||||||
}
|
|
||||||
if request.Port != 53 {
|
|
||||||
t.Errorf("Expected port 53, but got %d", request.Port)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestResponseToBytes(t *testing.T) {
|
func TestResponseToBytes(t *testing.T) {
|
||||||
|
assert := unit.Assert(t)
|
||||||
|
|
||||||
response := Socks5Response{
|
response := Socks5Response{
|
||||||
socksVersion,
|
socksVersion,
|
||||||
ErrorSuccess,
|
ErrorSuccess,
|
||||||
@ -88,7 +79,5 @@ func TestResponseToBytes(t *testing.T) {
|
|||||||
0x72, 0x72, 0x72, 0x72,
|
0x72, 0x72, 0x72, 0x72,
|
||||||
byte(0x00), byte(0x035),
|
byte(0x00), byte(0x035),
|
||||||
}
|
}
|
||||||
if !bytes.Equal(rawResponse, expectedBytes) {
|
assert.Bytes(rawResponse).Named("raw response").Equals(expectedBytes)
|
||||||
t.Errorf("Expected response %v, but got %v", expectedBytes, rawResponse)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
31
testing/unit/assertions.go
Normal file
31
testing/unit/assertions.go
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
package unit
|
||||||
|
|
||||||
|
import (
|
||||||
|
"testing"
|
||||||
|
)
|
||||||
|
|
||||||
|
type Assertion struct {
|
||||||
|
t *testing.T
|
||||||
|
}
|
||||||
|
|
||||||
|
func Assert(t *testing.T) *Assertion {
|
||||||
|
assert := new(Assertion)
|
||||||
|
assert.t = t
|
||||||
|
return assert
|
||||||
|
}
|
||||||
|
|
||||||
|
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)
|
||||||
|
}
|
38
testing/unit/bytessubject.go
Normal file
38
testing/unit/bytessubject.go
Normal file
@ -0,0 +1,38 @@
|
|||||||
|
package unit
|
||||||
|
|
||||||
|
import (
|
||||||
|
"bytes"
|
||||||
|
"fmt"
|
||||||
|
)
|
||||||
|
|
||||||
|
type BytesSubject struct {
|
||||||
|
*Subject
|
||||||
|
value []byte
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewBytesSubject(base *Subject, value []byte) *BytesSubject {
|
||||||
|
subject := new(BytesSubject)
|
||||||
|
subject.Subject = base
|
||||||
|
subject.value = value
|
||||||
|
return subject
|
||||||
|
}
|
||||||
|
|
||||||
|
func (subject *BytesSubject) Named(name string) *BytesSubject {
|
||||||
|
subject.Subject.Named(name)
|
||||||
|
return subject
|
||||||
|
}
|
||||||
|
|
||||||
|
func (subject *BytesSubject) Fail(verb string, other []byte) {
|
||||||
|
otherString := fmt.Sprintf("%v", other)
|
||||||
|
subject.FailWithMessage("Not true that " + subject.DisplayString() + " " + verb + " <" + otherString + ">.")
|
||||||
|
}
|
||||||
|
|
||||||
|
func (subject *BytesSubject) DisplayString() string {
|
||||||
|
return subject.Subject.DisplayString(fmt.Sprintf("%v", subject.value))
|
||||||
|
}
|
||||||
|
|
||||||
|
func (subject *BytesSubject) Equals(expectation []byte) {
|
||||||
|
if !bytes.Equal(subject.value, expectation) {
|
||||||
|
subject.Fail("is equal to", expectation)
|
||||||
|
}
|
||||||
|
}
|
48
testing/unit/bytesubject.go
Normal file
48
testing/unit/bytesubject.go
Normal file
@ -0,0 +1,48 @@
|
|||||||
|
package unit
|
||||||
|
|
||||||
|
import (
|
||||||
|
"strconv"
|
||||||
|
)
|
||||||
|
|
||||||
|
type ByteSubject struct {
|
||||||
|
*Subject
|
||||||
|
value byte
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewByteSubject(base *Subject, value byte) *ByteSubject {
|
||||||
|
subject := new(ByteSubject)
|
||||||
|
subject.Subject = base
|
||||||
|
subject.value = value
|
||||||
|
return subject
|
||||||
|
}
|
||||||
|
|
||||||
|
func (subject *ByteSubject) Named(name string) *ByteSubject {
|
||||||
|
subject.Subject.Named(name)
|
||||||
|
return subject
|
||||||
|
}
|
||||||
|
|
||||||
|
func (subject *ByteSubject) Fail(verb string, other byte) {
|
||||||
|
subject.FailWithMessage("Not true that " + subject.DisplayString() + " " + verb + " <" + strconv.Itoa(int(other)) + ">.")
|
||||||
|
}
|
||||||
|
|
||||||
|
func (subject *ByteSubject) DisplayString() string {
|
||||||
|
return subject.Subject.DisplayString(strconv.Itoa(int(subject.value)))
|
||||||
|
}
|
||||||
|
|
||||||
|
func (subject *ByteSubject) Equals(expectation byte) {
|
||||||
|
if subject.value != expectation {
|
||||||
|
subject.Fail("is equal to", expectation)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (subject *ByteSubject) GreaterThan(expectation byte) {
|
||||||
|
if subject.value <= expectation {
|
||||||
|
subject.Fail("is greater than", expectation)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (subject *ByteSubject) LessThan(expectation byte) {
|
||||||
|
if subject.value >= expectation {
|
||||||
|
subject.Fail("is less than", expectation)
|
||||||
|
}
|
||||||
|
}
|
48
testing/unit/intsubject.go
Normal file
48
testing/unit/intsubject.go
Normal file
@ -0,0 +1,48 @@
|
|||||||
|
package unit
|
||||||
|
|
||||||
|
import (
|
||||||
|
"strconv"
|
||||||
|
)
|
||||||
|
|
||||||
|
type IntSubject struct {
|
||||||
|
*Subject
|
||||||
|
value int
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewIntSubject(base *Subject, value int) *IntSubject {
|
||||||
|
subject := new(IntSubject)
|
||||||
|
subject.Subject = base
|
||||||
|
subject.value = value
|
||||||
|
return subject
|
||||||
|
}
|
||||||
|
|
||||||
|
func (subject *IntSubject) Named(name string) *IntSubject {
|
||||||
|
subject.Subject.Named(name)
|
||||||
|
return subject
|
||||||
|
}
|
||||||
|
|
||||||
|
func (subject *IntSubject) Fail(verb string, other int) {
|
||||||
|
subject.FailWithMessage("Not true that " + subject.DisplayString() + " " + verb + " <" + strconv.Itoa(other) + ">.")
|
||||||
|
}
|
||||||
|
|
||||||
|
func (subject *IntSubject) DisplayString() string {
|
||||||
|
return subject.Subject.DisplayString(strconv.Itoa(subject.value))
|
||||||
|
}
|
||||||
|
|
||||||
|
func (subject *IntSubject) Equals(expectation int) {
|
||||||
|
if subject.value != expectation {
|
||||||
|
subject.Fail("is equal to", expectation)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (subject *IntSubject) GreaterThan(expectation int) {
|
||||||
|
if subject.value <= expectation {
|
||||||
|
subject.Fail("is greater than", expectation)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (subject *IntSubject) LessThan(expectation int) {
|
||||||
|
if subject.value >= expectation {
|
||||||
|
subject.Fail("is less than", expectation)
|
||||||
|
}
|
||||||
|
}
|
31
testing/unit/subject.go
Normal file
31
testing/unit/subject.go
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
package unit
|
||||||
|
|
||||||
|
type Subject struct {
|
||||||
|
assert *Assertion
|
||||||
|
name string
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewSubject(assert *Assertion) *Subject {
|
||||||
|
subject := new(Subject)
|
||||||
|
subject.assert = assert
|
||||||
|
subject.name = ""
|
||||||
|
return subject
|
||||||
|
}
|
||||||
|
|
||||||
|
func (subject *Subject) FailWithMessage(message string) {
|
||||||
|
subject.assert.t.Error(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 + ">)"
|
||||||
|
}
|
48
testing/unit/uint16subject.go
Normal file
48
testing/unit/uint16subject.go
Normal file
@ -0,0 +1,48 @@
|
|||||||
|
package unit
|
||||||
|
|
||||||
|
import (
|
||||||
|
"strconv"
|
||||||
|
)
|
||||||
|
|
||||||
|
type Uint16Subject struct {
|
||||||
|
*Subject
|
||||||
|
value uint16
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewUint16Subject(base *Subject, value uint16) *Uint16Subject {
|
||||||
|
subject := new(Uint16Subject)
|
||||||
|
subject.Subject = base
|
||||||
|
subject.value = value
|
||||||
|
return subject
|
||||||
|
}
|
||||||
|
|
||||||
|
func (subject *Uint16Subject) Named(name string) *Uint16Subject {
|
||||||
|
subject.Subject.Named(name)
|
||||||
|
return subject
|
||||||
|
}
|
||||||
|
|
||||||
|
func (subject *Uint16Subject) Fail(verb string, other uint16) {
|
||||||
|
subject.FailWithMessage("Not true that " + subject.DisplayString() + " " + verb + " <" + strconv.Itoa(int(other)) + ">.")
|
||||||
|
}
|
||||||
|
|
||||||
|
func (subject *Uint16Subject) DisplayString() string {
|
||||||
|
return subject.Subject.DisplayString(strconv.Itoa(int(subject.value)))
|
||||||
|
}
|
||||||
|
|
||||||
|
func (subject *Uint16Subject) Equals(expectation uint16) {
|
||||||
|
if subject.value != expectation {
|
||||||
|
subject.Fail("is equal to", expectation)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (subject *Uint16Subject) GreaterThan(expectation uint16) {
|
||||||
|
if subject.value <= expectation {
|
||||||
|
subject.Fail("is greater than", expectation)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (subject *Uint16Subject) LessThan(expectation uint16) {
|
||||||
|
if subject.value >= expectation {
|
||||||
|
subject.Fail("is less than", expectation)
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user