2019-06-15 05:34:11 -07:00
|
|
|
package client_test
|
|
|
|
|
|
|
|
import (
|
2020-07-02 06:02:28 -07:00
|
|
|
"context"
|
|
|
|
"fmt"
|
2019-06-15 05:34:11 -07:00
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/spf13/cobra"
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
|
|
|
|
"github.com/cosmos/cosmos-sdk/client"
|
2020-07-02 06:02:28 -07:00
|
|
|
"github.com/cosmos/cosmos-sdk/client/flags"
|
2020-07-09 23:55:48 -07:00
|
|
|
"github.com/cosmos/cosmos-sdk/testutil"
|
2019-06-15 05:34:11 -07:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestValidateCmd(t *testing.T) {
|
|
|
|
// setup root and subcommands
|
|
|
|
rootCmd := &cobra.Command{
|
|
|
|
Use: "root",
|
|
|
|
}
|
|
|
|
queryCmd := &cobra.Command{
|
|
|
|
Use: "query",
|
|
|
|
}
|
|
|
|
rootCmd.AddCommand(queryCmd)
|
|
|
|
|
|
|
|
// command being tested
|
|
|
|
distCmd := &cobra.Command{
|
|
|
|
Use: "distr",
|
|
|
|
DisableFlagParsing: true,
|
|
|
|
SuggestionsMinimumDistance: 2,
|
|
|
|
}
|
|
|
|
queryCmd.AddCommand(distCmd)
|
|
|
|
|
|
|
|
commissionCmd := &cobra.Command{
|
|
|
|
Use: "commission",
|
|
|
|
}
|
|
|
|
distCmd.AddCommand(commissionCmd)
|
|
|
|
|
|
|
|
tests := []struct {
|
|
|
|
reason string
|
|
|
|
args []string
|
|
|
|
wantErr bool
|
|
|
|
}{
|
2020-04-22 11:24:13 -07:00
|
|
|
{"misspelled command", []string{"COMMISSION"}, true},
|
2019-06-15 05:34:11 -07:00
|
|
|
{"no command provided", []string{}, false},
|
2020-04-22 11:24:13 -07:00
|
|
|
{"help flag", []string{"COMMISSION", "--help"}, false},
|
|
|
|
{"shorthand help flag", []string{"COMMISSION", "-h"}, false},
|
2020-04-04 11:24:11 -07:00
|
|
|
{"flag only, no command provided", []string{"--gas", "1000atom"}, false},
|
2020-04-22 11:24:13 -07:00
|
|
|
{"flag and misspelled command", []string{"--gas", "1000atom", "COMMISSION"}, true},
|
2019-06-15 05:34:11 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
for _, tt := range tests {
|
|
|
|
err := client.ValidateCmd(distCmd, tt.args)
|
|
|
|
require.Equal(t, tt.wantErr, err != nil, tt.reason)
|
|
|
|
}
|
|
|
|
}
|
2020-07-02 06:02:28 -07:00
|
|
|
|
|
|
|
func TestSetCmdClientContextHandler(t *testing.T) {
|
|
|
|
initClientCtx := client.Context{}.WithHomeDir("/foo/bar").WithChainID("test-chain")
|
|
|
|
|
|
|
|
newCmd := func() *cobra.Command {
|
|
|
|
c := &cobra.Command{
|
|
|
|
PreRunE: func(cmd *cobra.Command, args []string) error {
|
|
|
|
return client.SetCmdClientContextHandler(initClientCtx, cmd)
|
|
|
|
},
|
|
|
|
RunE: func(cmd *cobra.Command, _ []string) error {
|
|
|
|
clientCtx := client.GetClientContextFromCmd(cmd)
|
|
|
|
_, err := client.ReadTxCommandFlags(clientCtx, cmd.Flags())
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
c.Flags().String(flags.FlagChainID, "", "network chain ID")
|
|
|
|
|
|
|
|
return c
|
|
|
|
}
|
|
|
|
|
|
|
|
testCases := []struct {
|
|
|
|
name string
|
|
|
|
expectedContext client.Context
|
|
|
|
args []string
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
"no flags set",
|
|
|
|
initClientCtx,
|
|
|
|
[]string{},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"flags set",
|
|
|
|
initClientCtx.WithChainID("new-chain-id"),
|
|
|
|
[]string{
|
|
|
|
fmt.Sprintf("--%s=new-chain-id", flags.FlagChainID),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, tc := range testCases {
|
|
|
|
tc := tc
|
|
|
|
|
|
|
|
t.Run(tc.name, func(t *testing.T) {
|
|
|
|
ctx := context.Background()
|
|
|
|
ctx = context.WithValue(ctx, client.ClientContextKey, &client.Context{})
|
|
|
|
|
|
|
|
cmd := newCmd()
|
2020-07-09 23:55:48 -07:00
|
|
|
_ = testutil.ApplyMockIODiscardOutErr(cmd)
|
2020-07-02 06:02:28 -07:00
|
|
|
cmd.SetArgs(tc.args)
|
|
|
|
|
|
|
|
require.NoError(t, cmd.ExecuteContext(ctx))
|
|
|
|
|
|
|
|
clientCtx := client.GetClientContextFromCmd(cmd)
|
|
|
|
require.Equal(t, tc.expectedContext, clientCtx)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|