-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathencryption_test.go
71 lines (51 loc) · 1.92 KB
/
encryption_test.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
package easyecc
import (
"bytes"
"testing"
"github.com/ethereum/go-ethereum/crypto"
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/require"
)
func TestEncryption(t *testing.T) {
require := require.New(t)
alicePrivateKey, err := GeneratePrivateKey(SECP256K1)
require.NoError(err)
bobPrivateKey, err := GeneratePrivateKey(SECP256K1)
require.NoError(err)
key1x, key1y := crypto.S256().ScalarMult(alicePrivateKey.PublicKey().X(), alicePrivateKey.PublicKey().Y(),
bobPrivateKey.Secret().Bytes())
key2x, key2y := crypto.S256().ScalarMult(bobPrivateKey.PublicKey().X(), bobPrivateKey.PublicKey().Y(),
alicePrivateKey.Secret().Bytes())
require.Equal(key1x, key2x)
require.Equal(key1y, key2y)
}
func TestEncryptDecrypt(t *testing.T) {
assert := assert.New(t)
alicePrivateKey, err := GeneratePrivateKey(P256)
assert.NoError(err)
bobPrivateKey, err := GeneratePrivateKey(P256)
assert.NoError(err)
message := "All that we are is the result of what we have thought"
ciphertext, err := alicePrivateKey.EncryptECDH([]byte(message), bobPrivateKey.PublicKey())
assert.NoError(err)
plaintext, err := bobPrivateKey.DecryptECDH(ciphertext, alicePrivateKey.PublicKey())
assert.NoError(err)
assert.True(bytes.Equal([]byte(message), plaintext))
// Test error on different curves.
spongeBobPrivateKey, err := GeneratePrivateKey(P521)
assert.NoError(err)
_, err = alicePrivateKey.EncryptECDH([]byte(message), spongeBobPrivateKey.PublicKey())
assert.Equal(ErrDifferentCurves, err)
}
func TestEncryptDecryptSymmetric(t *testing.T) {
assert := assert.New(t)
privateKey, err := GeneratePrivateKey(P521)
assert.NoError(err)
message := "super secret message"
encrypted, err := privateKey.EncryptSymmetric([]byte(message))
assert.NoError(err)
assert.True(len(encrypted) > len([]byte(message)))
decrypted, err := privateKey.DecryptSymmetric(encrypted)
assert.NoError(err)
assert.EqualValues(message, string(decrypted))
}