ota_test.go 1.1 KB

123456789101112131415161718192021222324252627282930313233343536
  1. package shadowsocks_test
  2. import (
  3. "testing"
  4. "v2ray.com/core/common/buf"
  5. . "v2ray.com/core/proxy/shadowsocks"
  6. . "v2ray.com/ext/assert"
  7. )
  8. func TestNormalChunkReading(t *testing.T) {
  9. assert := With(t)
  10. buffer := buf.New()
  11. buffer.WriteBytes(
  12. 0, 8, 39, 228, 69, 96, 133, 39, 254, 26, 201, 70, 11, 12, 13, 14, 15, 16, 17, 18)
  13. reader := NewChunkReader(buffer, NewAuthenticator(ChunkKeyGenerator(
  14. []byte{21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36})))
  15. payload, err := reader.ReadMultiBuffer()
  16. assert(err, IsNil)
  17. assert(payload[0].Bytes(), Equals, []byte{11, 12, 13, 14, 15, 16, 17, 18})
  18. }
  19. func TestNormalChunkWriting(t *testing.T) {
  20. assert := With(t)
  21. buffer := buf.New()
  22. writer := NewChunkWriter(buffer, NewAuthenticator(ChunkKeyGenerator(
  23. []byte{21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36})))
  24. b := buf.New()
  25. b.Write([]byte{11, 12, 13, 14, 15, 16, 17, 18})
  26. err := writer.WriteMultiBuffer(buf.NewMultiBufferValue(b))
  27. assert(err, IsNil)
  28. assert(buffer.Bytes(), Equals, []byte{0, 8, 39, 228, 69, 96, 133, 39, 254, 26, 201, 70, 11, 12, 13, 14, 15, 16, 17, 18})
  29. }