2020-08-11 15:01:15 +00:00
|
|
|
package crypto
|
|
|
|
|
|
|
|
import (
|
|
|
|
"strings"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
|
2020-09-29 20:10:56 +00:00
|
|
|
"github.com/ethereum/go-ethereum/common"
|
2020-08-11 15:01:15 +00:00
|
|
|
ethcrypto "github.com/ethereum/go-ethereum/crypto"
|
|
|
|
|
2020-09-29 20:10:56 +00:00
|
|
|
hdwallet "github.com/miguelmota/go-ethereum-hdwallet"
|
|
|
|
|
2020-08-23 21:41:54 +00:00
|
|
|
"github.com/cosmos/cosmos-sdk/crypto/keys"
|
2020-08-11 15:01:15 +00:00
|
|
|
"github.com/cosmos/cosmos-sdk/crypto/keys/hd"
|
|
|
|
"github.com/cosmos/cosmos-sdk/tests"
|
2020-09-29 20:10:56 +00:00
|
|
|
|
|
|
|
ethermint "github.com/cosmos/ethermint/types"
|
2020-08-11 15:01:15 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestEthermintKeygenFunc(t *testing.T) {
|
|
|
|
privkey, err := GenerateKey()
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
testCases := []struct {
|
|
|
|
name string
|
|
|
|
privKey []byte
|
2020-08-23 21:41:54 +00:00
|
|
|
algo keys.SigningAlgo
|
2020-08-11 15:01:15 +00:00
|
|
|
expPass bool
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
"valid ECDSA privKey",
|
|
|
|
ethcrypto.FromECDSA(privkey.ToECDSA()),
|
|
|
|
EthSecp256k1,
|
|
|
|
true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"nil bytes, valid algo",
|
|
|
|
nil,
|
|
|
|
EthSecp256k1,
|
|
|
|
true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"empty bytes, valid algo",
|
|
|
|
[]byte{},
|
|
|
|
EthSecp256k1,
|
|
|
|
true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"invalid algo",
|
|
|
|
nil,
|
2020-08-23 21:41:54 +00:00
|
|
|
keys.MultiAlgo,
|
2020-08-11 15:01:15 +00:00
|
|
|
false,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, tc := range testCases {
|
|
|
|
privkey, err := EthermintKeygenFunc(tc.privKey, tc.algo)
|
|
|
|
if tc.expPass {
|
|
|
|
require.NoError(t, err, tc.name)
|
|
|
|
} else {
|
|
|
|
require.Error(t, err, tc.name)
|
|
|
|
require.Nil(t, privkey, tc.name)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestKeyring(t *testing.T) {
|
|
|
|
dir, cleanup := tests.NewTestCaseDir(t)
|
|
|
|
mockIn := strings.NewReader("")
|
|
|
|
t.Cleanup(cleanup)
|
|
|
|
|
2020-08-23 21:41:54 +00:00
|
|
|
kr, err := keys.NewKeyring("ethermint", keys.BackendTest, dir, mockIn, EthSecp256k1Options()...)
|
2020-08-11 15:01:15 +00:00
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
// fail in retrieving key
|
|
|
|
info, err := kr.Get("foo")
|
|
|
|
require.Error(t, err)
|
|
|
|
require.Nil(t, info)
|
|
|
|
|
|
|
|
mockIn.Reset("password\npassword\n")
|
2020-09-29 20:10:56 +00:00
|
|
|
info, mnemonic, err := kr.CreateMnemonic("foo", keys.English, ethermint.BIP44HDPath, EthSecp256k1)
|
2020-08-11 15:01:15 +00:00
|
|
|
require.NoError(t, err)
|
|
|
|
require.NotEmpty(t, mnemonic)
|
|
|
|
require.Equal(t, "foo", info.GetName())
|
|
|
|
require.Equal(t, "local", info.GetType().String())
|
|
|
|
require.Equal(t, EthSecp256k1, info.GetAlgo())
|
|
|
|
|
2020-09-29 20:10:56 +00:00
|
|
|
params := *hd.NewFundraiserParams(0, ethermint.Bip44CoinType, 0)
|
2020-08-11 15:01:15 +00:00
|
|
|
hdPath := params.String()
|
|
|
|
|
2020-09-29 20:10:56 +00:00
|
|
|
bz, err := DeriveKey(mnemonic, keys.DefaultBIP39Passphrase, hdPath, keys.Secp256k1)
|
2020-08-11 15:01:15 +00:00
|
|
|
require.NoError(t, err)
|
|
|
|
require.NotEmpty(t, bz)
|
|
|
|
|
2020-09-29 20:10:56 +00:00
|
|
|
bz, err = DeriveSecp256k1(mnemonic, keys.DefaultBIP39Passphrase, hdPath)
|
2020-08-11 15:01:15 +00:00
|
|
|
require.NoError(t, err)
|
|
|
|
require.NotEmpty(t, bz)
|
|
|
|
|
2020-08-23 21:41:54 +00:00
|
|
|
bz, err = DeriveKey(mnemonic, keys.DefaultBIP39Passphrase, hdPath, keys.SigningAlgo(""))
|
2020-08-11 15:01:15 +00:00
|
|
|
require.Error(t, err)
|
|
|
|
require.Empty(t, bz)
|
2020-09-29 20:10:56 +00:00
|
|
|
|
|
|
|
bz, err = DeriveSecp256k1(mnemonic, keys.DefaultBIP39Passphrase, "/wrong/hdPath")
|
|
|
|
require.Error(t, err)
|
|
|
|
require.Empty(t, bz)
|
|
|
|
|
|
|
|
bz, err = DeriveKey(mnemonic, keys.DefaultBIP39Passphrase, hdPath, EthSecp256k1)
|
|
|
|
require.NoError(t, err)
|
|
|
|
require.NotEmpty(t, bz)
|
|
|
|
|
|
|
|
privkey := PrivKeySecp256k1(bz)
|
|
|
|
addr := common.BytesToAddress(privkey.PubKey().Address().Bytes())
|
|
|
|
|
|
|
|
wallet, err := hdwallet.NewFromMnemonic(mnemonic)
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
path := hdwallet.MustParseDerivationPath(hdPath)
|
|
|
|
|
|
|
|
account, err := wallet.Derive(path, false)
|
|
|
|
require.NoError(t, err)
|
|
|
|
require.Equal(t, addr.String(), account.Address.String())
|
2020-08-11 15:01:15 +00:00
|
|
|
}
|