ota_test.go 1.1 KB

1234567891011121314151617181920212223242526272829303132333435
  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.Write([]byte{0, 8, 39, 228, 69, 96, 133, 39, 254, 26, 201, 70, 11, 12, 13, 14, 15, 16, 17, 18})
  12. reader := NewChunkReader(buffer, NewAuthenticator(ChunkKeyGenerator(
  13. []byte{21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36})))
  14. payload, err := reader.ReadMultiBuffer()
  15. assert(err, IsNil)
  16. assert(payload[0].Bytes(), Equals, []byte{11, 12, 13, 14, 15, 16, 17, 18})
  17. }
  18. func TestNormalChunkWriting(t *testing.T) {
  19. assert := With(t)
  20. buffer := buf.New()
  21. writer := NewChunkWriter(buffer, NewAuthenticator(ChunkKeyGenerator(
  22. []byte{21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36})))
  23. b := buf.New()
  24. b.Write([]byte{11, 12, 13, 14, 15, 16, 17, 18})
  25. err := writer.WriteMultiBuffer(buf.NewMultiBufferValue(b))
  26. assert(err, IsNil)
  27. 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})
  28. }