| 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, 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, 4*1024)
 
- }
 
 
  |