Skip to content

Commit

Permalink
add en-/decrypt tests and salsa20 init test
Browse files Browse the repository at this point in the history
  • Loading branch information
genzj committed Mar 30, 2015
1 parent 7d1eff9 commit 5fcd2fd
Showing 1 changed file with 127 additions and 0 deletions.
127 changes: 127 additions & 0 deletions shadowsocks/encrypt_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,8 @@ package shadowsocks
import (
"crypto/rc4"
"reflect"
"io"
"crypto/rand"
"testing"
)

Expand Down Expand Up @@ -144,11 +146,15 @@ func TestRC4MD5(t *testing.T) {
}

var cipherKey = make([]byte, 64)
var cipherIv = make([]byte, 64)

const CIPHER_BENCHMARK_BUFFER_LEN = 4096

func init() {
for i := 0; i < len(cipherKey); i++ {
cipherKey[i] = byte(i)
}
io.ReadFull(rand.Reader, cipherIv)
}

func BenchmarkRC4Init(b *testing.B) {
Expand Down Expand Up @@ -200,3 +206,124 @@ func BenchmarkRC4MD5Init(b *testing.B) {
ci := cipherMethod["rc4-md5"]
benchmarkCipherInit(b, ci)
}

func BenchmarkSalsa20Init(b *testing.B) {
ci := cipherMethod["salsa20"]
benchmarkCipherInit(b, ci)
}

func benchmarkCipherEncrypt(b *testing.B, ci *cipherInfo) {
key := cipherKey[:ci.keyLen]
iv := cipherIv[:ci.ivLen]
enc, err := ci.newStream(key, iv, Encrypt)
if err != nil {
b.Error(err)
}
src := make([]byte, CIPHER_BENCHMARK_BUFFER_LEN)
dst := make([]byte, CIPHER_BENCHMARK_BUFFER_LEN)
io.ReadFull(rand.Reader, src)
for i := 0; i < b.N; i++ {
enc.XORKeyStream(dst, src)
}
}

func BenchmarkAES128Encrypt(b *testing.B) {
ci := cipherMethod["aes-128-cfb"]
benchmarkCipherEncrypt(b, ci)
}

func BenchmarkAES192Encrypt(b *testing.B) {
ci := cipherMethod["aes-192-cfb"]
benchmarkCipherEncrypt(b, ci)
}

func BenchmarkAES256Encrypt(b *testing.B) {
ci := cipherMethod["aes-256-cfb"]
benchmarkCipherEncrypt(b, ci)
}

func BenchmarkBlowFishEncrypt(b *testing.B) {
ci := cipherMethod["bf-cfb"]
benchmarkCipherEncrypt(b, ci)
}

func BenchmarkCast5Encrypt(b *testing.B) {
ci := cipherMethod["bf-cfb"]
benchmarkCipherEncrypt(b, ci)
}

func BenchmarkDESEncrypt(b *testing.B) {
ci := cipherMethod["des-cfb"]
benchmarkCipherEncrypt(b, ci)
}

func BenchmarkRC4MD5Encrypt(b *testing.B) {
ci := cipherMethod["rc4-md5"]
benchmarkCipherEncrypt(b, ci)
}

func BenchmarkSalsa20Encrypt(b *testing.B) {
ci := cipherMethod["salsa20"]
benchmarkCipherEncrypt(b, ci)
}

func benchmarkCipherDecrypt(b *testing.B, ci *cipherInfo) {
key := cipherKey[:ci.keyLen]
iv := cipherIv[:ci.ivLen]
enc, err := ci.newStream(key, iv, Encrypt)
if err != nil {
b.Error(err)
}
dec, err := ci.newStream(key, iv, Decrypt)
if err != nil {
b.Error(err)
}
src := make([]byte, CIPHER_BENCHMARK_BUFFER_LEN)
dst := make([]byte, CIPHER_BENCHMARK_BUFFER_LEN)
io.ReadFull(rand.Reader, src)
enc.XORKeyStream(dst, src)
for i := 0; i < b.N; i++ {
dec.XORKeyStream(src, dst)
}
}

func BenchmarkAES128Decrypt(b *testing.B) {
ci := cipherMethod["aes-128-cfb"]
benchmarkCipherDecrypt(b, ci)
}

func BenchmarkAES192Decrypt(b *testing.B) {
ci := cipherMethod["aes-192-cfb"]
benchmarkCipherDecrypt(b, ci)
}

func BenchmarkAES256Decrypt(b *testing.B) {
ci := cipherMethod["aes-256-cfb"]
benchmarkCipherDecrypt(b, ci)
}

func BenchmarkBlowFishDecrypt(b *testing.B) {
ci := cipherMethod["bf-cfb"]
benchmarkCipherDecrypt(b, ci)
}

func BenchmarkCast5Decrypt(b *testing.B) {
ci := cipherMethod["bf-cfb"]
benchmarkCipherDecrypt(b, ci)
}

func BenchmarkDESDecrypt(b *testing.B) {
ci := cipherMethod["des-cfb"]
benchmarkCipherDecrypt(b, ci)
}

func BenchmarkRC4MD5Decrypt(b *testing.B) {
ci := cipherMethod["rc4-md5"]
benchmarkCipherDecrypt(b, ci)
}

func BenchmarkSalsa20Decrypt(b *testing.B) {
ci := cipherMethod["salsa20"]
benchmarkCipherDecrypt(b, ci)
}

0 comments on commit 5fcd2fd

Please sign in to comment.