| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152 | package mtproto_testimport (	"bytes"	"crypto/rand"	"testing"	"github.com/google/go-cmp/cmp"	"github.com/xtls/xray-core/common"	. "github.com/xtls/xray-core/proxy/mtproto")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 r := cmp.Diff(bii, b); r != "" {		t.Fatal(r)	}}func TestAuthenticationReadWrite(t *testing.T) {	a := NewAuthentication(DefaultSessionContext())	b := bytes.NewReader(a.Header[:])	a2, err := ReadAuthentication(b)	common.Must(err)	if r := cmp.Diff(a.EncodingKey[:], a2.DecodingKey[:]); r != "" {		t.Error("decoding key: ", r)	}	if r := cmp.Diff(a.EncodingNonce[:], a2.DecodingNonce[:]); r != "" {		t.Error("decoding nonce: ", r)	}	if r := cmp.Diff(a.DecodingKey[:], a2.EncodingKey[:]); r != "" {		t.Error("encoding key: ", r)	}	if r := cmp.Diff(a.DecodingNonce[:], a2.EncodingNonce[:]); r != "" {		t.Error("encoding nonce: ", r)	}}
 |