Skip to content

Commit

Permalink
test: add cli_test for query
Browse files Browse the repository at this point in the history
Signed-off-by: 170210 <[email protected]>
  • Loading branch information
170210 committed May 21, 2024
1 parent dab544e commit 710e64e
Show file tree
Hide file tree
Showing 3 changed files with 354 additions and 0 deletions.
18 changes: 18 additions & 0 deletions x/fswap/client/testutil/cli_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
//go:build norace
// +build norace

package testutil

import (
"testing"

"github.com/stretchr/testify/suite"

"github.com/Finschia/finschia-sdk/testutil/network"
)

func TestIntegrationTestSuite(t *testing.T) {
cfg := network.DefaultConfig()
cfg.NumValidators = 1
suite.Run(t, NewIntegrationTestSuite(cfg))
}
245 changes: 245 additions & 0 deletions x/fswap/client/testutil/query.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,245 @@
package testutil

import (
clitestutil "github.com/Finschia/finschia-sdk/testutil/cli"
sdk "github.com/Finschia/finschia-sdk/types"
"github.com/Finschia/finschia-sdk/types/query"
"github.com/Finschia/finschia-sdk/x/fswap/client/cli"
fswaptypes "github.com/Finschia/finschia-sdk/x/fswap/types"
"github.com/gogo/protobuf/proto"
)

func (s *IntegrationTestSuite) TestCmdQuerySwapped() {
val := s.network.Validators[0]
clientCtx := val.ClientCtx
// avoid printing as yaml from CLI command
clientCtx.OutputFormat = "JSON"

Check failure on line 16 in x/fswap/client/testutil/query.go

View workflow job for this annotation

GitHub Actions / golangci-lint

string `JSON` has 4 occurrences, make it a constant (goconst)

fromDenom := s.cfg.BondDenom
toDenom := s.toDenom.Base

testCases := []struct {
name string
args []string
expectErr bool
expected proto.Message
}{
{
"valid query",
[]string{fromDenom, toDenom},
false,
&fswaptypes.QuerySwappedResponse{
FromCoinAmount: sdk.NewCoin(fromDenom, sdk.ZeroInt()),
ToCoinAmount: sdk.NewCoin(toDenom, sdk.ZeroInt()),
},
},
{
"wrong number of args",
[]string{fromDenom, toDenom, "extra"},
true,
nil,
},
{
"invalid fromDenom",
[]string{"", toDenom},
true,
nil,
},
{
"invalid toDenom",
[]string{fromDenom, ""},
true,
nil,
},
}

for _, tc := range testCases {
tc := tc

s.Run(tc.name, func() {
cmd := cli.CmdQuerySwapped()
out, err := clitestutil.ExecTestCLICmd(clientCtx, cmd, tc.args)

if tc.expectErr {
s.Require().Error(err)
} else {
s.Require().NoError(err)
var actual fswaptypes.QuerySwappedResponse
s.Require().NoError(val.ClientCtx.Codec.UnmarshalJSON(out.Bytes(), &actual))
s.Require().Equal(tc.expected, &actual)
}
})
}
}

func (s *IntegrationTestSuite) TestCmdQueryTotalSwappableAmount() {
val := s.network.Validators[0]
clientCtx := val.ClientCtx
// avoid printing as yaml from CLI command
clientCtx.OutputFormat = "JSON"

fromDenom := s.cfg.BondDenom
toDenom := s.toDenom.Base

testCases := []struct {
name string
args []string
expectErr bool
expected proto.Message
}{
{
"valid query",
[]string{fromDenom, toDenom},
false,
&fswaptypes.QueryTotalSwappableToCoinAmountResponse{
SwappableAmount: sdk.NewCoin(toDenom, s.dummySwap.AmountCapForToDenom),
},
},
{
"wrong number of args",
[]string{fromDenom, toDenom, "extra"},
true,
nil,
},
{
"invalid fromDenom",
[]string{"", toDenom},
true,
nil,
},
{
"invalid toDenom",
[]string{fromDenom, ""},
true,
nil,
},
}

for _, tc := range testCases {
tc := tc

s.Run(tc.name, func() {
cmd := cli.CmdQueryTotalSwappableAmount()
out, err := clitestutil.ExecTestCLICmd(clientCtx, cmd, tc.args)

if tc.expectErr {
s.Require().Error(err)
} else {
s.Require().NoError(err)
var actual fswaptypes.QueryTotalSwappableToCoinAmountResponse
s.Require().NoError(val.ClientCtx.Codec.UnmarshalJSON(out.Bytes(), &actual))
s.Require().Equal(tc.expected, &actual)
}
})
}
}

