crypto/keyring: `Keybase` interface gives way to its successor: `Keyring`. `LegacyKeybase` interface is added in order to guarantee limited backward compatibility with the old `Keybase` interface for the sole purpose of migrating keys across the new keyring backends. The package no longer depends on the `github.com/types.Config` singleton. `SupportedAlgos` and `SupportedLedgerAlgos` methods have been removed. The keyring just fails when trying to perform an action with an unsupported algorithm. crypto/ subdirs reorganization: `crypto/keys/hd` was moved to `crypto/hd`, which now groups together all HD wallets related types and utilities. client/input: * Removal of unnecessary `GetCheckPassword`, `PrintPrefixed` functions. * `GetConfirmation`'s signature changed to take in a io.Writer for better integration with `cobra.Command` types. client/context: * In-memory keyring is allocated in the context when `--gen-only` flag is passed in. `GetFromFields` does no longer silently allocate a keyring, it takes one as argument. Co-authored with @jgimeno Co-authored-by: Jonathan Gimeno <jgimeno@gmail.com>
70 lines
2.0 KiB
Go
70 lines
2.0 KiB
Go
package server_test
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
"github.com/cosmos/cosmos-sdk/crypto/hd"
|
|
"github.com/cosmos/cosmos-sdk/crypto/keyring"
|
|
"github.com/cosmos/cosmos-sdk/server"
|
|
"github.com/cosmos/cosmos-sdk/tests"
|
|
"github.com/cosmos/cosmos-sdk/types"
|
|
)
|
|
|
|
func TestGenerateCoinKey(t *testing.T) {
|
|
t.Parallel()
|
|
addr, mnemonic, err := server.GenerateCoinKey()
|
|
require.NoError(t, err)
|
|
|
|
// Test creation
|
|
info, err := keyring.NewInMemory().NewAccount("xxx", mnemonic, "", hd.NewFundraiserParams(0, types.GetConfig().GetCoinType(), 0).String(), hd.Secp256k1)
|
|
require.NoError(t, err)
|
|
require.Equal(t, addr, info.GetAddress())
|
|
}
|
|
|
|
func TestGenerateSaveCoinKey(t *testing.T) {
|
|
t.Parallel()
|
|
dir, cleanup := tests.NewTestCaseDir(t)
|
|
t.Cleanup(cleanup)
|
|
|
|
kb, err := keyring.New(t.Name(), "test", dir, nil)
|
|
require.NoError(t, err)
|
|
|
|
addr, mnemonic, err := server.GenerateSaveCoinKey(kb, "keyname", "012345678", false)
|
|
require.NoError(t, err)
|
|
|
|
// Test key was actually saved
|
|
info, err := kb.Key("keyname")
|
|
require.NoError(t, err)
|
|
require.Equal(t, addr, info.GetAddress())
|
|
|
|
// Test in-memory recovery
|
|
info, err = keyring.NewInMemory().NewAccount("xxx", mnemonic, "", hd.NewFundraiserParams(0, types.GetConfig().GetCoinType(), 0).String(), hd.Secp256k1)
|
|
require.NoError(t, err)
|
|
require.Equal(t, addr, info.GetAddress())
|
|
}
|
|
|
|
func TestGenerateSaveCoinKeyOverwriteFlag(t *testing.T) {
|
|
t.Parallel()
|
|
dir, cleanup := tests.NewTestCaseDir(t)
|
|
t.Cleanup(cleanup)
|
|
|
|
kb, err := keyring.New(t.Name(), "test", dir, nil)
|
|
require.NoError(t, err)
|
|
|
|
keyname := "justakey"
|
|
addr1, _, err := server.GenerateSaveCoinKey(kb, keyname, "012345678", false)
|
|
require.NoError(t, err)
|
|
|
|
// Test overwrite with overwrite=false
|
|
_, _, err = server.GenerateSaveCoinKey(kb, keyname, "012345678", false)
|
|
require.Error(t, err)
|
|
|
|
// Test overwrite with overwrite=true
|
|
addr2, _, err := server.GenerateSaveCoinKey(kb, keyname, "012345678", true)
|
|
require.NoError(t, err)
|
|
|
|
require.NotEqual(t, addr1, addr2)
|
|
}
|