croc/src/crypt/crypt_test.go

106 lines
2.4 KiB
Go
Raw Normal View History

2018-09-24 15:13:43 +02:00
package crypt
import (
2021-04-22 01:53:29 +02:00
"fmt"
"testing"
2018-09-24 15:13:43 +02:00
"github.com/stretchr/testify/assert"
)
2019-11-18 16:50:43 +01:00
func BenchmarkEncrypt(b *testing.B) {
bob, _, _ := New([]byte("password"), nil)
2018-09-24 15:13:43 +02:00
for i := 0; i < b.N; i++ {
2019-11-18 16:50:43 +01:00
Encrypt([]byte("hello, world"), bob)
}
}
2018-09-24 15:13:43 +02:00
2019-11-18 16:50:43 +01:00
func BenchmarkDecrypt(b *testing.B) {
key, _, _ := New([]byte("password"), nil)
msg := []byte("hello, world")
enc, _ := Encrypt(msg, key)
b.ResetTimer()
for i := 0; i < b.N; i++ {
2019-11-18 16:50:43 +01:00
Decrypt(enc, key)
2018-09-24 15:13:43 +02:00
}
}
2021-04-22 01:53:29 +02:00
func BenchmarkEncryptChaCha(b *testing.B) {
bob, _, _ := NewArgon2([]byte("password"), nil)
for i := 0; i < b.N; i++ {
EncryptChaCha([]byte("hello, world"), bob)
}
}
func BenchmarkDecryptChaCha(b *testing.B) {
key, _, _ := NewArgon2([]byte("password"), nil)
msg := []byte("hello, world")
enc, _ := EncryptChaCha(msg, key)
b.ResetTimer()
for i := 0; i < b.N; i++ {
DecryptChaCha(enc, key)
}
}
func TestEncryption(t *testing.T) {
2019-11-18 16:50:43 +01:00
key, salt, err := New([]byte("password"), nil)
assert.Nil(t, err)
2019-11-18 16:50:43 +01:00
msg := []byte("hello, world")
enc, err := Encrypt(msg, key)
assert.Nil(t, err)
2019-11-18 16:50:43 +01:00
dec, err := Decrypt(enc, key)
2019-04-28 02:03:05 +02:00
assert.Nil(t, err)
2019-11-18 16:50:43 +01:00
assert.Equal(t, msg, dec)
2019-04-30 00:33:15 +02:00
2019-11-18 16:50:43 +01:00
// check reusing the salt
key2, _, err := New([]byte("password"), salt)
dec, err = Decrypt(enc, key2)
2019-04-30 00:33:15 +02:00
assert.Nil(t, err)
2019-11-18 16:50:43 +01:00
assert.Equal(t, msg, dec)
2019-04-30 00:33:15 +02:00
2019-11-18 16:50:43 +01:00
// check reusing the salt
key2, _, err = New([]byte("wrong password"), salt)
dec, err = Decrypt(enc, key2)
2019-04-30 00:33:15 +02:00
assert.NotNil(t, err)
2019-11-18 16:50:43 +01:00
assert.NotEqual(t, msg, dec)
2020-03-02 19:06:20 +01:00
// error with no password
dec, err = Decrypt([]byte(""), key)
assert.NotNil(t, err)
// error with small password
_, _, err = New([]byte(""), nil)
assert.NotNil(t, err)
2019-09-07 18:41:24 +02:00
}
2021-04-22 01:53:29 +02:00
func TestEncryptionChaCha(t *testing.T) {
key, salt, err := NewArgon2([]byte("password"), nil)
fmt.Printf("key: %x\n", key)
assert.Nil(t, err)
msg := []byte("hello, world")
enc, err := EncryptChaCha(msg, key)
assert.Nil(t, err)
dec, err := DecryptChaCha(enc, key)
assert.Nil(t, err)
assert.Equal(t, msg, dec)
// check reusing the salt
key2, _, err := NewArgon2([]byte("password"), salt)
dec, err = DecryptChaCha(enc, key2)
assert.Nil(t, err)
assert.Equal(t, msg, dec)
// check reusing the salt
key2, _, err = NewArgon2([]byte("wrong password"), salt)
dec, err = DecryptChaCha(enc, key2)
assert.NotNil(t, err)
assert.NotEqual(t, msg, dec)
// error with no password
dec, err = DecryptChaCha([]byte(""), key)
assert.NotNil(t, err)
// error with small password
_, _, err = NewArgon2([]byte(""), nil)
assert.NotNil(t, err)
}