mirror of
https://github.com/v2fly/v2ray-core.git
synced 2024-12-30 05:56:54 -05:00
test case for net.vmess
This commit is contained in:
parent
ab723fa0b5
commit
76200e2764
75
net/vmess/vmess_test.go
Normal file
75
net/vmess/vmess_test.go
Normal file
@ -0,0 +1,75 @@
|
|||||||
|
package vmess
|
||||||
|
|
||||||
|
import (
|
||||||
|
"bytes"
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
"github.com/v2ray/v2ray-core"
|
||||||
|
v2net "github.com/v2ray/v2ray-core/net"
|
||||||
|
"github.com/v2ray/v2ray-core/testing/mocks"
|
||||||
|
"github.com/v2ray/v2ray-core/testing/unit"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestVMessInAndOut(t *testing.T) {
|
||||||
|
assert := unit.Assert(t)
|
||||||
|
|
||||||
|
data2Send := "The data to be send to outbound server."
|
||||||
|
|
||||||
|
portA := uint16(17392)
|
||||||
|
ich := &mocks.InboundConnectionHandler{
|
||||||
|
Data2Send: []byte(data2Send),
|
||||||
|
DataReturned: bytes.NewBuffer(make([]byte, 0, 1024)),
|
||||||
|
}
|
||||||
|
|
||||||
|
core.RegisterInboundConnectionHandlerFactory("mock_ich", ich)
|
||||||
|
|
||||||
|
configA := mocks.Config{
|
||||||
|
PortValue: portA,
|
||||||
|
InboundConfigValue: &mocks.ConnectionConfig{
|
||||||
|
ProtocolValue: "mock_ich",
|
||||||
|
ContentValue: nil,
|
||||||
|
},
|
||||||
|
OutboundConfigValue: &mocks.ConnectionConfig{
|
||||||
|
ProtocolValue: "vmess",
|
||||||
|
ContentValue: []byte("{\"vnext\":[{\"address\": \"127.0.0.1\", \"port\": 13829, \"users\":[{\"id\": \"ad937d9d-6e23-4a5a-ba23-bce5092a7c51\"}]}]}"),
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
pointA, err := core.NewPoint(&configA)
|
||||||
|
assert.Error(err).IsNil()
|
||||||
|
|
||||||
|
err = pointA.Start()
|
||||||
|
assert.Error(err).IsNil()
|
||||||
|
|
||||||
|
portB := uint16(13829)
|
||||||
|
|
||||||
|
och := &mocks.OutboundConnectionHandler{
|
||||||
|
Data2Send: bytes.NewBuffer(make([]byte, 0, 1024)),
|
||||||
|
Data2Return: []byte("The data to be returned to inbound server."),
|
||||||
|
}
|
||||||
|
|
||||||
|
core.RegisterOutboundConnectionHandlerFactory("mock_och", och)
|
||||||
|
|
||||||
|
configB := mocks.Config{
|
||||||
|
PortValue: portB,
|
||||||
|
InboundConfigValue: &mocks.ConnectionConfig{
|
||||||
|
ProtocolValue: "vmess",
|
||||||
|
ContentValue: []byte("{\"clients\": [{\"id\": \"ad937d9d-6e23-4a5a-ba23-bce5092a7c51\"}]}"),
|
||||||
|
},
|
||||||
|
OutboundConfigValue: &mocks.ConnectionConfig{
|
||||||
|
ProtocolValue: "mock_och",
|
||||||
|
ContentValue: nil,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
pointB, err := core.NewPoint(&configB)
|
||||||
|
assert.Error(err).IsNil()
|
||||||
|
|
||||||
|
err = pointB.Start()
|
||||||
|
assert.Error(err).IsNil()
|
||||||
|
|
||||||
|
dest := v2net.IPAddress([]byte{1, 2, 3, 4}, 80)
|
||||||
|
ich.Communicate(dest)
|
||||||
|
assert.Bytes([]byte(data2Send)).Equals(och.Data2Send.Bytes())
|
||||||
|
assert.Bytes(ich.DataReturned.Bytes()).Equals(och.Data2Return)
|
||||||
|
}
|
38
testing/mocks/inboundhandler.go
Normal file
38
testing/mocks/inboundhandler.go
Normal file
@ -0,0 +1,38 @@
|
|||||||
|
package mocks
|
||||||
|
|
||||||
|
import (
|
||||||
|
"bytes"
|
||||||
|
|
||||||
|
"github.com/v2ray/v2ray-core"
|
||||||
|
v2net "github.com/v2ray/v2ray-core/net"
|
||||||
|
)
|
||||||
|
|
||||||
|
type InboundConnectionHandler struct {
|
||||||
|
Data2Send []byte
|
||||||
|
DataReturned *bytes.Buffer
|
||||||
|
Port uint16
|
||||||
|
Server *core.Point
|
||||||
|
}
|
||||||
|
|
||||||
|
func (handler *InboundConnectionHandler) Listen(port uint16) error {
|
||||||
|
handler.Port = port
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (handler *InboundConnectionHandler) Communicate(dest v2net.Address) error {
|
||||||
|
ray := handler.Server.NewInboundConnectionAccepted(dest)
|
||||||
|
|
||||||
|
input := ray.InboundInput()
|
||||||
|
output := ray.InboundOutput()
|
||||||
|
|
||||||
|
input <- handler.Data2Send
|
||||||
|
close(input)
|
||||||
|
|
||||||
|
v2net.ChanToWriter(handler.DataReturned, output)
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (handler *InboundConnectionHandler) Create(point *core.Point, config []byte) (core.InboundConnectionHandler, error) {
|
||||||
|
handler.Server = point
|
||||||
|
return handler, nil
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user