2018-07-23 15:04:04 -07:00
|
|
|
package xsalsa20symmetric
|
2018-06-20 15:30:44 -07:00
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
|
2018-12-16 14:19:38 -05:00
|
|
|
"golang.org/x/crypto/bcrypt"
|
2018-10-11 10:01:53 -04:00
|
|
|
|
2018-07-18 08:38:44 -07:00
|
|
|
"github.com/tendermint/tendermint/crypto"
|
2018-06-20 15:30:44 -07:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestSimple(t *testing.T) {
|
|
|
|
|
|
|
|
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) {
|
|
|
|
|
|
|
|
plaintext := []byte("sometext")
|
|
|
|
secretPass := []byte("somesecret")
|
2018-12-16 14:19:38 -05:00
|
|
|
secret, err := bcrypt.GenerateFromPassword(secretPass, 12)
|
2018-06-20 15:30:44 -07:00
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
2018-07-18 08:38:44 -07:00
|
|
|
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)
|
|
|
|
}
|