* 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>
98 lines
2.3 KiB
Go
98 lines
2.3 KiB
Go
package keys_test
|
|
|
|
import (
|
|
"bytes"
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
"github.com/cosmos/cosmos-sdk/client/keys"
|
|
"github.com/cosmos/cosmos-sdk/crypto/keyring"
|
|
)
|
|
|
|
type testCases struct {
|
|
Keys []keyring.KeyOutput
|
|
Answers []keyring.KeyOutput
|
|
JSON [][]byte
|
|
}
|
|
|
|
func getTestCases() testCases {
|
|
return testCases{
|
|
// nolint:govet
|
|
[]keyring.KeyOutput{
|
|
{"A", "B", "C", "D", "E"},
|
|
{"A", "B", "C", "D", ""},
|
|
{"", "B", "C", "D", ""},
|
|
{"", "", "", "", ""},
|
|
},
|
|
make([]keyring.KeyOutput, 4),
|
|
[][]byte{
|
|
[]byte(`{"name":"A","type":"B","address":"C","pubkey":"D","mnemonic":"E"}`),
|
|
[]byte(`{"name":"A","type":"B","address":"C","pubkey":"D"}`),
|
|
[]byte(`{"name":"","type":"B","address":"C","pubkey":"D"}`),
|
|
[]byte(`{"name":"","type":"","address":"","pubkey":""}`),
|
|
},
|
|
}
|
|
}
|
|
|
|
func TestMarshalJSON(t *testing.T) {
|
|
type args struct {
|
|
o keyring.KeyOutput
|
|
}
|
|
|
|
data := getTestCases()
|
|
|
|
tests := []struct {
|
|
name string
|
|
args args
|
|
want []byte
|
|
wantErr bool
|
|
}{
|
|
{"basic", args{data.Keys[0]}, data.JSON[0], false},
|
|
{"mnemonic is optional", args{data.Keys[1]}, data.JSON[1], false},
|
|
|
|
// REVIEW: Are the next results expected??
|
|
{"empty name", args{data.Keys[2]}, data.JSON[2], false},
|
|
{"empty object", args{data.Keys[3]}, data.JSON[3], false},
|
|
}
|
|
for _, tt := range tests {
|
|
tt := tt
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
got, err := keys.MarshalJSON(tt.args.o)
|
|
require.Equal(t, tt.wantErr, err != nil)
|
|
require.True(t, bytes.Equal(got, tt.want))
|
|
})
|
|
}
|
|
}
|
|
|
|
func TestUnmarshalJSON(t *testing.T) {
|
|
type args struct {
|
|
bz []byte
|
|
ptr interface{}
|
|
}
|
|
|
|
data := getTestCases()
|
|
|
|
tests := []struct {
|
|
name string
|
|
args args
|
|
wantErr bool
|
|
}{
|
|
{"basic", args{data.JSON[0], &data.Answers[0]}, false},
|
|
{"mnemonic is optional", args{data.JSON[1], &data.Answers[1]}, false},
|
|
|
|
// REVIEW: Are the next results expected??
|
|
{"empty name", args{data.JSON[2], &data.Answers[2]}, false},
|
|
{"empty object", args{data.JSON[3], &data.Answers[3]}, false},
|
|
}
|
|
for idx, tt := range tests {
|
|
idx, tt := idx, tt
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
err := keys.UnmarshalJSON(tt.args.bz, tt.args.ptr)
|
|
require.Equal(t, tt.wantErr, err != nil)
|
|
// Confirm deserialized objects are the same
|
|
require.Equal(t, data.Keys[idx], data.Answers[idx])
|
|
})
|
|
}
|
|
}
|