cosmos-sdk/x/staking/keeper/grpc_query_test.go
Lucas Francisco López 467cc6d427
feat: Add consensus address to validator query response (#20434)
Co-authored-by: Facundo Medica <14063057+facundomedica@users.noreply.github.com>
Co-authored-by: Julien Robert <julien@rbrt.fr>
2024-06-21 10:15:03 +00:00

125 lines
3.3 KiB
Go

package keeper_test
import (
gocontext "context"
"fmt"
"cosmossdk.io/x/staking/testutil"
"cosmossdk.io/x/staking/types"
sdk "github.com/cosmos/cosmos-sdk/types"
)
func (s *KeeperTestSuite) TestGRPCQueryValidator() {
ctx, keeper, queryClient := s.ctx, s.stakingKeeper, s.queryClient
require := s.Require()
validator := testutil.NewValidator(s.T(), sdk.ValAddress(PKs[0].Address().Bytes()), PKs[0])
require.NoError(keeper.SetValidator(ctx, validator))
var req *types.QueryValidatorRequest
testCases := []struct {
msg string
malleate func()
expPass bool
}{
{
"empty request",
func() {
req = &types.QueryValidatorRequest{}
},
false,
},
{
"with valid and not existing address",
func() {
req = &types.QueryValidatorRequest{
ValidatorAddr: "cosmosvaloper15jkng8hytwt22lllv6mw4k89qkqehtahd84ptu",
}
},
false,
},
{
"valid request",
func() {
req = &types.QueryValidatorRequest{ValidatorAddr: validator.OperatorAddress}
},
true,
},
}
for _, tc := range testCases {
s.Run(fmt.Sprintf("Case %s", tc.msg), func() {
tc.malleate()
res, err := queryClient.Validator(gocontext.Background(), req)
if tc.expPass {
require.NoError(err)
require.True(validator.Equal(&res.Validator))
} else {
require.Error(err)
require.Nil(res)
}
})
}
}
func (s *KeeperTestSuite) TestGRPCQueryValidators() {
ctx, keeper, queryClient := s.ctx, s.stakingKeeper, s.queryClient
require := s.Require()
// Create and set validators
pkValidator1 := PKs[0]
pkValidator2 := PKs[1]
validator1 := testutil.NewValidator(s.T(), sdk.ValAddress(pkValidator1.Address().Bytes()), pkValidator1)
validator2 := testutil.NewValidator(s.T(), sdk.ValAddress(pkValidator2.Address().Bytes()), pkValidator2)
require.NoError(keeper.SetValidator(ctx, validator1))
require.NoError(keeper.SetValidator(ctx, validator2))
// Create a map to associate consensus addresses with validators
consensusAddrMap := make(map[string]types.Validator)
consAddr1, err := keeper.ConsensusAddressCodec().BytesToString(pkValidator1.Address())
require.NoError(err)
consAddr2, err := keeper.ConsensusAddressCodec().BytesToString(pkValidator2.Address())
require.NoError(err)
consensusAddrMap[consAddr1] = validator1
consensusAddrMap[consAddr2] = validator2
var req *types.QueryValidatorsRequest
testCases := []struct {
msg string
malleate func()
}{
{
"valid request with no status",
func() {
req = &types.QueryValidatorsRequest{}
},
},
{
"valid request with bonded status",
func() {
req = &types.QueryValidatorsRequest{
Status: types.Bonded.String(),
}
},
},
}
for _, tc := range testCases {
s.Run(fmt.Sprintf("Case %s", tc.msg), func() {
tc.malleate()
res, err := queryClient.Validators(gocontext.Background(), req)
require.NoError(err)
require.NotNil(res)
// Verify that the length of both lists is the same
require.Equal(len(res.Validators), len(res.ValidatorInfo))
// Verify that each ValidatorInfo corresponds to the correct Validator and the response match created validators
for i, valInfo := range res.ValidatorInfo {
val, exists := consensusAddrMap[valInfo.ConsensusAddress]
require.True(exists, "Validator not found for consensus address")
require.Equal(val.OperatorAddress, res.Validators[i].OperatorAddress)
}
})
}
}