| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950 | package buf_testimport (	"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)}
 |