test(client): add a fuzz test for QueryBalance (#15763)
This commit is contained in:
parent
491cf3babe
commit
c3fd0e7c64
60
client/fuzz_test.go
Normal file
60
client/fuzz_test.go
Normal file
@ -0,0 +1,60 @@
|
||||
package client_test
|
||||
|
||||
import (
|
||||
"context"
|
||||
"testing"
|
||||
|
||||
"google.golang.org/grpc"
|
||||
"google.golang.org/grpc/metadata"
|
||||
|
||||
"github.com/cosmos/cosmos-sdk/testutil/testdata"
|
||||
sdk "github.com/cosmos/cosmos-sdk/types"
|
||||
"github.com/cosmos/cosmos-sdk/x/bank/types"
|
||||
)
|
||||
|
||||
type fuzzSuite struct {
|
||||
IntegrationTestSuite
|
||||
}
|
||||
|
||||
func (fz *fuzzSuite) FuzzQueryBalance(f *testing.F) {
|
||||
if testing.Short() {
|
||||
f.Skip("In -short mode")
|
||||
}
|
||||
|
||||
// gRPC query to test service should work
|
||||
testRes, err := fz.testClient.Echo(context.Background(), &testdata.EchoRequest{Message: "hello"})
|
||||
fz.Require().NoError(err)
|
||||
fz.Require().Equal("hello", testRes.Message)
|
||||
|
||||
// 1. Generate some seeds.
|
||||
bz, err := fz.cdc.Marshal(&types.QueryBalanceRequest{
|
||||
Address: fz.genesisAccount.GetAddress().String(),
|
||||
Denom: sdk.DefaultBondDenom,
|
||||
})
|
||||
fz.Require().NoError(err)
|
||||
f.Add(bz)
|
||||
|
||||
// 2. Now fuzz it and ensure that we don't get any panics.
|
||||
ctx := context.Background()
|
||||
f.Fuzz(func(t *testing.T, in []byte) {
|
||||
qbReq := new(types.QueryBalanceRequest)
|
||||
if err := fz.cdc.Unmarshal(in, qbReq); err != nil {
|
||||
return
|
||||
}
|
||||
|
||||
// gRPC query to bank service should work
|
||||
var header metadata.MD
|
||||
_, _ = fz.bankClient.Balance(
|
||||
ctx,
|
||||
qbReq,
|
||||
grpc.Header(&header),
|
||||
)
|
||||
})
|
||||
}
|
||||
|
||||
func FuzzQueryBalance(f *testing.F) {
|
||||
fzs := new(fuzzSuite)
|
||||
fzs.SetT(new(testing.T))
|
||||
fzs.SetupSuite()
|
||||
fzs.FuzzQueryBalance(f)
|
||||
}
|
||||
@ -33,6 +33,7 @@ type IntegrationTestSuite struct {
|
||||
suite.Suite
|
||||
|
||||
ctx sdk.Context
|
||||
cdc codec.Codec
|
||||
genesisAccount *authtypes.BaseAccount
|
||||
bankClient types.QueryClient
|
||||
testClient testdata.QueryClient
|
||||
@ -96,6 +97,7 @@ func (s *IntegrationTestSuite) SetupSuite() {
|
||||
// end of app init
|
||||
|
||||
s.ctx = app.BaseApp.NewContext(false, cmtproto.Header{})
|
||||
s.cdc = cdc
|
||||
queryHelper := baseapp.NewQueryServerTestHelper(s.ctx, interfaceRegistry)
|
||||
types.RegisterQueryServer(queryHelper, bankKeeper)
|
||||
testdata.RegisterQueryServer(queryHelper, testdata.QueryImpl{})
|
||||
|
||||
2
client/testdata/fuzz/FuzzQueryBalance/4bf93f2225e526ac
vendored
Normal file
2
client/testdata/fuzz/FuzzQueryBalance/4bf93f2225e526ac
vendored
Normal file
@ -0,0 +1,2 @@
|
||||
go test fuzz v1
|
||||
[]byte("\n-cosmos1wrq8cagsama0xwf2vmlzgrkyynfsxuyhturvyz\x12\x0500000")
|
||||
Loading…
Reference in New Issue
Block a user