mirror of https://github.com/v2ray/v2ray-core
				
				
				
			
		
			
				
	
	
		
			40 lines
		
	
	
		
			865 B
		
	
	
	
		
			Go
		
	
	
			
		
		
	
	
			40 lines
		
	
	
		
			865 B
		
	
	
	
		
			Go
		
	
	
| package shadowsocks_test
 | |
| 
 | |
| import (
 | |
| 	"crypto/rand"
 | |
| 	"testing"
 | |
| 
 | |
| 	"github.com/google/go-cmp/cmp"
 | |
| 
 | |
| 	"v2ray.com/core/common"
 | |
| 	"v2ray.com/core/common/buf"
 | |
| 	"v2ray.com/core/proxy/shadowsocks"
 | |
| )
 | |
| 
 | |
| func TestAEADCipherUDP(t *testing.T) {
 | |
| 	rawAccount := &shadowsocks.Account{
 | |
| 		CipherType: shadowsocks.CipherType_AES_128_GCM,
 | |
| 		Password:   "test",
 | |
| 	}
 | |
| 	account, err := rawAccount.AsAccount()
 | |
| 	common.Must(err)
 | |
| 
 | |
| 	cipher := account.(*shadowsocks.MemoryAccount).Cipher
 | |
| 
 | |
| 	key := make([]byte, cipher.KeySize())
 | |
| 	common.Must2(rand.Read(key))
 | |
| 
 | |
| 	payload := make([]byte, 1024)
 | |
| 	common.Must2(rand.Read(payload))
 | |
| 
 | |
| 	b1 := buf.New()
 | |
| 	common.Must2(b1.ReadFullFrom(rand.Reader, cipher.IVSize()))
 | |
| 	common.Must2(b1.Write(payload))
 | |
| 	common.Must(cipher.EncodePacket(key, b1))
 | |
| 
 | |
| 	common.Must(cipher.DecodePacket(key, b1))
 | |
| 	if diff := cmp.Diff(b1.Bytes(), payload); diff != "" {
 | |
| 		t.Error(diff)
 | |
| 	}
 | |
| }
 |