2016-01-22 10:25:01 -05:00
|
|
|
package scenarios
|
|
|
|
|
|
|
|
import (
|
2016-05-04 18:24:18 -04:00
|
|
|
"bytes"
|
|
|
|
"io"
|
2016-01-22 10:25:01 -05:00
|
|
|
"net"
|
|
|
|
"testing"
|
|
|
|
|
2016-08-20 14:55:45 -04:00
|
|
|
v2net "v2ray.com/core/common/net"
|
|
|
|
"v2ray.com/core/testing/assert"
|
|
|
|
"v2ray.com/core/testing/servers/tcp"
|
2016-01-22 10:25:01 -05:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestDynamicVMess(t *testing.T) {
|
2016-05-24 15:55:46 -04:00
|
|
|
assert := assert.On(t)
|
2016-01-22 10:25:01 -05:00
|
|
|
|
|
|
|
tcpServer := &tcp.Server{
|
|
|
|
Port: v2net.Port(50032),
|
|
|
|
MsgProcessor: func(data []byte) []byte {
|
|
|
|
buffer := make([]byte, 0, 2048)
|
|
|
|
buffer = append(buffer, []byte("Processed: ")...)
|
|
|
|
buffer = append(buffer, data...)
|
|
|
|
return buffer
|
|
|
|
},
|
|
|
|
}
|
|
|
|
_, err := tcpServer.Start()
|
|
|
|
assert.Error(err).IsNil()
|
|
|
|
defer tcpServer.Close()
|
|
|
|
|
|
|
|
assert.Error(InitializeServerSetOnce("test_4")).IsNil()
|
|
|
|
|
|
|
|
for i := 0; i < 100; i++ {
|
|
|
|
conn, err := net.DialTCP("tcp", nil, &net.TCPAddr{
|
|
|
|
IP: []byte{127, 0, 0, 1},
|
|
|
|
Port: 50030,
|
|
|
|
})
|
|
|
|
assert.Error(err).IsNil()
|
|
|
|
|
|
|
|
payload := "dokodemo request."
|
|
|
|
nBytes, err := conn.Write([]byte(payload))
|
|
|
|
assert.Error(err).IsNil()
|
|
|
|
assert.Int(nBytes).Equals(len(payload))
|
|
|
|
|
|
|
|
conn.CloseWrite()
|
|
|
|
|
2016-05-04 18:24:18 -04:00
|
|
|
response := bytes.NewBuffer(nil)
|
|
|
|
_, err = io.Copy(response, conn)
|
2016-01-22 10:25:01 -05:00
|
|
|
assert.Error(err).IsNil()
|
2016-05-24 15:55:46 -04:00
|
|
|
assert.String("Processed: " + payload).Equals(string(response.Bytes()))
|
2016-01-22 10:25:01 -05:00
|
|
|
|
|
|
|
conn.Close()
|
|
|
|
}
|
|
|
|
|
|
|
|
CloseAllServers()
|
|
|
|
}
|