|
@@ -2,28 +2,45 @@ package mux_test
|
|
|
|
|
|
|
|
import (
|
|
import (
|
|
|
"context"
|
|
"context"
|
|
|
|
|
+ "io"
|
|
|
"testing"
|
|
"testing"
|
|
|
|
|
|
|
|
. "v2ray.com/core/app/proxyman/mux"
|
|
. "v2ray.com/core/app/proxyman/mux"
|
|
|
"v2ray.com/core/common/buf"
|
|
"v2ray.com/core/common/buf"
|
|
|
"v2ray.com/core/common/net"
|
|
"v2ray.com/core/common/net"
|
|
|
|
|
+ "v2ray.com/core/common/protocol"
|
|
|
"v2ray.com/core/testing/assert"
|
|
"v2ray.com/core/testing/assert"
|
|
|
"v2ray.com/core/transport/ray"
|
|
"v2ray.com/core/transport/ray"
|
|
|
)
|
|
)
|
|
|
|
|
|
|
|
|
|
+func readAll(reader buf.Reader) (buf.MultiBuffer, error) {
|
|
|
|
|
+ mb := buf.NewMultiBuffer()
|
|
|
|
|
+ for {
|
|
|
|
|
+ b, err := reader.Read()
|
|
|
|
|
+ if err == io.EOF {
|
|
|
|
|
+ break
|
|
|
|
|
+ }
|
|
|
|
|
+ if err != nil {
|
|
|
|
|
+ return nil, err
|
|
|
|
|
+ }
|
|
|
|
|
+ mb.AppendMulti(b)
|
|
|
|
|
+ }
|
|
|
|
|
+ return mb, nil
|
|
|
|
|
+}
|
|
|
|
|
+
|
|
|
func TestReaderWriter(t *testing.T) {
|
|
func TestReaderWriter(t *testing.T) {
|
|
|
assert := assert.On(t)
|
|
assert := assert.On(t)
|
|
|
|
|
|
|
|
stream := ray.NewStream(context.Background())
|
|
stream := ray.NewStream(context.Background())
|
|
|
|
|
|
|
|
dest := net.TCPDestination(net.DomainAddress("v2ray.com"), 80)
|
|
dest := net.TCPDestination(net.DomainAddress("v2ray.com"), 80)
|
|
|
- writer := NewWriter(1, dest, stream)
|
|
|
|
|
|
|
+ writer := NewWriter(1, dest, stream, protocol.TransferTypeStream)
|
|
|
|
|
|
|
|
dest2 := net.TCPDestination(net.LocalHostIP, 443)
|
|
dest2 := net.TCPDestination(net.LocalHostIP, 443)
|
|
|
- writer2 := NewWriter(2, dest2, stream)
|
|
|
|
|
|
|
+ writer2 := NewWriter(2, dest2, stream, protocol.TransferTypeStream)
|
|
|
|
|
|
|
|
dest3 := net.TCPDestination(net.LocalHostIPv6, 18374)
|
|
dest3 := net.TCPDestination(net.LocalHostIPv6, 18374)
|
|
|
- writer3 := NewWriter(3, dest3, stream)
|
|
|
|
|
|
|
+ writer3 := NewWriter(3, dest3, stream, protocol.TransferTypeStream)
|
|
|
|
|
|
|
|
writePayload := func(writer *Writer, payload ...byte) error {
|
|
writePayload := func(writer *Writer, payload ...byte) error {
|
|
|
b := buf.New()
|
|
b := buf.New()
|
|
@@ -43,73 +60,76 @@ func TestReaderWriter(t *testing.T) {
|
|
|
assert.Error(writePayload(writer2, 'y')).IsNil()
|
|
assert.Error(writePayload(writer2, 'y')).IsNil()
|
|
|
writer2.Close()
|
|
writer2.Close()
|
|
|
|
|
|
|
|
- reader := NewReader(stream)
|
|
|
|
|
- meta, err := reader.ReadMetadata()
|
|
|
|
|
|
|
+ bytesReader := buf.ToBytesReader(stream)
|
|
|
|
|
+ metaReader := NewMetadataReader(bytesReader)
|
|
|
|
|
+ streamReader := NewStreamReader(bytesReader)
|
|
|
|
|
+
|
|
|
|
|
+ meta, err := metaReader.Read()
|
|
|
assert.Error(err).IsNil()
|
|
assert.Error(err).IsNil()
|
|
|
assert.Uint16(meta.SessionID).Equals(1)
|
|
assert.Uint16(meta.SessionID).Equals(1)
|
|
|
assert.Byte(byte(meta.SessionStatus)).Equals(byte(SessionStatusNew))
|
|
assert.Byte(byte(meta.SessionStatus)).Equals(byte(SessionStatusNew))
|
|
|
assert.Destination(meta.Target).Equals(dest)
|
|
assert.Destination(meta.Target).Equals(dest)
|
|
|
assert.Byte(byte(meta.Option)).Equals(byte(OptionData))
|
|
assert.Byte(byte(meta.Option)).Equals(byte(OptionData))
|
|
|
|
|
|
|
|
- data, err := reader.Read()
|
|
|
|
|
|
|
+ data, err := readAll(streamReader)
|
|
|
assert.Error(err).IsNil()
|
|
assert.Error(err).IsNil()
|
|
|
assert.Int(len(data)).Equals(1)
|
|
assert.Int(len(data)).Equals(1)
|
|
|
assert.String(data[0].String()).Equals("abcd")
|
|
assert.String(data[0].String()).Equals("abcd")
|
|
|
|
|
|
|
|
- meta, err = reader.ReadMetadata()
|
|
|
|
|
|
|
+ meta, err = metaReader.Read()
|
|
|
assert.Error(err).IsNil()
|
|
assert.Error(err).IsNil()
|
|
|
assert.Byte(byte(meta.SessionStatus)).Equals(byte(SessionStatusNew))
|
|
assert.Byte(byte(meta.SessionStatus)).Equals(byte(SessionStatusNew))
|
|
|
assert.Uint16(meta.SessionID).Equals(2)
|
|
assert.Uint16(meta.SessionID).Equals(2)
|
|
|
assert.Byte(byte(meta.Option)).Equals(0)
|
|
assert.Byte(byte(meta.Option)).Equals(0)
|
|
|
assert.Destination(meta.Target).Equals(dest2)
|
|
assert.Destination(meta.Target).Equals(dest2)
|
|
|
|
|
|
|
|
- meta, err = reader.ReadMetadata()
|
|
|
|
|
|
|
+ meta, err = metaReader.Read()
|
|
|
assert.Error(err).IsNil()
|
|
assert.Error(err).IsNil()
|
|
|
assert.Byte(byte(meta.SessionStatus)).Equals(byte(SessionStatusKeep))
|
|
assert.Byte(byte(meta.SessionStatus)).Equals(byte(SessionStatusKeep))
|
|
|
assert.Uint16(meta.SessionID).Equals(1)
|
|
assert.Uint16(meta.SessionID).Equals(1)
|
|
|
assert.Byte(byte(meta.Option)).Equals(1)
|
|
assert.Byte(byte(meta.Option)).Equals(1)
|
|
|
|
|
|
|
|
- data, err = reader.Read()
|
|
|
|
|
|
|
+ data, err = readAll(streamReader)
|
|
|
assert.Error(err).IsNil()
|
|
assert.Error(err).IsNil()
|
|
|
assert.Int(len(data)).Equals(1)
|
|
assert.Int(len(data)).Equals(1)
|
|
|
assert.String(data[0].String()).Equals("efgh")
|
|
assert.String(data[0].String()).Equals("efgh")
|
|
|
|
|
|
|
|
- meta, err = reader.ReadMetadata()
|
|
|
|
|
|
|
+ meta, err = metaReader.Read()
|
|
|
assert.Error(err).IsNil()
|
|
assert.Error(err).IsNil()
|
|
|
assert.Byte(byte(meta.SessionStatus)).Equals(byte(SessionStatusNew))
|
|
assert.Byte(byte(meta.SessionStatus)).Equals(byte(SessionStatusNew))
|
|
|
assert.Uint16(meta.SessionID).Equals(3)
|
|
assert.Uint16(meta.SessionID).Equals(3)
|
|
|
assert.Byte(byte(meta.Option)).Equals(1)
|
|
assert.Byte(byte(meta.Option)).Equals(1)
|
|
|
assert.Destination(meta.Target).Equals(dest3)
|
|
assert.Destination(meta.Target).Equals(dest3)
|
|
|
|
|
|
|
|
- data, err = reader.Read()
|
|
|
|
|
|
|
+ data, err = readAll(streamReader)
|
|
|
assert.Error(err).IsNil()
|
|
assert.Error(err).IsNil()
|
|
|
assert.Int(len(data)).Equals(1)
|
|
assert.Int(len(data)).Equals(1)
|
|
|
assert.String(data[0].String()).Equals("x")
|
|
assert.String(data[0].String()).Equals("x")
|
|
|
|
|
|
|
|
- meta, err = reader.ReadMetadata()
|
|
|
|
|
|
|
+ meta, err = metaReader.Read()
|
|
|
assert.Error(err).IsNil()
|
|
assert.Error(err).IsNil()
|
|
|
assert.Byte(byte(meta.SessionStatus)).Equals(byte(SessionStatusEnd))
|
|
assert.Byte(byte(meta.SessionStatus)).Equals(byte(SessionStatusEnd))
|
|
|
assert.Uint16(meta.SessionID).Equals(1)
|
|
assert.Uint16(meta.SessionID).Equals(1)
|
|
|
assert.Byte(byte(meta.Option)).Equals(0)
|
|
assert.Byte(byte(meta.Option)).Equals(0)
|
|
|
|
|
|
|
|
- meta, err = reader.ReadMetadata()
|
|
|
|
|
|
|
+ meta, err = metaReader.Read()
|
|
|
assert.Error(err).IsNil()
|
|
assert.Error(err).IsNil()
|
|
|
assert.Byte(byte(meta.SessionStatus)).Equals(byte(SessionStatusEnd))
|
|
assert.Byte(byte(meta.SessionStatus)).Equals(byte(SessionStatusEnd))
|
|
|
assert.Uint16(meta.SessionID).Equals(3)
|
|
assert.Uint16(meta.SessionID).Equals(3)
|
|
|
assert.Byte(byte(meta.Option)).Equals(0)
|
|
assert.Byte(byte(meta.Option)).Equals(0)
|
|
|
|
|
|
|
|
- meta, err = reader.ReadMetadata()
|
|
|
|
|
|
|
+ meta, err = metaReader.Read()
|
|
|
assert.Error(err).IsNil()
|
|
assert.Error(err).IsNil()
|
|
|
assert.Byte(byte(meta.SessionStatus)).Equals(byte(SessionStatusKeep))
|
|
assert.Byte(byte(meta.SessionStatus)).Equals(byte(SessionStatusKeep))
|
|
|
assert.Uint16(meta.SessionID).Equals(2)
|
|
assert.Uint16(meta.SessionID).Equals(2)
|
|
|
assert.Byte(byte(meta.Option)).Equals(1)
|
|
assert.Byte(byte(meta.Option)).Equals(1)
|
|
|
|
|
|
|
|
- data, err = reader.Read()
|
|
|
|
|
|
|
+ data, err = readAll(streamReader)
|
|
|
assert.Error(err).IsNil()
|
|
assert.Error(err).IsNil()
|
|
|
assert.Int(len(data)).Equals(1)
|
|
assert.Int(len(data)).Equals(1)
|
|
|
assert.String(data[0].String()).Equals("y")
|
|
assert.String(data[0].String()).Equals("y")
|
|
|
|
|
|
|
|
- meta, err = reader.ReadMetadata()
|
|
|
|
|
|
|
+ meta, err = metaReader.Read()
|
|
|
assert.Error(err).IsNil()
|
|
assert.Error(err).IsNil()
|
|
|
assert.Byte(byte(meta.SessionStatus)).Equals(byte(SessionStatusEnd))
|
|
assert.Byte(byte(meta.SessionStatus)).Equals(byte(SessionStatusEnd))
|
|
|
assert.Uint16(meta.SessionID).Equals(2)
|
|
assert.Uint16(meta.SessionID).Equals(2)
|
|
@@ -117,6 +137,6 @@ func TestReaderWriter(t *testing.T) {
|
|
|
|
|
|
|
|
stream.Close()
|
|
stream.Close()
|
|
|
|
|
|
|
|
- meta, err = reader.ReadMetadata()
|
|
|
|
|
|
|
+ meta, err = metaReader.Read()
|
|
|
assert.Error(err).IsNotNil()
|
|
assert.Error(err).IsNotNil()
|
|
|
}
|
|
}
|