| 1234567891011121314151617181920212223242526272829303132333435363738394041424344 | package mtproto_testimport (	"bytes"	"crypto/rand"	"testing"	"v2ray.com/core/common"	"v2ray.com/core/common/compare"	. "v2ray.com/core/proxy/mtproto"	. "v2ray.com/ext/assert")func TestInverse(t *testing.T) {	const size = 64	b := make([]byte, 64)	for b[0] == b[size-1] {		common.Must2(rand.Read(b))	}	bi := Inverse(b)	if b[0] == bi[0] {		t.Fatal("seems bytes are not inversed: ", b[0], "vs", bi[0])	}	bii := Inverse(bi)	if err := compare.BytesEqualWithDetail(bii, b); err != nil {		t.Fatal(err)	}}func TestAuthenticationReadWrite(t *testing.T) {	assert := With(t)	a := NewAuthentication()	b := bytes.NewReader(a.Header[:])	a2, err := ReadAuthentication(b)	assert(err, IsNil)	assert(a.EncodingKey[:], Equals, a2.DecodingKey[:])	assert(a.EncodingNonce[:], Equals, a2.DecodingNonce[:])	assert(a.DecodingKey[:], Equals, a2.EncodingKey[:])	assert(a.DecodingNonce[:], Equals, a2.EncodingNonce[:])}
 |