tendermint/crypto/xsalsa20symmetric/symmetric_test.go

47 lines
1.2 KiB
Go
Raw Normal View History

package xsalsa20symmetric
2018-06-20 15:30:44 -07:00
import (
"testing"
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/require"
"golang.org/x/crypto/bcrypt" // forked to github.com/tendermint/crypto
"github.com/tendermint/tendermint/crypto"
2018-06-20 15:30:44 -07:00
)
func TestSimple(t *testing.T) {
crypto.MixEntropy([]byte("someentropy"))
2018-06-20 15:30:44 -07:00
plaintext := []byte("sometext")
secret := []byte("somesecretoflengththirtytwo===32")
ciphertext := EncryptSymmetric(plaintext, secret)
plaintext2, err := DecryptSymmetric(ciphertext, secret)
require.Nil(t, err, "%+v", err)
assert.Equal(t, plaintext, plaintext2)
}
func TestSimpleWithKDF(t *testing.T) {
crypto.MixEntropy([]byte("someentropy"))
2018-06-20 15:30:44 -07:00
plaintext := []byte("sometext")
secretPass := []byte("somesecret")
salt := []byte("somesaltsomesalt") // len 16
// NOTE: we use a fork of x/crypto so we can inject our own randomness for salt
secret, err := bcrypt.GenerateFromPassword(salt, secretPass, 12)
2018-06-20 15:30:44 -07:00
if err != nil {
t.Error(err)
}
secret = crypto.Sha256(secret)
2018-06-20 15:30:44 -07:00
ciphertext := EncryptSymmetric(plaintext, secret)
plaintext2, err := DecryptSymmetric(ciphertext, secret)
require.Nil(t, err, "%+v", err)
assert.Equal(t, plaintext, plaintext2)
}