func (s *IntegrationTestSuite) TestCmdQuerySwap() {
val := s.network.Validators[0]
clientCtx := val.ClientCtx
// avoid printing as yaml from CLI command
clientCtx.OutputFormat = "JSON"

fromDenom := s.cfg.BondDenom
toDenom := s.toDenom.Base

testCases := []struct {
name string
args []string
expectErr bool
expected proto.Message
}{
{
"valid query",
[]string{fromDenom, toDenom},
false,
&fswaptypes.QuerySwapResponse{
Swap: s.dummySwap,
},
},
{
"wrong number of args",
[]string{fromDenom, toDenom, "extra"},
true,
nil,
},
{
"invalid fromDenom",
[]string{"", toDenom},
true,
nil,
},
{
"invalid toDenom",
[]string{fromDenom, ""},
true,
nil,
},
}

for _, tc := range testCases {
tc := tc

s.Run(tc.name, func() {
cmd := cli.CmdQuerySwap()
out, err := clitestutil.ExecTestCLICmd(clientCtx, cmd, tc.args)

if tc.expectErr {
s.Require().Error(err)
} else {
s.Require().NoError(err)
var actual fswaptypes.QuerySwapResponse
s.Require().NoError(val.ClientCtx.Codec.UnmarshalJSON(out.Bytes(), &actual))
s.Require().Equal(tc.expected, &actual)
}
})
}
}

func (s *IntegrationTestSuite) TestCmdQuerySwaps() {
val := s.network.Validators[0]
clientCtx := val.ClientCtx
// avoid printing as yaml from CLI command
clientCtx.OutputFormat = "JSON"

testCases := []struct {
name string
args []string
expectErr bool
expected proto.Message
}{
{
"valid query (default pagination)",
[]string{},
false,
&fswaptypes.QuerySwapsResponse{
Swaps: []fswaptypes.Swap{s.dummySwap},
Pagination: &query.PageResponse{Total: 1},
},
},
{
"invalid query",
[]string{"extra"},
true,
nil,
},
}

for _, tc := range testCases {
tc := tc

s.Run(tc.name, func() {
cmd := cli.CmdQuerySwaps()
out, err := clitestutil.ExecTestCLICmd(clientCtx, cmd, tc.args)

if tc.expectErr {
s.Require().Error(err)
} else {
s.Require().NoError(err)
var actual fswaptypes.QuerySwapsResponse
s.Require().NoError(val.ClientCtx.Codec.UnmarshalJSON(out.Bytes(), &actual))
s.Require().Equal(tc.expected, &actual)
}
})
}
}
91 changes: 91 additions & 0 deletions x/fswap/client/testutil/suite.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,91 @@
package testutil

import (
"github.com/Finschia/finschia-sdk/testutil/network"
sdk "github.com/Finschia/finschia-sdk/types"
banktypes "github.com/Finschia/finschia-sdk/x/bank/types"
fswaptypes "github.com/Finschia/finschia-sdk/x/fswap/types"
"github.com/stretchr/testify/suite"
)

type IntegrationTestSuite struct {
suite.Suite

cfg network.Config
network *network.Network

toDenom banktypes.Metadata
dummySwap fswaptypes.Swap
}

func NewIntegrationTestSuite(cfg network.Config) *IntegrationTestSuite {
return &IntegrationTestSuite{cfg: cfg}
}

func (s *IntegrationTestSuite) SetupSuite() {
s.T().Log("setting up integration test suite")

genesisState := s.cfg.GenesisState
var bankGenesis banktypes.GenesisState
s.Require().NoError(s.cfg.Codec.UnmarshalJSON(genesisState[banktypes.ModuleName], &bankGenesis))
s.toDenom = banktypes.Metadata{
Name: "Dummy Coin",
Symbol: "Dummy",
Description: "The native token of Dummy chain",
DenomUnits: []*banktypes.DenomUnit{
{
Denom: "dummy",
Exponent: 0,
Aliases: []string{},
},
},
Base: "dummy",
Display: "Dummy",
}
bankGenesis.DenomMetadata = []banktypes.Metadata{s.toDenom}
bankDataBz, err := s.cfg.Codec.MarshalJSON(&bankGenesis)
s.Require().NoError(err)
genesisState[banktypes.ModuleName] = bankDataBz

bondDenom := s.cfg.BondDenom
toDenom := s.toDenom.Base

var fswapData fswaptypes.GenesisState
s.Require().NoError(s.cfg.Codec.UnmarshalJSON(genesisState[fswaptypes.ModuleName], &fswapData))
fswapData.SwapStats.SwapCount = 1
s.dummySwap = fswaptypes.Swap{
FromDenom: bondDenom,
ToDenom: toDenom,
AmountCapForToDenom: sdk.NewInt(12340000000000),
SwapRate: sdk.MustNewDecFromStr("1234"),
}

fswapData.Swaps = []fswaptypes.Swap{s.dummySwap}
fswapData.Swappeds = []fswaptypes.Swapped{
{
FromCoinAmount: sdk.Coin{
Denom: bondDenom,
Amount: sdk.ZeroInt(),
},
ToCoinAmount: sdk.Coin{
Denom: toDenom,
Amount: sdk.ZeroInt(),
},
},
}

fswapDataBz, err := s.cfg.Codec.MarshalJSON(&fswapData)
s.Require().NoError(err)
genesisState[fswaptypes.ModuleName] = fswapDataBz
s.cfg.GenesisState = genesisState

s.network = network.New(s.T(), s.cfg)

_, err = s.network.WaitForHeight(1)
s.Require().NoError(err)
}

func (s *IntegrationTestSuite) TearDownSuite() {
s.T().Log("tearing down integration test suite")
s.network.Cleanup()
}

0 comments on commit 710e64e

Please sign in to comment.