290 lines
4.8 KiB
Go
290 lines
4.8 KiB
Go
package kcp
|
|
|
|
import (
|
|
"bytes"
|
|
"crypto/aes"
|
|
"crypto/md5"
|
|
"crypto/rand"
|
|
"crypto/sha1"
|
|
"hash/crc32"
|
|
"io"
|
|
"testing"
|
|
)
|
|
|
|
func TestSM4(t *testing.T) {
|
|
bc, err := NewSM4BlockCrypt(pass[:16])
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
cryptTest(t, bc)
|
|
}
|
|
|
|
func TestAES(t *testing.T) {
|
|
bc, err := NewAESBlockCrypt(pass[:32])
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
cryptTest(t, bc)
|
|
}
|
|
|
|
func TestTEA(t *testing.T) {
|
|
bc, err := NewTEABlockCrypt(pass[:16])
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
cryptTest(t, bc)
|
|
}
|
|
|
|
func TestXOR(t *testing.T) {
|
|
bc, err := NewSimpleXORBlockCrypt(pass[:32])
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
cryptTest(t, bc)
|
|
}
|
|
|
|
func TestBlowfish(t *testing.T) {
|
|
bc, err := NewBlowfishBlockCrypt(pass[:32])
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
cryptTest(t, bc)
|
|
}
|
|
|
|
func TestNone(t *testing.T) {
|
|
bc, err := NewNoneBlockCrypt(pass[:32])
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
cryptTest(t, bc)
|
|
}
|
|
|
|
func TestCast5(t *testing.T) {
|
|
bc, err := NewCast5BlockCrypt(pass[:16])
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
cryptTest(t, bc)
|
|
}
|
|
|
|
func Test3DES(t *testing.T) {
|
|
bc, err := NewTripleDESBlockCrypt(pass[:24])
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
cryptTest(t, bc)
|
|
}
|
|
|
|
func TestTwofish(t *testing.T) {
|
|
bc, err := NewTwofishBlockCrypt(pass[:32])
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
cryptTest(t, bc)
|
|
}
|
|
|
|
func TestXTEA(t *testing.T) {
|
|
bc, err := NewXTEABlockCrypt(pass[:16])
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
cryptTest(t, bc)
|
|
}
|
|
|
|
func TestSalsa20(t *testing.T) {
|
|
bc, err := NewSalsa20BlockCrypt(pass[:32])
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
cryptTest(t, bc)
|
|
}
|
|
|
|
func cryptTest(t *testing.T, bc BlockCrypt) {
|
|
data := make([]byte, mtuLimit)
|
|
io.ReadFull(rand.Reader, data)
|
|
dec := make([]byte, mtuLimit)
|
|
enc := make([]byte, mtuLimit)
|
|
bc.Encrypt(enc, data)
|
|
bc.Decrypt(dec, enc)
|
|
if !bytes.Equal(data, dec) {
|
|
t.Fail()
|
|
}
|
|
}
|
|
|
|
func BenchmarkSM4(b *testing.B) {
|
|
bc, err := NewSM4BlockCrypt(pass[:16])
|
|
if err != nil {
|
|
b.Fatal(err)
|
|
}
|
|
benchCrypt(b, bc)
|
|
}
|
|
|
|
func BenchmarkAES128(b *testing.B) {
|
|
bc, err := NewAESBlockCrypt(pass[:16])
|
|
if err != nil {
|
|
b.Fatal(err)
|
|
}
|
|
|
|
benchCrypt(b, bc)
|
|
}
|
|
|
|
func BenchmarkAES192(b *testing.B) {
|
|
bc, err := NewAESBlockCrypt(pass[:24])
|
|
if err != nil {
|
|
b.Fatal(err)
|
|
}
|
|
|
|
benchCrypt(b, bc)
|
|
}
|
|
|
|
func BenchmarkAES256(b *testing.B) {
|
|
bc, err := NewAESBlockCrypt(pass[:32])
|
|
if err != nil {
|
|
b.Fatal(err)
|
|
}
|
|
|
|
benchCrypt(b, bc)
|
|
}
|
|
|
|
func BenchmarkTEA(b *testing.B) {
|
|
bc, err := NewTEABlockCrypt(pass[:16])
|
|
if err != nil {
|
|
b.Fatal(err)
|
|
}
|
|
benchCrypt(b, bc)
|
|
}
|
|
|
|
func BenchmarkXOR(b *testing.B) {
|
|
bc, err := NewSimpleXORBlockCrypt(pass[:32])
|
|
if err != nil {
|
|
b.Fatal(err)
|
|
}
|
|
benchCrypt(b, bc)
|
|
}
|
|
|
|
func BenchmarkBlowfish(b *testing.B) {
|
|
bc, err := NewBlowfishBlockCrypt(pass[:32])
|
|
if err != nil {
|
|
b.Fatal(err)
|
|
}
|
|
benchCrypt(b, bc)
|
|
}
|
|
|
|
func BenchmarkNone(b *testing.B) {
|
|
bc, err := NewNoneBlockCrypt(pass[:32])
|
|
if err != nil {
|
|
b.Fatal(err)
|
|
}
|
|
benchCrypt(b, bc)
|
|
}
|
|
|
|
func BenchmarkCast5(b *testing.B) {
|
|
bc, err := NewCast5BlockCrypt(pass[:16])
|
|
if err != nil {
|
|
b.Fatal(err)
|
|
}
|
|
benchCrypt(b, bc)
|
|
}
|
|
|
|
func Benchmark3DES(b *testing.B) {
|
|
bc, err := NewTripleDESBlockCrypt(pass[:24])
|
|
if err != nil {
|
|
b.Fatal(err)
|
|
}
|
|
benchCrypt(b, bc)
|
|
}
|
|
|
|
func BenchmarkTwofish(b *testing.B) {
|
|
bc, err := NewTwofishBlockCrypt(pass[:32])
|
|
if err != nil {
|
|
b.Fatal(err)
|
|
}
|
|
benchCrypt(b, bc)
|
|
}
|
|
|
|
func BenchmarkXTEA(b *testing.B) {
|
|
bc, err := NewXTEABlockCrypt(pass[:16])
|
|
if err != nil {
|
|
b.Fatal(err)
|
|
}
|
|
benchCrypt(b, bc)
|
|
}
|
|
|
|
func BenchmarkSalsa20(b *testing.B) {
|
|
bc, err := NewSalsa20BlockCrypt(pass[:32])
|
|
if err != nil {
|
|
b.Fatal(err)
|
|
}
|
|
benchCrypt(b, bc)
|
|
}
|
|
|
|
func benchCrypt(b *testing.B, bc BlockCrypt) {
|
|
data := make([]byte, mtuLimit)
|
|
io.ReadFull(rand.Reader, data)
|
|
dec := make([]byte, mtuLimit)
|
|
enc := make([]byte, mtuLimit)
|
|
|
|
b.ReportAllocs()
|
|
b.SetBytes(int64(len(enc) * 2))
|
|
b.ResetTimer()
|
|
for i := 0; i < b.N; i++ {
|
|
bc.Encrypt(enc, data)
|
|
bc.Decrypt(dec, enc)
|
|
}
|
|
}
|
|
|
|
func BenchmarkCRC32(b *testing.B) {
|
|
content := make([]byte, 1024)
|
|
b.SetBytes(int64(len(content)))
|
|
for i := 0; i < b.N; i++ {
|
|
crc32.ChecksumIEEE(content)
|
|
}
|
|
}
|
|
|
|
func BenchmarkCsprngSystem(b *testing.B) {
|
|
data := make([]byte, md5.Size)
|
|
b.SetBytes(int64(len(data)))
|
|
|
|
for i := 0; i < b.N; i++ {
|
|
io.ReadFull(rand.Reader, data)
|
|
}
|
|
}
|
|
|
|
func BenchmarkCsprngMD5(b *testing.B) {
|
|
var data [md5.Size]byte
|
|
b.SetBytes(md5.Size)
|
|
|
|
for i := 0; i < b.N; i++ {
|
|
data = md5.Sum(data[:])
|
|
}
|
|
}
|
|
func BenchmarkCsprngSHA1(b *testing.B) {
|
|
var data [sha1.Size]byte
|
|
b.SetBytes(sha1.Size)
|
|
|
|
for i := 0; i < b.N; i++ {
|
|
data = sha1.Sum(data[:])
|
|
}
|
|
}
|
|
|
|
func BenchmarkCsprngNonceMD5(b *testing.B) {
|
|
var ng nonceMD5
|
|
ng.Init()
|
|
b.SetBytes(md5.Size)
|
|
data := make([]byte, md5.Size)
|
|
for i := 0; i < b.N; i++ {
|
|
ng.Fill(data)
|
|
}
|
|
}
|
|
|
|
func BenchmarkCsprngNonceAES128(b *testing.B) {
|
|
var ng nonceAES128
|
|
ng.Init()
|
|
|
|
b.SetBytes(aes.BlockSize)
|
|
data := make([]byte, aes.BlockSize)
|
|
for i := 0; i < b.N; i++ {
|
|
ng.Fill(data)
|
|
}
|
|
}
|