Some checks failed
CodeQL / Analyze (push) Waiting to run
golangci-lint / lint (push) Waiting to run
Tests / Code Coverage / build (amd64) (push) Waiting to run
Tests / Code Coverage / build (arm64) (push) Waiting to run
Tests / Code Coverage / unit-tests (map[additional-args:-tags="test_e2e" name:e2e path:./e2e]) (push) Waiting to run
Tests / Code Coverage / unit-tests (map[name:08-wasm path:./modules/light-clients/08-wasm]) (push) Waiting to run
Tests / Code Coverage / unit-tests (map[name:ibc-go path:.]) (push) Waiting to run
Docker Build & Push Simapp (main) / docker-build (push) Has been cancelled
188 lines
5.5 KiB
Go
188 lines
5.5 KiB
Go
package keeper_test
|
|
|
|
import (
|
|
sdk "git.cw.tr/mukan-network/mukan-sdk/types"
|
|
banktypes "git.cw.tr/mukan-network/mukan-sdk/x/bank/types"
|
|
stakingtypes "git.cw.tr/mukan-network/mukan-sdk/x/staking/types"
|
|
|
|
"git.cw.tr/mukan-network/mukan-ibc/modules/apps/27-interchain-accounts/host/keeper"
|
|
"git.cw.tr/mukan-network/mukan-ibc/modules/apps/27-interchain-accounts/host/types"
|
|
transfertypes "git.cw.tr/mukan-network/mukan-ibc/modules/apps/transfer/types"
|
|
ibcerrors "git.cw.tr/mukan-network/mukan-ibc/modules/core/errors"
|
|
)
|
|
|
|
func (suite *KeeperTestSuite) TestModuleQuerySafe() {
|
|
var (
|
|
msg *types.MsgModuleQuerySafe
|
|
expResponses [][]byte
|
|
)
|
|
testCases := []struct {
|
|
name string
|
|
malleate func()
|
|
expErr error
|
|
}{
|
|
{
|
|
"success",
|
|
func() {
|
|
balanceQueryBz, err := banktypes.NewQueryBalanceRequest(suite.chainA.SenderAccount.GetAddress(), sdk.DefaultBondDenom).Marshal()
|
|
suite.Require().NoError(err)
|
|
|
|
queryReq := types.QueryRequest{
|
|
Path: "/cosmos.bank.v1beta1.Query/Balance",
|
|
Data: balanceQueryBz,
|
|
}
|
|
|
|
msg = types.NewMsgModuleQuerySafe(suite.chainA.GetSimApp().ICAHostKeeper.GetAuthority(), []types.QueryRequest{queryReq})
|
|
|
|
balance := suite.chainA.GetSimApp().BankKeeper.GetBalance(suite.chainA.GetContext(), suite.chainA.SenderAccount.GetAddress(), sdk.DefaultBondDenom)
|
|
|
|
expResp := banktypes.QueryBalanceResponse{Balance: &balance}
|
|
expRespBz, err := expResp.Marshal()
|
|
suite.Require().NoError(err)
|
|
|
|
expResponses = [][]byte{expRespBz}
|
|
},
|
|
nil,
|
|
},
|
|
{
|
|
"success: multiple queries",
|
|
func() {
|
|
balanceQueryBz, err := banktypes.NewQueryBalanceRequest(suite.chainA.SenderAccount.GetAddress(), sdk.DefaultBondDenom).Marshal()
|
|
suite.Require().NoError(err)
|
|
|
|
queryReq := types.QueryRequest{
|
|
Path: "/cosmos.bank.v1beta1.Query/Balance",
|
|
Data: balanceQueryBz,
|
|
}
|
|
|
|
paramsQuery := stakingtypes.QueryParamsRequest{}
|
|
paramsQueryBz, err := paramsQuery.Marshal()
|
|
suite.Require().NoError(err)
|
|
|
|
paramsQueryReq := types.QueryRequest{
|
|
Path: "/cosmos.staking.v1beta1.Query/Params",
|
|
Data: paramsQueryBz,
|
|
}
|
|
|
|
msg = types.NewMsgModuleQuerySafe(suite.chainA.GetSimApp().ICAHostKeeper.GetAuthority(), []types.QueryRequest{queryReq, paramsQueryReq})
|
|
|
|
balance := suite.chainA.GetSimApp().BankKeeper.GetBalance(suite.chainA.GetContext(), suite.chainA.SenderAccount.GetAddress(), sdk.DefaultBondDenom)
|
|
|
|
expResp := banktypes.QueryBalanceResponse{Balance: &balance}
|
|
expRespBz, err := expResp.Marshal()
|
|
suite.Require().NoError(err)
|
|
|
|
params, err := suite.chainA.GetSimApp().StakingKeeper.GetParams(suite.chainA.GetContext())
|
|
suite.Require().NoError(err)
|
|
expParamsResp := stakingtypes.QueryParamsResponse{Params: params}
|
|
expParamsRespBz, err := expParamsResp.Marshal()
|
|
suite.Require().NoError(err)
|
|
|
|
expResponses = [][]byte{expRespBz, expParamsRespBz}
|
|
},
|
|
nil,
|
|
},
|
|
{
|
|
"failure: not module query safe",
|
|
func() {
|
|
balanceQueryBz, err := banktypes.NewQueryBalanceRequest(suite.chainA.SenderAccount.GetAddress(), sdk.DefaultBondDenom).Marshal()
|
|
suite.Require().NoError(err)
|
|
|
|
queryReq := types.QueryRequest{
|
|
Path: "/cosmos.bank.v1beta1.Query/Balance",
|
|
Data: balanceQueryBz,
|
|
}
|
|
|
|
paramsQuery := transfertypes.QueryParamsRequest{}
|
|
paramsQueryBz, err := paramsQuery.Marshal()
|
|
suite.Require().NoError(err)
|
|
|
|
paramsQueryReq := types.QueryRequest{
|
|
Path: "/ibc.applications.transfer.v1.Query/Params",
|
|
Data: paramsQueryBz,
|
|
}
|
|
|
|
msg = types.NewMsgModuleQuerySafe(suite.chainA.GetSimApp().ICAHostKeeper.GetAuthority(), []types.QueryRequest{queryReq, paramsQueryReq})
|
|
},
|
|
ibcerrors.ErrInvalidRequest,
|
|
},
|
|
{
|
|
"failure: invalid query path",
|
|
func() {
|
|
balanceQueryBz, err := banktypes.NewQueryBalanceRequest(suite.chainA.SenderAccount.GetAddress(), sdk.DefaultBondDenom).Marshal()
|
|
suite.Require().NoError(err)
|
|
|
|
queryReq := types.QueryRequest{
|
|
Path: "/cosmos.invalid.Query/Invalid",
|
|
Data: balanceQueryBz,
|
|
}
|
|
|
|
msg = types.NewMsgModuleQuerySafe(suite.chainA.GetSimApp().ICAHostKeeper.GetAuthority(), []types.QueryRequest{queryReq})
|
|
},
|
|
ibcerrors.ErrInvalidRequest,
|
|
},
|
|
}
|
|
|
|
for _, tc := range testCases {
|
|
suite.Run(tc.name, func() {
|
|
suite.SetupTest()
|
|
|
|
// reset
|
|
msg = nil
|
|
expResponses = nil
|
|
|
|
tc.malleate()
|
|
|
|
ctx := suite.chainA.GetContext()
|
|
msgServer := keeper.NewMsgServerImpl(&suite.chainA.GetSimApp().ICAHostKeeper)
|
|
res, err := msgServer.ModuleQuerySafe(ctx, msg)
|
|
|
|
if tc.expErr == nil {
|
|
suite.Require().NoError(err)
|
|
suite.Require().NotNil(res)
|
|
|
|
suite.Require().ElementsMatch(expResponses, res.Responses)
|
|
} else {
|
|
suite.Require().ErrorIs(err, tc.expErr)
|
|
suite.Require().Nil(res)
|
|
}
|
|
})
|
|
}
|
|
}
|
|
|
|
func (suite *KeeperTestSuite) TestUpdateParams() {
|
|
testCases := []struct {
|
|
name string
|
|
msg *types.MsgUpdateParams
|
|
expErr error
|
|
}{
|
|
{
|
|
"success",
|
|
types.NewMsgUpdateParams(suite.chainA.GetSimApp().ICAHostKeeper.GetAuthority(), types.DefaultParams()),
|
|
nil,
|
|
},
|
|
{
|
|
"invalid signer address",
|
|
types.NewMsgUpdateParams("signer", types.DefaultParams()),
|
|
ibcerrors.ErrUnauthorized,
|
|
},
|
|
}
|
|
|
|
for _, tc := range testCases {
|
|
suite.Run(tc.name, func() {
|
|
suite.SetupTest()
|
|
|
|
ctx := suite.chainA.GetContext()
|
|
msgServer := keeper.NewMsgServerImpl(&suite.chainA.GetSimApp().ICAHostKeeper)
|
|
res, err := msgServer.UpdateParams(ctx, tc.msg)
|
|
|
|
if tc.expErr == nil {
|
|
suite.Require().NoError(err)
|
|
suite.Require().NotNil(res)
|
|
} else {
|
|
suite.Require().ErrorIs(err, tc.expErr)
|
|
suite.Require().Nil(res)
|
|
}
|
|
})
|
|
}
|
|
}
|