| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950 |
- package buf_test
- import (
- "crypto/rand"
- "testing"
- "v2ray.com/core/common"
- . "v2ray.com/core/common/buf"
- . "v2ray.com/ext/assert"
- )
- func TestMultiBufferRead(t *testing.T) {
- assert := With(t)
- b1 := New()
- b1.AppendBytes('a', 'b')
- b2 := New()
- b2.AppendBytes('c', 'd')
- mb := NewMultiBufferValue(b1, b2)
- bs := make([]byte, 32)
- nBytes, err := mb.Read(bs)
- assert(err, IsNil)
- assert(nBytes, Equals, 4)
- assert(bs[:nBytes], Equals, []byte("abcd"))
- }
- func TestMultiBufferAppend(t *testing.T) {
- assert := With(t)
- var mb MultiBuffer
- b := New()
- b.AppendBytes('a', 'b')
- mb.Append(b)
- assert(mb.Len(), Equals, int32(2))
- }
- func TestMultiBufferSliceBySizeLarge(t *testing.T) {
- assert := With(t)
- lb := NewSize(8 * 1024)
- common.Must(lb.Reset(ReadFrom(rand.Reader)))
- var mb MultiBuffer
- mb.Append(lb)
- mb2 := mb.SliceBySize(4 * 1024)
- assert(mb2.Len(), Equals, int32(4*1024))
- }
|