chore: move server.GenerateCoinKey and server.GenerateSaveCoinKey to … (#10957)
Cleaning it and moving the breaking "test" code to testutils Related to: https://github.com/cosmos/cosmos-sdk/pull/10956 --- ### Author Checklist *All items are required. Please add a note to the item if the item is not applicable and please add links to any relevant follow up issues.* I have... - [ ] included the correct [type prefix](https://github.com/commitizen/conventional-commit-types/blob/v3.0.0/index.json) in the PR title - [ ] added `!` to the type prefix if API or client breaking change - [ ] targeted the correct branch (see [PR Targeting](https://github.com/cosmos/cosmos-sdk/blob/master/CONTRIBUTING.md#pr-targeting)) - [ ] provided a link to the relevant issue or specification - [ ] followed the guidelines for [building modules](https://github.com/cosmos/cosmos-sdk/blob/master/docs/building-modules) - [ ] included the necessary unit and integration [tests](https://github.com/cosmos/cosmos-sdk/blob/master/CONTRIBUTING.md#testing) - [ ] added a changelog entry to `CHANGELOG.md` - [ ] included comments for [documenting Go code](https://blog.golang.org/godoc) - [ ] updated the relevant documentation or specification - [ ] reviewed "Files changed" and left comments if necessary - [ ] confirmed all CI checks have passed ### Reviewers Checklist *All items are required. Please add a note if the item is not applicable and please add your handle next to the items reviewed if you only reviewed selected items.* I have... - [ ] confirmed the correct [type prefix](https://github.com/commitizen/conventional-commit-types/blob/v3.0.0/index.json) in the PR title - [ ] confirmed `!` in the type prefix if API or client breaking change - [ ] confirmed all author checklist items have been addressed - [ ] reviewed state machine logic - [ ] reviewed API design and naming - [ ] reviewed documentation is accurate - [ ] reviewed tests and test coverage - [ ] manually tested (if applicable)
This commit is contained in:
parent
43cf8ebb2b
commit
285db0674a
|
@ -116,6 +116,7 @@ Ref: https://keepachangelog.com/en/1.0.0/
|
||||||
* [\#10748](https://github.com/cosmos/cosmos-sdk/pull/10748) Move legacy `x/gov` api to `v1beta1` directory.
|
* [\#10748](https://github.com/cosmos/cosmos-sdk/pull/10748) Move legacy `x/gov` api to `v1beta1` directory.
|
||||||
* [\#10816](https://github.com/cosmos/cosmos-sdk/pull/10816) Reuse blocked addresses from the bank module. No need to pass them to distribution.
|
* [\#10816](https://github.com/cosmos/cosmos-sdk/pull/10816) Reuse blocked addresses from the bank module. No need to pass them to distribution.
|
||||||
* [\#10852](https://github.com/cosmos/cosmos-sdk/pull/10852) Move `x/gov/types` to `x/gov/types/v1beta2`.
|
* [\#10852](https://github.com/cosmos/cosmos-sdk/pull/10852) Move `x/gov/types` to `x/gov/types/v1beta2`.
|
||||||
|
* [\#10922](https://github.com/cosmos/cosmos-sdk/pull/10922), [/#10957](https://github.com/cosmos/cosmos-sdk/pull/10957) Move key `server.Generate*` functions to testutil and support custom mnemonics in in-process testing network. Moved `TestMnemonic` from `testutil` package to `testdata`.
|
||||||
|
|
||||||
### Client Breaking Changes
|
### Client Breaking Changes
|
||||||
|
|
||||||
|
|
|
@ -16,6 +16,7 @@ import (
|
||||||
"github.com/cosmos/cosmos-sdk/crypto/keyring"
|
"github.com/cosmos/cosmos-sdk/crypto/keyring"
|
||||||
"github.com/cosmos/cosmos-sdk/simapp"
|
"github.com/cosmos/cosmos-sdk/simapp"
|
||||||
"github.com/cosmos/cosmos-sdk/testutil"
|
"github.com/cosmos/cosmos-sdk/testutil"
|
||||||
|
"github.com/cosmos/cosmos-sdk/testutil/testdata"
|
||||||
sdk "github.com/cosmos/cosmos-sdk/types"
|
sdk "github.com/cosmos/cosmos-sdk/types"
|
||||||
"github.com/cosmos/go-bip39"
|
"github.com/cosmos/go-bip39"
|
||||||
)
|
)
|
||||||
|
@ -202,7 +203,7 @@ func Test_runAddCmdDryRun(t *testing.T) {
|
||||||
ctx := context.WithValue(context.Background(), client.ClientContextKey, &clientCtx)
|
ctx := context.WithValue(context.Background(), client.ClientContextKey, &clientCtx)
|
||||||
|
|
||||||
path := sdk.GetConfig().GetFullBIP44Path()
|
path := sdk.GetConfig().GetFullBIP44Path()
|
||||||
_, err = kb.NewAccount("subkey", testutil.TestMnemonic, "", path, hd.Secp256k1)
|
_, err = kb.NewAccount("subkey", testdata.TestMnemonic, "", path, hd.Secp256k1)
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
|
||||||
t.Cleanup(func() {
|
t.Cleanup(func() {
|
||||||
|
|
|
@ -13,6 +13,7 @@ import (
|
||||||
"github.com/cosmos/cosmos-sdk/crypto/keyring"
|
"github.com/cosmos/cosmos-sdk/crypto/keyring"
|
||||||
"github.com/cosmos/cosmos-sdk/simapp"
|
"github.com/cosmos/cosmos-sdk/simapp"
|
||||||
"github.com/cosmos/cosmos-sdk/testutil"
|
"github.com/cosmos/cosmos-sdk/testutil"
|
||||||
|
"github.com/cosmos/cosmos-sdk/testutil/testdata"
|
||||||
sdk "github.com/cosmos/cosmos-sdk/types"
|
sdk "github.com/cosmos/cosmos-sdk/types"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -39,7 +40,7 @@ func Test_runDeleteCmd(t *testing.T) {
|
||||||
kb, err := keyring.New(sdk.KeyringServiceName(), keyring.BackendTest, kbHome, mockIn, cdc)
|
kb, err := keyring.New(sdk.KeyringServiceName(), keyring.BackendTest, kbHome, mockIn, cdc)
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
|
||||||
_, err = kb.NewAccount(fakeKeyName1, testutil.TestMnemonic, "", path, hd.Secp256k1)
|
_, err = kb.NewAccount(fakeKeyName1, testdata.TestMnemonic, "", path, hd.Secp256k1)
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
|
||||||
_, _, err = kb.NewMnemonic(fakeKeyName2, keyring.English, sdk.FullFundraiserPath, keyring.DefaultBIP39Passphrase, hd.Secp256k1)
|
_, _, err = kb.NewMnemonic(fakeKeyName2, keyring.English, sdk.FullFundraiserPath, keyring.DefaultBIP39Passphrase, hd.Secp256k1)
|
||||||
|
|
|
@ -11,6 +11,7 @@ import (
|
||||||
"github.com/cosmos/cosmos-sdk/client"
|
"github.com/cosmos/cosmos-sdk/client"
|
||||||
"github.com/cosmos/cosmos-sdk/crypto/hd"
|
"github.com/cosmos/cosmos-sdk/crypto/hd"
|
||||||
"github.com/cosmos/cosmos-sdk/testutil"
|
"github.com/cosmos/cosmos-sdk/testutil"
|
||||||
|
"github.com/cosmos/cosmos-sdk/testutil/testdata"
|
||||||
|
|
||||||
"github.com/cosmos/cosmos-sdk/client/flags"
|
"github.com/cosmos/cosmos-sdk/client/flags"
|
||||||
"github.com/cosmos/cosmos-sdk/crypto/keyring"
|
"github.com/cosmos/cosmos-sdk/crypto/keyring"
|
||||||
|
@ -93,7 +94,7 @@ func Test_runExportCmd(t *testing.T) {
|
||||||
})
|
})
|
||||||
|
|
||||||
path := sdk.GetConfig().GetFullBIP44Path()
|
path := sdk.GetConfig().GetFullBIP44Path()
|
||||||
_, err = kb.NewAccount("keyname1", testutil.TestMnemonic, "", path, hd.Secp256k1)
|
_, err = kb.NewAccount("keyname1", testdata.TestMnemonic, "", path, hd.Secp256k1)
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
|
||||||
clientCtx := client.Context{}.
|
clientCtx := client.Context{}.
|
||||||
|
|
|
@ -14,6 +14,7 @@ import (
|
||||||
"github.com/cosmos/cosmos-sdk/crypto/keyring"
|
"github.com/cosmos/cosmos-sdk/crypto/keyring"
|
||||||
"github.com/cosmos/cosmos-sdk/simapp"
|
"github.com/cosmos/cosmos-sdk/simapp"
|
||||||
"github.com/cosmos/cosmos-sdk/testutil"
|
"github.com/cosmos/cosmos-sdk/testutil"
|
||||||
|
"github.com/cosmos/cosmos-sdk/testutil/testdata"
|
||||||
sdk "github.com/cosmos/cosmos-sdk/types"
|
sdk "github.com/cosmos/cosmos-sdk/types"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -33,7 +34,7 @@ func Test_runListCmd(t *testing.T) {
|
||||||
ctx := context.WithValue(context.Background(), client.ClientContextKey, &clientCtx)
|
ctx := context.WithValue(context.Background(), client.ClientContextKey, &clientCtx)
|
||||||
|
|
||||||
path := "" //sdk.GetConfig().GetFullBIP44Path()
|
path := "" //sdk.GetConfig().GetFullBIP44Path()
|
||||||
_, err = kb.NewAccount("something", testutil.TestMnemonic, "", path, hd.Secp256k1)
|
_, err = kb.NewAccount("something", testdata.TestMnemonic, "", path, hd.Secp256k1)
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
|
||||||
t.Cleanup(func() {
|
t.Cleanup(func() {
|
||||||
|
|
|
@ -13,6 +13,7 @@ import (
|
||||||
"github.com/cosmos/cosmos-sdk/crypto/keyring"
|
"github.com/cosmos/cosmos-sdk/crypto/keyring"
|
||||||
"github.com/cosmos/cosmos-sdk/simapp"
|
"github.com/cosmos/cosmos-sdk/simapp"
|
||||||
"github.com/cosmos/cosmos-sdk/testutil"
|
"github.com/cosmos/cosmos-sdk/testutil"
|
||||||
|
"github.com/cosmos/cosmos-sdk/testutil/testdata"
|
||||||
sdk "github.com/cosmos/cosmos-sdk/types"
|
sdk "github.com/cosmos/cosmos-sdk/types"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -36,7 +37,7 @@ func Test_runRenameCmd(t *testing.T) {
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
|
||||||
// put fakeKeyName1 in keyring
|
// put fakeKeyName1 in keyring
|
||||||
_, err = kb.NewAccount(fakeKeyName1, testutil.TestMnemonic, "", path, hd.Secp256k1)
|
_, err = kb.NewAccount(fakeKeyName1, testdata.TestMnemonic, "", path, hd.Secp256k1)
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
|
||||||
clientCtx := client.Context{}.
|
clientCtx := client.Context{}.
|
||||||
|
|
|
@ -16,6 +16,7 @@ import (
|
||||||
cryptotypes "github.com/cosmos/cosmos-sdk/crypto/types"
|
cryptotypes "github.com/cosmos/cosmos-sdk/crypto/types"
|
||||||
"github.com/cosmos/cosmos-sdk/simapp"
|
"github.com/cosmos/cosmos-sdk/simapp"
|
||||||
"github.com/cosmos/cosmos-sdk/testutil"
|
"github.com/cosmos/cosmos-sdk/testutil"
|
||||||
|
"github.com/cosmos/cosmos-sdk/testutil/testdata"
|
||||||
sdk "github.com/cosmos/cosmos-sdk/types"
|
sdk "github.com/cosmos/cosmos-sdk/types"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -76,11 +77,11 @@ func Test_runShowCmd(t *testing.T) {
|
||||||
})
|
})
|
||||||
|
|
||||||
path := hd.NewFundraiserParams(1, sdk.CoinType, 0).String()
|
path := hd.NewFundraiserParams(1, sdk.CoinType, 0).String()
|
||||||
_, err = kb.NewAccount(fakeKeyName1, testutil.TestMnemonic, "", path, hd.Secp256k1)
|
_, err = kb.NewAccount(fakeKeyName1, testdata.TestMnemonic, "", path, hd.Secp256k1)
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
|
||||||
path2 := hd.NewFundraiserParams(1, sdk.CoinType, 1).String()
|
path2 := hd.NewFundraiserParams(1, sdk.CoinType, 1).String()
|
||||||
_, err = kb.NewAccount(fakeKeyName2, testutil.TestMnemonic, "", path2, hd.Secp256k1)
|
_, err = kb.NewAccount(fakeKeyName2, testdata.TestMnemonic, "", path2, hd.Secp256k1)
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
|
||||||
// Now try single key
|
// Now try single key
|
||||||
|
|
|
@ -1,3 +1,4 @@
|
||||||
|
//go:build ledger && test_ledger_mock
|
||||||
// +build ledger,test_ledger_mock
|
// +build ledger,test_ledger_mock
|
||||||
|
|
||||||
package ledger
|
package ledger
|
||||||
|
@ -14,7 +15,7 @@ import (
|
||||||
|
|
||||||
"github.com/cosmos/cosmos-sdk/crypto/hd"
|
"github.com/cosmos/cosmos-sdk/crypto/hd"
|
||||||
csecp256k1 "github.com/cosmos/cosmos-sdk/crypto/keys/secp256k1"
|
csecp256k1 "github.com/cosmos/cosmos-sdk/crypto/keys/secp256k1"
|
||||||
"github.com/cosmos/cosmos-sdk/testutil"
|
"github.com/cosmos/cosmos-sdk/testutil/testdata"
|
||||||
sdk "github.com/cosmos/cosmos-sdk/types"
|
sdk "github.com/cosmos/cosmos-sdk/types"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -45,7 +46,7 @@ func (mock LedgerSECP256K1Mock) GetPublicKeySECP256K1(derivationPath []uint32) (
|
||||||
return nil, errors.New("Invalid derivation path")
|
return nil, errors.New("Invalid derivation path")
|
||||||
}
|
}
|
||||||
|
|
||||||
seed, err := bip39.NewSeedWithErrorChecking(testutil.TestMnemonic, "")
|
seed, err := bip39.NewSeedWithErrorChecking(testdata.TestMnemonic, "")
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
@ -87,7 +88,7 @@ func (mock LedgerSECP256K1Mock) GetAddressPubKeySECP256K1(derivationPath []uint3
|
||||||
|
|
||||||
func (mock LedgerSECP256K1Mock) SignSECP256K1(derivationPath []uint32, message []byte) ([]byte, error) {
|
func (mock LedgerSECP256K1Mock) SignSECP256K1(derivationPath []uint32, message []byte) ([]byte, error) {
|
||||||
path := hd.NewParams(derivationPath[0], derivationPath[1], derivationPath[2], derivationPath[3] != 0, derivationPath[4])
|
path := hd.NewParams(derivationPath[0], derivationPath[1], derivationPath[2], derivationPath[3] != 0, derivationPath[4])
|
||||||
seed, err := bip39.NewSeedWithErrorChecking(testutil.TestMnemonic, "")
|
seed, err := bip39.NewSeedWithErrorChecking(testdata.TestMnemonic, "")
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
|
@ -9,7 +9,7 @@ import (
|
||||||
"github.com/cosmos/cosmos-sdk/codec/legacy"
|
"github.com/cosmos/cosmos-sdk/codec/legacy"
|
||||||
"github.com/cosmos/cosmos-sdk/crypto/hd"
|
"github.com/cosmos/cosmos-sdk/crypto/hd"
|
||||||
"github.com/cosmos/cosmos-sdk/crypto/types"
|
"github.com/cosmos/cosmos-sdk/crypto/types"
|
||||||
"github.com/cosmos/cosmos-sdk/testutil"
|
"github.com/cosmos/cosmos-sdk/testutil/testdata"
|
||||||
sdk "github.com/cosmos/cosmos-sdk/types"
|
sdk "github.com/cosmos/cosmos-sdk/types"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -33,11 +33,11 @@ func checkDefaultPubKey(t *testing.T, priv types.LedgerPrivKey) {
|
||||||
expectedPkStr := "PubKeySecp256k1{034FEF9CD7C4C63588D3B03FEB5281B9D232CBA34D6F3D71AEE59211FFBFE1FE87}"
|
expectedPkStr := "PubKeySecp256k1{034FEF9CD7C4C63588D3B03FEB5281B9D232CBA34D6F3D71AEE59211FFBFE1FE87}"
|
||||||
require.Equal(t, "eb5ae98721034fef9cd7c4c63588d3b03feb5281b9d232cba34d6f3d71aee59211ffbfe1fe87",
|
require.Equal(t, "eb5ae98721034fef9cd7c4c63588d3b03feb5281b9d232cba34d6f3d71aee59211ffbfe1fe87",
|
||||||
fmt.Sprintf("%x", cdc.Amino.MustMarshalBinaryBare(priv.PubKey())),
|
fmt.Sprintf("%x", cdc.Amino.MustMarshalBinaryBare(priv.PubKey())),
|
||||||
"Is your device using test mnemonic: %s ?", testutil.TestMnemonic)
|
"Is your device using test mnemonic: %s ?", testdata.TestMnemonic)
|
||||||
require.Equal(t, expectedPkStr, priv.PubKey().String())
|
require.Equal(t, expectedPkStr, priv.PubKey().String())
|
||||||
addr := sdk.AccAddress(priv.PubKey().Address()).String()
|
addr := sdk.AccAddress(priv.PubKey().Address()).String()
|
||||||
require.Equal(t, "cosmos1w34k53py5v5xyluazqpq65agyajavep2rflq6h",
|
require.Equal(t, "cosmos1w34k53py5v5xyluazqpq65agyajavep2rflq6h",
|
||||||
addr, "Is your device using test mnemonic: %s ?", testutil.TestMnemonic)
|
addr, "Is your device using test mnemonic: %s ?", testdata.TestMnemonic)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestPublicKeyUnsafeHDPath(t *testing.T) {
|
func TestPublicKeyUnsafeHDPath(t *testing.T) {
|
||||||
|
@ -74,7 +74,7 @@ func TestPublicKeyUnsafeHDPath(t *testing.T) {
|
||||||
|
|
||||||
// in this test we are chekcking if the generated keys are correct.
|
// in this test we are chekcking if the generated keys are correct.
|
||||||
require.Equal(t, expectedAnswers[i], priv.PubKey().String(),
|
require.Equal(t, expectedAnswers[i], priv.PubKey().String(),
|
||||||
"Is your device using test mnemonic: %s ?", testutil.TestMnemonic)
|
"Is your device using test mnemonic: %s ?", testdata.TestMnemonic)
|
||||||
|
|
||||||
// Store and restore
|
// Store and restore
|
||||||
serializedPk := priv.Bytes()
|
serializedPk := priv.Bytes()
|
||||||
|
@ -151,7 +151,7 @@ func TestPublicKeyHDPath(t *testing.T) {
|
||||||
require.Equal(t, addr2, addr)
|
require.Equal(t, addr2, addr)
|
||||||
require.Equal(t,
|
require.Equal(t,
|
||||||
expectedAddrs[i], addr,
|
expectedAddrs[i], addr,
|
||||||
"Is your device using test mnemonic: %s ?", testutil.TestMnemonic)
|
"Is your device using test mnemonic: %s ?", testdata.TestMnemonic)
|
||||||
|
|
||||||
// Check other methods
|
// Check other methods
|
||||||
tmp := priv.(PrivKeyLedgerSecp256k1)
|
tmp := priv.(PrivKeyLedgerSecp256k1)
|
||||||
|
@ -161,7 +161,7 @@ func TestPublicKeyHDPath(t *testing.T) {
|
||||||
// in this test we are chekcking if the generated keys are correct and stored in a right path.
|
// in this test we are chekcking if the generated keys are correct and stored in a right path.
|
||||||
require.Equal(t,
|
require.Equal(t,
|
||||||
expectedPubKeys[i], priv.PubKey().String(),
|
expectedPubKeys[i], priv.PubKey().String(),
|
||||||
"Is your device using test mnemonic: %s ?", testutil.TestMnemonic)
|
"Is your device using test mnemonic: %s ?", testdata.TestMnemonic)
|
||||||
|
|
||||||
// Store and restore
|
// Store and restore
|
||||||
serializedPk := priv.Bytes()
|
serializedPk := priv.Bytes()
|
||||||
|
@ -203,7 +203,7 @@ func TestSignaturesHD(t *testing.T) {
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
|
||||||
valid := pub.VerifySignature(msg, sig)
|
valid := pub.VerifySignature(msg, sig)
|
||||||
require.True(t, valid, "Is your device using test mnemonic: %s ?", testutil.TestMnemonic)
|
require.True(t, valid, "Is your device using test mnemonic: %s ?", testdata.TestMnemonic)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -26,6 +26,7 @@ import (
|
||||||
cryptotypes "github.com/cosmos/cosmos-sdk/crypto/types"
|
cryptotypes "github.com/cosmos/cosmos-sdk/crypto/types"
|
||||||
"github.com/cosmos/cosmos-sdk/server"
|
"github.com/cosmos/cosmos-sdk/server"
|
||||||
srvconfig "github.com/cosmos/cosmos-sdk/server/config"
|
srvconfig "github.com/cosmos/cosmos-sdk/server/config"
|
||||||
|
"github.com/cosmos/cosmos-sdk/testutil"
|
||||||
"github.com/cosmos/cosmos-sdk/testutil/network"
|
"github.com/cosmos/cosmos-sdk/testutil/network"
|
||||||
sdk "github.com/cosmos/cosmos-sdk/types"
|
sdk "github.com/cosmos/cosmos-sdk/types"
|
||||||
"github.com/cosmos/cosmos-sdk/types/module"
|
"github.com/cosmos/cosmos-sdk/types/module"
|
||||||
|
@ -263,7 +264,7 @@ func initTestnetFiles(
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
addr, secret, err := server.GenerateSaveCoinKey(kb, nodeDirName, "", true, algo)
|
addr, secret, err := testutil.GenerateSaveCoinKey(kb, nodeDirName, "", true, algo)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
_ = os.RemoveAll(args.outputDir)
|
_ = os.RemoveAll(args.outputDir)
|
||||||
return err
|
return err
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
package server
|
package testutil
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
|
@ -8,25 +8,30 @@ import (
|
||||||
sdk "github.com/cosmos/cosmos-sdk/types"
|
sdk "github.com/cosmos/cosmos-sdk/types"
|
||||||
)
|
)
|
||||||
|
|
||||||
// GenerateCoinKey returns the address of a public key, along with the secret
|
// GenerateCoinKey generates a new key mnemonic along with its addrress.
|
||||||
// phrase to recover the private key.
|
|
||||||
func GenerateCoinKey(algo keyring.SignatureAlgo, cdc codec.Codec) (sdk.AccAddress, string, error) {
|
func GenerateCoinKey(algo keyring.SignatureAlgo, cdc codec.Codec) (sdk.AccAddress, string, error) {
|
||||||
// generate a private key, with recovery phrase
|
// generate a private key, with mnemonic
|
||||||
k, secret, err := keyring.NewInMemory(cdc).NewMnemonic("name", keyring.English, sdk.GetConfig().GetFullBIP44Path(), keyring.DefaultBIP39Passphrase, algo)
|
info, secret, err := keyring.NewInMemory(cdc).NewMnemonic(
|
||||||
|
"name",
|
||||||
|
keyring.English,
|
||||||
|
sdk.GetConfig().GetFullBIP44Path(),
|
||||||
|
keyring.DefaultBIP39Passphrase,
|
||||||
|
algo,
|
||||||
|
)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return sdk.AccAddress{}, "", err
|
return sdk.AccAddress{}, "", err
|
||||||
}
|
}
|
||||||
|
addr, err := info.GetAddress()
|
||||||
addr, err := k.GetAddress()
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, "", err
|
return sdk.AccAddress{}, "", err
|
||||||
}
|
}
|
||||||
|
|
||||||
return addr, secret, nil
|
return addr, secret, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// GenerateSaveCoinKey returns the address of a public key, along with the secret
|
// GenerateSaveCoinKey generates a new key mnemonic with its addrress.
|
||||||
// phrase to recover the private key.
|
// If mnemonic is provided then it's used for key generation.
|
||||||
|
// The key is saved in the keyring. The function returns error if overwrite=true and the key
|
||||||
|
// already exists.
|
||||||
func GenerateSaveCoinKey(
|
func GenerateSaveCoinKey(
|
||||||
keybase keyring.Keyring,
|
keybase keyring.Keyring,
|
||||||
keyName, mnemonic string,
|
keyName, mnemonic string,
|
||||||
|
@ -44,9 +49,8 @@ func GenerateSaveCoinKey(
|
||||||
return sdk.AccAddress{}, "", fmt.Errorf("key already exists, overwrite is disabled")
|
return sdk.AccAddress{}, "", fmt.Errorf("key already exists, overwrite is disabled")
|
||||||
}
|
}
|
||||||
|
|
||||||
// remove the old key by name if it exists
|
|
||||||
if exists {
|
if exists {
|
||||||
if err = keybase.Delete(keyName); err != nil {
|
if err := keybase.Delete(keyName); err != nil {
|
||||||
return sdk.AccAddress{}, "", fmt.Errorf("failed to overwrite key")
|
return sdk.AccAddress{}, "", fmt.Errorf("failed to overwrite key")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -71,6 +75,5 @@ func GenerateSaveCoinKey(
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, "", err
|
return nil, "", err
|
||||||
}
|
}
|
||||||
|
|
||||||
return addr, secret, nil
|
return addr, secret, nil
|
||||||
}
|
}
|
|
@ -1,4 +1,4 @@
|
||||||
package server_test
|
package testutil
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"testing"
|
"testing"
|
||||||
|
@ -7,7 +7,6 @@ import (
|
||||||
|
|
||||||
"github.com/cosmos/cosmos-sdk/crypto/hd"
|
"github.com/cosmos/cosmos-sdk/crypto/hd"
|
||||||
"github.com/cosmos/cosmos-sdk/crypto/keyring"
|
"github.com/cosmos/cosmos-sdk/crypto/keyring"
|
||||||
"github.com/cosmos/cosmos-sdk/server"
|
|
||||||
"github.com/cosmos/cosmos-sdk/simapp"
|
"github.com/cosmos/cosmos-sdk/simapp"
|
||||||
"github.com/cosmos/cosmos-sdk/types"
|
"github.com/cosmos/cosmos-sdk/types"
|
||||||
)
|
)
|
||||||
|
@ -15,7 +14,7 @@ import (
|
||||||
func TestGenerateCoinKey(t *testing.T) {
|
func TestGenerateCoinKey(t *testing.T) {
|
||||||
t.Parallel()
|
t.Parallel()
|
||||||
cdc := simapp.MakeTestEncodingConfig().Codec
|
cdc := simapp.MakeTestEncodingConfig().Codec
|
||||||
addr, mnemonic, err := server.GenerateCoinKey(hd.Secp256k1, cdc)
|
addr, mnemonic, err := GenerateCoinKey(hd.Secp256k1, cdc)
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
|
||||||
// Test creation
|
// Test creation
|
||||||
|
@ -33,7 +32,7 @@ func TestGenerateSaveCoinKey(t *testing.T) {
|
||||||
kb, err := keyring.New(t.Name(), "test", t.TempDir(), nil, encCfg.Codec)
|
kb, err := keyring.New(t.Name(), "test", t.TempDir(), nil, encCfg.Codec)
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
|
||||||
addr, mnemonic, err := server.GenerateSaveCoinKey(kb, "keyname", "", false, hd.Secp256k1)
|
addr, mnemonic, err := GenerateSaveCoinKey(kb, "keyname", "", false, hd.Secp256k1)
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
|
||||||
// Test key was actually saved
|
// Test key was actually saved
|
||||||
|
@ -59,15 +58,15 @@ func TestGenerateSaveCoinKeyOverwriteFlag(t *testing.T) {
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
|
||||||
keyname := "justakey"
|
keyname := "justakey"
|
||||||
addr1, _, err := server.GenerateSaveCoinKey(kb, keyname, "", false, hd.Secp256k1)
|
addr1, _, err := GenerateSaveCoinKey(kb, keyname, "", false, hd.Secp256k1)
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
|
||||||
// Test overwrite with overwrite=false
|
// Test overwrite with overwrite=false
|
||||||
_, _, err = server.GenerateSaveCoinKey(kb, keyname, "", false, hd.Secp256k1)
|
_, _, err = GenerateSaveCoinKey(kb, keyname, "", false, hd.Secp256k1)
|
||||||
require.Error(t, err)
|
require.Error(t, err)
|
||||||
|
|
||||||
// Test overwrite with overwrite=true
|
// Test overwrite with overwrite=true
|
||||||
addr2, _, err := server.GenerateSaveCoinKey(kb, keyname, "", true, hd.Secp256k1)
|
addr2, _, err := GenerateSaveCoinKey(kb, keyname, "", true, hd.Secp256k1)
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
|
||||||
require.NotEqual(t, addr1, addr2)
|
require.NotEqual(t, addr1, addr2)
|
|
@ -39,6 +39,7 @@ import (
|
||||||
"github.com/cosmos/cosmos-sdk/simapp"
|
"github.com/cosmos/cosmos-sdk/simapp"
|
||||||
"github.com/cosmos/cosmos-sdk/simapp/params"
|
"github.com/cosmos/cosmos-sdk/simapp/params"
|
||||||
storetypes "github.com/cosmos/cosmos-sdk/store/types"
|
storetypes "github.com/cosmos/cosmos-sdk/store/types"
|
||||||
|
"github.com/cosmos/cosmos-sdk/testutil"
|
||||||
sdk "github.com/cosmos/cosmos-sdk/types"
|
sdk "github.com/cosmos/cosmos-sdk/types"
|
||||||
authtypes "github.com/cosmos/cosmos-sdk/x/auth/types"
|
authtypes "github.com/cosmos/cosmos-sdk/x/auth/types"
|
||||||
banktypes "github.com/cosmos/cosmos-sdk/x/bank/types"
|
banktypes "github.com/cosmos/cosmos-sdk/x/bank/types"
|
||||||
|
@ -357,7 +358,7 @@ func New(l Logger, baseDir string, cfg Config) (*Network, error) {
|
||||||
mnemonic = cfg.Mnemonics[i]
|
mnemonic = cfg.Mnemonics[i]
|
||||||
}
|
}
|
||||||
|
|
||||||
addr, secret, err := server.GenerateSaveCoinKey(kb, nodeDirName, mnemonic, true, algo)
|
addr, secret, err := testutil.GenerateSaveCoinKey(kb, nodeDirName, mnemonic, true, algo)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
package testutil
|
package testdata
|
||||||
|
|
||||||
const (
|
const (
|
||||||
// Tests expect a ledger device initialized to the following mnemonic
|
// Tests expect a ledger device initialized to the following mnemonic
|
|
@ -7,7 +7,7 @@ import (
|
||||||
|
|
||||||
"github.com/cosmos/cosmos-sdk/crypto/hd"
|
"github.com/cosmos/cosmos-sdk/crypto/hd"
|
||||||
"github.com/cosmos/cosmos-sdk/crypto/ledger"
|
"github.com/cosmos/cosmos-sdk/crypto/ledger"
|
||||||
"github.com/cosmos/cosmos-sdk/testutil"
|
"github.com/cosmos/cosmos-sdk/testutil/testdata"
|
||||||
sdk "github.com/cosmos/cosmos-sdk/types"
|
sdk "github.com/cosmos/cosmos-sdk/types"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -21,6 +21,5 @@ func TestBeach32ifPbKey(t *testing.T) {
|
||||||
pubKeyAddr, err := MarshalPubKey(AccPK, priv.PubKey())
|
pubKeyAddr, err := MarshalPubKey(AccPK, priv.PubKey())
|
||||||
require.NoError(err)
|
require.NoError(err)
|
||||||
require.Equal("cosmospub1addwnpepqd87l8xhcnrrtzxnkql7k55ph8fr9jarf4hn6udwukfprlalu8lgw0urza0",
|
require.Equal("cosmospub1addwnpepqd87l8xhcnrrtzxnkql7k55ph8fr9jarf4hn6udwukfprlalu8lgw0urza0",
|
||||||
pubKeyAddr, "Is your device using test mnemonic: %s ?", testutil.TestMnemonic)
|
pubKeyAddr, "Is your device using test mnemonic: %s ?", testdata.TestMnemonic)
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue