mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-19 00:04:12 +00:00
14e3e80df3
* keymanager-api * import updates to standards * adding in more unit tests and code fixes to improve api experience * deleting accidently generated files * deleting accidently generated files * adding in more test coverage * fixing linter issue * removing incorrect unit tests * improving logic for accounts import * linter fix * addressing review comments * fixing based on comments * fixing nonzero root * fixing protos * regen protos * adjusting protos again * updating api specs * fixing code and unit tests after specs changed * fixing imports * adding in required changes for api middleware also adding unit tests to catch changes for protos * fixing deepsource issues * fixing linting * seeing if using pointers helps * addressing comments * updating bazel build Co-authored-by: Raul Jordan <raul@prysmaticlabs.com>
194 lines
5.8 KiB
Go
194 lines
5.8 KiB
Go
package local
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
"strconv"
|
|
"testing"
|
|
|
|
"github.com/google/uuid"
|
|
"github.com/prysmaticlabs/prysm/crypto/bls"
|
|
ethpbservice "github.com/prysmaticlabs/prysm/proto/eth/service"
|
|
"github.com/prysmaticlabs/prysm/testing/assert"
|
|
"github.com/prysmaticlabs/prysm/testing/require"
|
|
mock "github.com/prysmaticlabs/prysm/validator/accounts/testing"
|
|
"github.com/prysmaticlabs/prysm/validator/keymanager"
|
|
keystorev4 "github.com/wealdtech/go-eth2-wallet-encryptor-keystorev4"
|
|
)
|
|
|
|
const password = "secretPassw0rd$1999"
|
|
|
|
func createRandomKeystore(t testing.TB, password string) *keymanager.Keystore {
|
|
encryptor := keystorev4.New()
|
|
id, err := uuid.NewRandom()
|
|
require.NoError(t, err)
|
|
validatingKey, err := bls.RandKey()
|
|
require.NoError(t, err)
|
|
pubKey := validatingKey.PublicKey().Marshal()
|
|
cryptoFields, err := encryptor.Encrypt(validatingKey.Marshal(), password)
|
|
require.NoError(t, err)
|
|
return &keymanager.Keystore{
|
|
Crypto: cryptoFields,
|
|
Pubkey: fmt.Sprintf("%x", pubKey),
|
|
ID: id.String(),
|
|
Version: encryptor.Version(),
|
|
Name: encryptor.Name(),
|
|
}
|
|
}
|
|
|
|
func TestLocalKeymanager_NoDuplicates(t *testing.T) {
|
|
numKeys := 50
|
|
pubKeys := make([][]byte, numKeys)
|
|
privKeys := make([][]byte, numKeys)
|
|
for i := 0; i < numKeys; i++ {
|
|
priv, err := bls.RandKey()
|
|
require.NoError(t, err)
|
|
privKeys[i] = priv.Marshal()
|
|
pubKeys[i] = priv.PublicKey().Marshal()
|
|
}
|
|
wallet := &mock.Wallet{
|
|
WalletPassword: "Passwordz0202$",
|
|
}
|
|
dr := &Keymanager{
|
|
wallet: wallet,
|
|
}
|
|
ctx := context.Background()
|
|
_, err := dr.CreateAccountsKeystore(ctx, privKeys, pubKeys)
|
|
require.NoError(t, err)
|
|
|
|
// We expect the 50 keys in the account store to match.
|
|
require.NotNil(t, dr.accountsStore)
|
|
require.Equal(t, len(dr.accountsStore.PublicKeys), len(dr.accountsStore.PrivateKeys))
|
|
require.Equal(t, len(dr.accountsStore.PublicKeys), numKeys)
|
|
for i := 0; i < len(dr.accountsStore.PrivateKeys); i++ {
|
|
assert.DeepEqual(t, dr.accountsStore.PrivateKeys[i], privKeys[i])
|
|
assert.DeepEqual(t, dr.accountsStore.PublicKeys[i], pubKeys[i])
|
|
}
|
|
|
|
// Re-run the create accounts keystore function with the same pubkeys.
|
|
_, err = dr.CreateAccountsKeystore(ctx, privKeys, pubKeys)
|
|
require.NoError(t, err)
|
|
|
|
// We expect nothing to change.
|
|
require.NotNil(t, dr.accountsStore)
|
|
require.Equal(t, len(dr.accountsStore.PublicKeys), len(dr.accountsStore.PrivateKeys))
|
|
require.Equal(t, len(dr.accountsStore.PublicKeys), numKeys)
|
|
for i := 0; i < len(dr.accountsStore.PrivateKeys); i++ {
|
|
assert.DeepEqual(t, dr.accountsStore.PrivateKeys[i], privKeys[i])
|
|
assert.DeepEqual(t, dr.accountsStore.PublicKeys[i], pubKeys[i])
|
|
}
|
|
|
|
// Now, we run the function again but with a new priv and pubkey and this
|
|
// time, we do expect a change.
|
|
privKey, err := bls.RandKey()
|
|
require.NoError(t, err)
|
|
privKeys = append(privKeys, privKey.Marshal())
|
|
pubKeys = append(pubKeys, privKey.PublicKey().Marshal())
|
|
|
|
_, err = dr.CreateAccountsKeystore(ctx, privKeys, pubKeys)
|
|
require.NoError(t, err)
|
|
require.Equal(t, len(dr.accountsStore.PublicKeys), len(dr.accountsStore.PrivateKeys))
|
|
|
|
// We should have 1 more new key in the store.
|
|
require.Equal(t, numKeys+1, len(dr.accountsStore.PrivateKeys))
|
|
}
|
|
|
|
func TestLocalKeymanager_ImportKeystores(t *testing.T) {
|
|
ctx := context.Background()
|
|
// Setup the keymanager.
|
|
wallet := &mock.Wallet{
|
|
Files: make(map[string]map[string][]byte),
|
|
WalletPassword: password,
|
|
}
|
|
dr := &Keymanager{
|
|
wallet: wallet,
|
|
accountsStore: &accountStore{},
|
|
}
|
|
|
|
t.Run("same password used to decrypt all keystores", func(t *testing.T) {
|
|
numKeystores := 5
|
|
keystores := make([]*keymanager.Keystore, numKeystores)
|
|
passwords := make([]string, numKeystores)
|
|
for i := 0; i < numKeystores; i++ {
|
|
keystores[i] = createRandomKeystore(t, password)
|
|
passwords[i] = password
|
|
}
|
|
statuses, err := dr.ImportKeystores(
|
|
ctx,
|
|
keystores,
|
|
passwords,
|
|
)
|
|
require.NoError(t, err)
|
|
require.Equal(t, numKeystores, len(statuses))
|
|
for _, status := range statuses {
|
|
require.Equal(t, ethpbservice.ImportedKeystoreStatus_IMPORTED, status.Status)
|
|
}
|
|
})
|
|
t.Run("each imported keystore with a different password succeeds", func(t *testing.T) {
|
|
numKeystores := 5
|
|
keystores := make([]*keymanager.Keystore, numKeystores)
|
|
passwords := make([]string, numKeystores)
|
|
for i := 0; i < numKeystores; i++ {
|
|
pass := password + strconv.Itoa(i)
|
|
keystores[i] = createRandomKeystore(t, pass)
|
|
passwords[i] = pass
|
|
}
|
|
statuses, err := dr.ImportKeystores(
|
|
ctx,
|
|
keystores,
|
|
passwords,
|
|
)
|
|
require.NoError(t, err)
|
|
require.Equal(t, numKeystores, len(statuses))
|
|
for _, status := range statuses {
|
|
require.Equal(t, ethpbservice.ImportedKeystoreStatus_IMPORTED, status.Status)
|
|
}
|
|
})
|
|
t.Run("some succeed, some fail to decrypt, some duplicated", func(t *testing.T) {
|
|
keystores := make([]*keymanager.Keystore, 0)
|
|
passwords := make([]string, 0)
|
|
|
|
// First keystore is normal.
|
|
keystore1 := createRandomKeystore(t, password)
|
|
keystores = append(keystores, keystore1)
|
|
passwords = append(passwords, password)
|
|
|
|
// Second keystore is a duplicate of the first.
|
|
keystores = append(keystores, keystore1)
|
|
passwords = append(passwords, password)
|
|
|
|
// Third keystore has a wrong password.
|
|
keystore3 := createRandomKeystore(t, password)
|
|
keystores = append(keystores, keystore3)
|
|
passwords = append(passwords, "foobar")
|
|
|
|
statuses, err := dr.ImportKeystores(
|
|
ctx,
|
|
keystores,
|
|
passwords,
|
|
)
|
|
require.NoError(t, err)
|
|
require.Equal(t, len(keystores), len(statuses))
|
|
require.Equal(
|
|
t,
|
|
ethpbservice.ImportedKeystoreStatus_IMPORTED,
|
|
statuses[0].Status,
|
|
)
|
|
require.Equal(
|
|
t,
|
|
ethpbservice.ImportedKeystoreStatus_DUPLICATE,
|
|
statuses[1].Status,
|
|
)
|
|
require.Equal(
|
|
t,
|
|
ethpbservice.ImportedKeystoreStatus_ERROR,
|
|
statuses[2].Status,
|
|
)
|
|
require.Equal(
|
|
t,
|
|
fmt.Sprintf("incorrect password for key 0x%s", keystores[2].Pubkey),
|
|
statuses[2].Message,
|
|
)
|
|
})
|
|
}
|