| 1234567891011121314151617181920212223242526272829303132333435363738394041424344 | 
							- package mtproto_test
 
- import (
 
- 	"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[:])
 
- }
 
 
  |