|
| 1 | +package keystore_test |
| 2 | + |
| 3 | +import ( |
| 4 | + "testing" |
| 5 | + |
| 6 | + "github.com/ethereum/go-ethereum/crypto" |
| 7 | + "github.com/stretchr/testify/require" |
| 8 | + |
| 9 | + "github.com/smartcontractkit/chainlink-common/keystore" |
| 10 | +) |
| 11 | + |
| 12 | +func TestCoreKeystore(t *testing.T) { |
| 13 | + ctx := t.Context() |
| 14 | + |
| 15 | + ks, err := keystore.LoadKeystore(t.Context(), keystore.NewMemoryStorage(), "test-password", keystore.WithScryptParams(keystore.FastScryptParams)) |
| 16 | + require.NoError(t, err) |
| 17 | + coreKs := keystore.NewCoreKeystore(ks) |
| 18 | + |
| 19 | + keysResp, err := ks.CreateKeys(ctx, keystore.CreateKeysRequest{ |
| 20 | + Keys: []keystore.CreateKeyRequest{ |
| 21 | + {KeyName: "encrypt", KeyType: keystore.X25519}, |
| 22 | + {KeyName: "sign", KeyType: keystore.ECDSA_S256}, |
| 23 | + }, |
| 24 | + }) |
| 25 | + require.NoError(t, err) |
| 26 | + require.Equal(t, 2, len(keysResp.Keys)) |
| 27 | + |
| 28 | + accounts, err := coreKs.Accounts(ctx) |
| 29 | + require.NoError(t, err) |
| 30 | + require.Equal(t, []string{"encrypt", "sign"}, accounts) |
| 31 | + |
| 32 | + signature, err := coreKs.Sign(ctx, "sign", crypto.Keccak256([]byte("test-data-to-sign"))) |
| 33 | + require.NoError(t, err) |
| 34 | + require.NotEmpty(t, signature) |
| 35 | + verifyResp, err := ks.Verify(ctx, keystore.VerifyRequest{ |
| 36 | + KeyType: keysResp.Keys[1].KeyInfo.KeyType, |
| 37 | + PublicKey: keysResp.Keys[1].KeyInfo.PublicKey, |
| 38 | + Data: crypto.Keccak256([]byte("test-data-to-sign")), |
| 39 | + Signature: signature, |
| 40 | + }) |
| 41 | + require.NoError(t, err) |
| 42 | + require.True(t, verifyResp.Valid) |
| 43 | + |
| 44 | + encryptedData, err := ks.Encrypt(ctx, keystore.EncryptRequest{ |
| 45 | + RemoteKeyType: keysResp.Keys[0].KeyInfo.KeyType, |
| 46 | + RemotePubKey: keysResp.Keys[0].KeyInfo.PublicKey, |
| 47 | + Data: []byte("test-data-to-encrypt"), |
| 48 | + }) |
| 49 | + require.NoError(t, err) |
| 50 | + require.NotEmpty(t, encryptedData) |
| 51 | + |
| 52 | + decryptedData, err := coreKs.Decrypt(ctx, "encrypt", encryptedData.EncryptedData) |
| 53 | + require.NoError(t, err) |
| 54 | + require.Equal(t, []byte("test-data-to-encrypt"), decryptedData) |
| 55 | +} |
0 commit comments