* Move PubKey bech32 to legacy package and migrate the usage where possible * update /server * wip * move proto json encoding helper functions to internal * update internal/marshal * wip * update sections which needs legacybech32 * update validators output * fix conflicts * slashing update * add more tests and helper function for ANY JSON serialization * update slashing * Update function documentation * Rename code any-marshal helper functions * Update pubkey unpacking test * Update test comments * solve TestDecodeStore * solve legacytx issues * all code compiles * keyring tests * keyring cleanup * remove AssertMsg * fix some tests * fix add_ledger_test.go * update cli tests * debug cli test * rename clashed bech32 names * linter fixes * update tmservice tests * linter: update legacy deprecated checks * fix names * linting * legacybech32 pubkey type rename * fix staking client * fix test compilation * fix TestGetCmdQuerySigningInfo * rename NewIfcJSONAnyMarshaler * keyring: remove duplicated information from multinfo structure * todo cleanups * Update Changelog * remove some legacybech32 from tests * remove todos * remove printlnJSON from /server CLI and amino encoding * remove protocdc.MarshalJSON * client/show remove duplicated function * remove protocdc package * comment update * remove legacybech32.MustMarshalPubKey from a test * add todo * fix TestPublicKeyUnsafe test * review update * fix bech32 UnmarshalPubKey * Use codec.MarshalIfcJSON * fix linter issues * merging conflict: fix codec.Unmarshal calls * cleanups * Update CHANGELOG.md Co-authored-by: Aaron Craelius <aaron@regen.network> * Reword changelog updates * use pubkey.String for comparison in Test_runAddCmdLedgerWithCustomCoinType * Update GetCmdQuerySigningInfo example * cli: update keys add docs * Add errors AsOf and errors.ErrIO type * restore multisigPubKeyInfo structure bring it back to multiInfo struct * Update codec/proto_codec.go Co-authored-by: Marie Gauthier <marie.gauthier63@gmail.com> * Update crypto/keys/ed25519/ed25519_test.go Co-authored-by: Marie Gauthier <marie.gauthier63@gmail.com> * Update codec/proto_codec.go Co-authored-by: Marie Gauthier <marie.gauthier63@gmail.com> * move pubkey any marshaling tests * Apply suggestions from code review Co-authored-by: Marie Gauthier <marie.gauthier63@gmail.com> * review updates * adding missing return * errors: use IsOf instead of AsOf * keyring: add a correct check for key not found in keyring.Get * add checkKeyNotFound * fix linter issues * fix: keyring key not found check * fix keyring tests * fix linting issues * cli tests * fix: 'simd keys show <key> -p' * fix: TestVerifyMultisignature * rename keyring Bech32... functions to Mk... * fix RunAddCmd * Update pubkey display * wip * add more tests * udate keyring output tests * remove todo from ledger tests * rename MkKeyOutput * Changelog update * solve liner issues * add link to github issue Co-authored-by: Aaron Craelius <aaron@regen.network> Co-authored-by: Marie Gauthier <marie.gauthier63@gmail.com>
95 lines
2.6 KiB
Go
95 lines
2.6 KiB
Go
package cli
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/spf13/pflag"
|
|
"github.com/stretchr/testify/require"
|
|
|
|
"github.com/cosmos/cosmos-sdk/client/flags"
|
|
"github.com/cosmos/cosmos-sdk/crypto/keys/ed25519"
|
|
)
|
|
|
|
func TestPrepareConfigForTxCreateValidator(t *testing.T) {
|
|
chainID := "chainID"
|
|
ip := "1.1.1.1"
|
|
nodeID := "nodeID"
|
|
privKey := ed25519.GenPrivKey()
|
|
valPubKey := privKey.PubKey()
|
|
moniker := "DefaultMoniker"
|
|
mkTxValCfg := func(amount, commission, commissionMax, commissionMaxChange, minSelfDelegation string) TxCreateValidatorConfig {
|
|
return TxCreateValidatorConfig{
|
|
IP: ip,
|
|
ChainID: chainID,
|
|
NodeID: nodeID,
|
|
PubKey: valPubKey,
|
|
Moniker: moniker,
|
|
Amount: amount,
|
|
CommissionRate: commission,
|
|
CommissionMaxRate: commissionMax,
|
|
CommissionMaxChangeRate: commissionMaxChange,
|
|
MinSelfDelegation: minSelfDelegation,
|
|
}
|
|
}
|
|
|
|
tests := []struct {
|
|
name string
|
|
fsModify func(fs *pflag.FlagSet)
|
|
expectedCfg TxCreateValidatorConfig
|
|
}{
|
|
{
|
|
name: "all defaults",
|
|
fsModify: func(fs *pflag.FlagSet) {
|
|
return
|
|
},
|
|
expectedCfg: mkTxValCfg(defaultAmount, "0.1", "0.2", "0.01", "1"),
|
|
}, {
|
|
name: "Custom amount",
|
|
fsModify: func(fs *pflag.FlagSet) {
|
|
fs.Set(FlagAmount, "2000stake")
|
|
},
|
|
expectedCfg: mkTxValCfg("2000stake", "0.1", "0.2", "0.01", "1"),
|
|
}, {
|
|
name: "Custom commission rate",
|
|
fsModify: func(fs *pflag.FlagSet) {
|
|
fs.Set(FlagCommissionRate, "0.54")
|
|
},
|
|
expectedCfg: mkTxValCfg(defaultAmount, "0.54", "0.2", "0.01", "1"),
|
|
}, {
|
|
name: "Custom commission max rate",
|
|
fsModify: func(fs *pflag.FlagSet) {
|
|
fs.Set(FlagCommissionMaxRate, "0.89")
|
|
},
|
|
expectedCfg: mkTxValCfg(defaultAmount, "0.1", "0.89", "0.01", "1"),
|
|
}, {
|
|
name: "Custom commission max change rate",
|
|
fsModify: func(fs *pflag.FlagSet) {
|
|
fs.Set(FlagCommissionMaxChangeRate, "0.55")
|
|
},
|
|
expectedCfg: mkTxValCfg(defaultAmount, "0.1", "0.2", "0.55", "1"),
|
|
},
|
|
{
|
|
name: "Custom min self delegations",
|
|
fsModify: func(fs *pflag.FlagSet) {
|
|
fs.Set(FlagMinSelfDelegation, "0.33")
|
|
},
|
|
expectedCfg: mkTxValCfg(defaultAmount, "0.1", "0.2", "0.01", "0.33"),
|
|
},
|
|
}
|
|
|
|
for _, tc := range tests {
|
|
tc := tc
|
|
t.Run(tc.name, func(t *testing.T) {
|
|
fs, _ := CreateValidatorMsgFlagSet(ip)
|
|
fs.String(flags.FlagName, "", "name of private key with which to sign the gentx")
|
|
|
|
tc.fsModify(fs)
|
|
|
|
cvCfg, err := PrepareConfigForTxCreateValidator(fs, moniker, nodeID, chainID, valPubKey)
|
|
require.NoError(t, err)
|
|
|
|
require.Equal(t, tc.expectedCfg, cvCfg)
|
|
})
|
|
}
|
|
}
|