|
|
@@ -0,0 +1,109 @@
|
|
|
+package io_test
|
|
|
+
|
|
|
+import (
|
|
|
+ "bytes"
|
|
|
+ "crypto/rand"
|
|
|
+ "io"
|
|
|
+ "testing"
|
|
|
+
|
|
|
+ "github.com/v2ray/v2ray-core/common/alloc"
|
|
|
+ v2io "github.com/v2ray/v2ray-core/common/io"
|
|
|
+ . "github.com/v2ray/v2ray-core/proxy/vmess/io"
|
|
|
+ v2testing "github.com/v2ray/v2ray-core/testing"
|
|
|
+ "github.com/v2ray/v2ray-core/testing/assert"
|
|
|
+)
|
|
|
+
|
|
|
+func TestAuthenticate(t *testing.T) {
|
|
|
+ v2testing.Current(t)
|
|
|
+
|
|
|
+ buffer := alloc.NewBuffer().Clear()
|
|
|
+ buffer.AppendBytes(1, 2, 3, 4)
|
|
|
+ Authenticate(buffer)
|
|
|
+ assert.Bytes(buffer.Value).Equals([]byte{0, 8, 87, 52, 168, 125, 1, 2, 3, 4})
|
|
|
+
|
|
|
+ b2, err := NewAuthChunkReader(buffer).Read()
|
|
|
+ assert.Error(err).IsNil()
|
|
|
+ assert.Bytes(b2.Value).Equals([]byte{1, 2, 3, 4})
|
|
|
+}
|
|
|
+
|
|
|
+func TestSingleIO(t *testing.T) {
|
|
|
+ v2testing.Current(t)
|
|
|
+
|
|
|
+ content := bytes.NewBuffer(make([]byte, 0, 1024*1024))
|
|
|
+
|
|
|
+ writer := NewAuthChunkWriter(v2io.NewAdaptiveWriter(content))
|
|
|
+ writer.Write(alloc.NewBuffer().Clear().AppendString("abcd"))
|
|
|
+ writer.Release()
|
|
|
+
|
|
|
+ reader := NewAuthChunkReader(content)
|
|
|
+ buffer, err := reader.Read()
|
|
|
+ assert.Error(err).IsNil()
|
|
|
+ assert.Bytes(buffer.Value).Equals([]byte("abcd"))
|
|
|
+}
|
|
|
+
|
|
|
+func TestLargeIO(t *testing.T) {
|
|
|
+ v2testing.Current(t)
|
|
|
+
|
|
|
+ content := make([]byte, 1024*1024)
|
|
|
+ rand.Read(content)
|
|
|
+
|
|
|
+ chunckContent := bytes.NewBuffer(make([]byte, 0, len(content)*2))
|
|
|
+ writer := NewAuthChunkWriter(v2io.NewAdaptiveWriter(chunckContent))
|
|
|
+ writeSize := 0
|
|
|
+ for {
|
|
|
+ chunkSize := 7 * 1024
|
|
|
+ if chunkSize+writeSize > len(content) {
|
|
|
+ chunkSize = len(content) - writeSize
|
|
|
+ }
|
|
|
+ writer.Write(alloc.NewBuffer().Clear().Append(content[writeSize : writeSize+chunkSize]))
|
|
|
+ writeSize += chunkSize
|
|
|
+ if writeSize == len(content) {
|
|
|
+ break
|
|
|
+ }
|
|
|
+
|
|
|
+ chunkSize = 8 * 1024
|
|
|
+ if chunkSize+writeSize > len(content) {
|
|
|
+ chunkSize = len(content) - writeSize
|
|
|
+ }
|
|
|
+ writer.Write(alloc.NewLargeBuffer().Clear().Append(content[writeSize : writeSize+chunkSize]))
|
|
|
+ writeSize += chunkSize
|
|
|
+ if writeSize == len(content) {
|
|
|
+ break
|
|
|
+ }
|
|
|
+
|
|
|
+ chunkSize = 63 * 1024
|
|
|
+ if chunkSize+writeSize > len(content) {
|
|
|
+ chunkSize = len(content) - writeSize
|
|
|
+ }
|
|
|
+ writer.Write(alloc.NewLargeBuffer().Clear().Append(content[writeSize : writeSize+chunkSize]))
|
|
|
+ writeSize += chunkSize
|
|
|
+ if writeSize == len(content) {
|
|
|
+ break
|
|
|
+ }
|
|
|
+
|
|
|
+ chunkSize = 64*1024 - 16
|
|
|
+ if chunkSize+writeSize > len(content) {
|
|
|
+ chunkSize = len(content) - writeSize
|
|
|
+ }
|
|
|
+ writer.Write(alloc.NewLargeBuffer().Clear().Append(content[writeSize : writeSize+chunkSize]))
|
|
|
+ writeSize += chunkSize
|
|
|
+ if writeSize == len(content) {
|
|
|
+ break
|
|
|
+ }
|
|
|
+ }
|
|
|
+ writer.Release()
|
|
|
+
|
|
|
+ actualContent := make([]byte, 0, len(content))
|
|
|
+ reader := NewAuthChunkReader(chunckContent)
|
|
|
+ for {
|
|
|
+ buffer, err := reader.Read()
|
|
|
+ if err == io.EOF {
|
|
|
+ break
|
|
|
+ }
|
|
|
+ assert.Error(err).IsNil()
|
|
|
+ actualContent = append(actualContent, buffer.Value...)
|
|
|
+ }
|
|
|
+
|
|
|
+ assert.Int(len(actualContent)).Equals(len(content))
|
|
|
+ assert.Bytes(actualContent).Equals(content)
|
|
|
+}
|