mirror of
https://github.com/0glabs/0g-chain.git
synced 2025-01-07 14:05:18 +00:00
395b69ac2f
* Add authority, MsgUpdateParams * Add e2e test for x/community UpdateParamsMsg proposal * Ensure new params are different * Add errors and update codec * Update changelog * Use single reused govAuthorityAddr * Add unit tests for authority and msg * Validate authority address * Update proto comment * Check for ErrInvalidSigner in invalid authority error
171 lines
4.2 KiB
Go
171 lines
4.2 KiB
Go
package keeper_test
|
|
|
|
import (
|
|
"testing"
|
|
|
|
sdkmath "cosmossdk.io/math"
|
|
sdk "github.com/cosmos/cosmos-sdk/types"
|
|
authtypes "github.com/cosmos/cosmos-sdk/x/auth/types"
|
|
govtypes "github.com/cosmos/cosmos-sdk/x/gov/types"
|
|
"github.com/stretchr/testify/suite"
|
|
|
|
"github.com/kava-labs/kava/app"
|
|
"github.com/kava-labs/kava/x/community/keeper"
|
|
"github.com/kava-labs/kava/x/community/testutil"
|
|
"github.com/kava-labs/kava/x/community/types"
|
|
)
|
|
|
|
type msgServerTestSuite struct {
|
|
testutil.Suite
|
|
|
|
communityPool sdk.AccAddress
|
|
msgServer types.MsgServer
|
|
}
|
|
|
|
func (suite *msgServerTestSuite) SetupTest() {
|
|
suite.Suite.SetupTest()
|
|
|
|
suite.communityPool = suite.App.GetAccountKeeper().GetModuleAddress(types.ModuleAccountName)
|
|
suite.msgServer = keeper.NewMsgServerImpl(suite.Keeper)
|
|
}
|
|
|
|
func TestMsgServerTestSuite(t *testing.T) {
|
|
suite.Run(t, new(msgServerTestSuite))
|
|
}
|
|
|
|
func (suite *msgServerTestSuite) TestMsgFundCommunityPool() {
|
|
singleCoin := sdk.NewCoins(sdk.NewCoin("ukava", sdkmath.NewInt(2e6)))
|
|
multipleCoins := sdk.NewCoins(
|
|
sdk.NewCoin("ukava", sdkmath.NewInt(3e6)),
|
|
sdk.NewCoin("usdx", sdkmath.NewInt(1e7)),
|
|
)
|
|
testCases := []struct {
|
|
name string
|
|
setup func() *types.MsgFundCommunityPool
|
|
expectedBalance sdk.Coins
|
|
shouldPass bool
|
|
}{
|
|
{
|
|
name: "valid funding of single coin",
|
|
setup: func() *types.MsgFundCommunityPool {
|
|
sender := app.RandomAddress()
|
|
suite.App.FundAccount(suite.Ctx, sender, singleCoin)
|
|
return &types.MsgFundCommunityPool{
|
|
Amount: singleCoin,
|
|
Depositor: sender.String(),
|
|
}
|
|
},
|
|
expectedBalance: singleCoin,
|
|
shouldPass: true,
|
|
},
|
|
{
|
|
name: "valid funding of multiple coins",
|
|
setup: func() *types.MsgFundCommunityPool {
|
|
sender := app.RandomAddress()
|
|
suite.App.FundAccount(suite.Ctx, sender, multipleCoins)
|
|
return &types.MsgFundCommunityPool{
|
|
Amount: multipleCoins,
|
|
Depositor: sender.String(),
|
|
}
|
|
},
|
|
expectedBalance: multipleCoins,
|
|
shouldPass: true,
|
|
},
|
|
{
|
|
name: "invalid - failing message validation",
|
|
setup: func() *types.MsgFundCommunityPool {
|
|
return &types.MsgFundCommunityPool{
|
|
Amount: sdk.NewCoins(),
|
|
Depositor: app.RandomAddress().String(),
|
|
}
|
|
},
|
|
expectedBalance: sdk.NewCoins(),
|
|
shouldPass: false,
|
|
},
|
|
{
|
|
name: "invalid - failing tx, insufficient funds",
|
|
setup: func() *types.MsgFundCommunityPool {
|
|
return &types.MsgFundCommunityPool{
|
|
Amount: singleCoin,
|
|
Depositor: app.RandomAddress().String(),
|
|
}
|
|
},
|
|
expectedBalance: sdk.NewCoins(),
|
|
shouldPass: false,
|
|
},
|
|
}
|
|
|
|
for _, tc := range testCases {
|
|
suite.Run(tc.name, func() {
|
|
suite.SetupTest()
|
|
|
|
msg := tc.setup()
|
|
_, err := suite.msgServer.FundCommunityPool(sdk.WrapSDKContext(suite.Ctx), msg)
|
|
if tc.shouldPass {
|
|
suite.NoError(err)
|
|
} else {
|
|
suite.Error(err)
|
|
}
|
|
|
|
balance := suite.Keeper.GetModuleAccountBalance(suite.Ctx)
|
|
suite.App.CheckBalance(suite.T(), suite.Ctx, suite.communityPool, balance)
|
|
})
|
|
}
|
|
}
|
|
|
|
func (suite *msgServerTestSuite) TestMsgUpdateParams() {
|
|
govAddr := authtypes.NewModuleAddress(govtypes.ModuleName)
|
|
|
|
testCases := []struct {
|
|
name string
|
|
msg types.MsgUpdateParams
|
|
expectedError error
|
|
}{
|
|
{
|
|
name: "valid",
|
|
msg: types.MsgUpdateParams{
|
|
Authority: govAddr.String(),
|
|
Params: types.DefaultParams(),
|
|
},
|
|
expectedError: nil,
|
|
},
|
|
{
|
|
name: "invalid - bad authority",
|
|
msg: types.MsgUpdateParams{
|
|
Authority: sdk.AccAddress{1, 2, 3}.String(),
|
|
Params: types.DefaultParams(),
|
|
},
|
|
expectedError: govtypes.ErrInvalidSigner,
|
|
},
|
|
{
|
|
name: "invalid - empty authority",
|
|
msg: types.MsgUpdateParams{
|
|
Authority: "",
|
|
Params: types.DefaultParams(),
|
|
},
|
|
expectedError: govtypes.ErrInvalidSigner,
|
|
},
|
|
{
|
|
name: "invalid - parameters",
|
|
msg: types.MsgUpdateParams{
|
|
Authority: govAddr.String(),
|
|
Params: types.Params{},
|
|
},
|
|
expectedError: types.ErrInvalidParams,
|
|
},
|
|
}
|
|
|
|
for _, tc := range testCases {
|
|
suite.Run(tc.name, func() {
|
|
suite.SetupTest()
|
|
|
|
_, err := suite.msgServer.UpdateParams(sdk.WrapSDKContext(suite.Ctx), &tc.msg)
|
|
if tc.expectedError == nil {
|
|
suite.NoError(err)
|
|
} else {
|
|
suite.ErrorIs(err, tc.expectedError)
|
|
}
|
|
})
|
|
}
|
|
}
|