mirror of
https://github.com/0glabs/0g-chain.git
synced 2025-01-27 15:35:17 +00:00
add handler tests
This commit is contained in:
parent
196ecf7f30
commit
c231912642
@ -14,8 +14,6 @@ import (
|
|||||||
"github.com/kava-labs/kava/x/committee"
|
"github.com/kava-labs/kava/x/committee"
|
||||||
)
|
)
|
||||||
|
|
||||||
func d(s string) sdk.Dec { return sdk.MustNewDecFromStr(s) }
|
|
||||||
|
|
||||||
type ModuleTestSuite struct {
|
type ModuleTestSuite struct {
|
||||||
suite.Suite
|
suite.Suite
|
||||||
|
|
||||||
|
191
x/committee/handler_test.go
Normal file
191
x/committee/handler_test.go
Normal file
@ -0,0 +1,191 @@
|
|||||||
|
package committee_test
|
||||||
|
|
||||||
|
import (
|
||||||
|
"testing"
|
||||||
|
"time"
|
||||||
|
|
||||||
|
sdk "github.com/cosmos/cosmos-sdk/types"
|
||||||
|
"github.com/cosmos/cosmos-sdk/x/distribution"
|
||||||
|
"github.com/cosmos/cosmos-sdk/x/params"
|
||||||
|
"github.com/stretchr/testify/suite"
|
||||||
|
abci "github.com/tendermint/tendermint/abci/types"
|
||||||
|
|
||||||
|
"github.com/kava-labs/kava/app"
|
||||||
|
cdptypes "github.com/kava-labs/kava/x/cdp/types"
|
||||||
|
"github.com/kava-labs/kava/x/committee"
|
||||||
|
"github.com/kava-labs/kava/x/committee/keeper"
|
||||||
|
"github.com/kava-labs/kava/x/committee/types"
|
||||||
|
)
|
||||||
|
|
||||||
|
// NewDistributionGenesisWithPool creates a default distribution genesis state with some coins in the community pool.
|
||||||
|
func NewDistributionGenesisWithPool(communityPoolCoins sdk.Coins) app.GenesisState {
|
||||||
|
gs := distribution.DefaultGenesisState()
|
||||||
|
gs.FeePool = distribution.FeePool{CommunityPool: sdk.NewDecCoins(communityPoolCoins)}
|
||||||
|
return app.GenesisState{distribution.ModuleName: distribution.ModuleCdc.MustMarshalJSON(gs)}
|
||||||
|
}
|
||||||
|
|
||||||
|
type HandlerTestSuite struct {
|
||||||
|
suite.Suite
|
||||||
|
|
||||||
|
app app.TestApp
|
||||||
|
keeper keeper.Keeper
|
||||||
|
handler sdk.Handler
|
||||||
|
ctx sdk.Context
|
||||||
|
addresses []sdk.AccAddress
|
||||||
|
|
||||||
|
communityPoolAmt sdk.Coins
|
||||||
|
}
|
||||||
|
|
||||||
|
func (suite *HandlerTestSuite) SetupTest() {
|
||||||
|
_, suite.addresses = app.GeneratePrivKeyAddressPairs(5)
|
||||||
|
suite.app = app.NewTestApp()
|
||||||
|
suite.keeper = suite.app.GetCommitteeKeeper()
|
||||||
|
suite.handler = committee.NewHandler(suite.keeper)
|
||||||
|
|
||||||
|
firstBlockTime := time.Date(1998, time.January, 1, 1, 0, 0, 0, time.UTC)
|
||||||
|
testGenesis := types.NewGenesisState(
|
||||||
|
3,
|
||||||
|
[]types.Committee{
|
||||||
|
{
|
||||||
|
ID: 1,
|
||||||
|
Description: "This committee is for testing.",
|
||||||
|
Members: suite.addresses[:3],
|
||||||
|
Permissions: []types.Permission{types.GodPermission{}},
|
||||||
|
VoteThreshold: d("0.5"),
|
||||||
|
ProposalDuration: time.Hour * 24 * 7,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
[]types.Proposal{},
|
||||||
|
[]types.Vote{},
|
||||||
|
)
|
||||||
|
suite.communityPoolAmt = cs(c("ukava", 1000))
|
||||||
|
suite.app.InitializeFromGenesisStates(
|
||||||
|
NewCommitteeGenesisState(suite.app.Codec(), testGenesis),
|
||||||
|
NewDistributionGenesisWithPool(suite.communityPoolAmt),
|
||||||
|
)
|
||||||
|
suite.ctx = suite.app.NewContext(true, abci.Header{Height: 1, Time: firstBlockTime})
|
||||||
|
}
|
||||||
|
|
||||||
|
func (suite *HandlerTestSuite) TestSubmitProposalMsg_Valid() {
|
||||||
|
msg := committee.NewMsgSubmitProposal(
|
||||||
|
params.NewParameterChangeProposal(
|
||||||
|
"A Title",
|
||||||
|
"A description of this proposal.",
|
||||||
|
[]params.ParamChange{{
|
||||||
|
Subspace: cdptypes.ModuleName,
|
||||||
|
Key: string(cdptypes.KeyDebtThreshold),
|
||||||
|
Value: string(types.ModuleCdc.MustMarshalJSON(i(1000000))),
|
||||||
|
}},
|
||||||
|
),
|
||||||
|
suite.addresses[0],
|
||||||
|
1,
|
||||||
|
)
|
||||||
|
|
||||||
|
res := suite.handler(suite.ctx, msg)
|
||||||
|
|
||||||
|
suite.True(res.IsOK())
|
||||||
|
_, found := suite.keeper.GetProposal(suite.ctx, types.Uint64FromBytes(res.Data))
|
||||||
|
suite.True(found)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (suite *HandlerTestSuite) TestSubmitProposalMsg_Invalid() {
|
||||||
|
msg := types.NewMsgSubmitProposal(
|
||||||
|
params.NewParameterChangeProposal(
|
||||||
|
"A Title",
|
||||||
|
"A description of this proposal.",
|
||||||
|
[]params.ParamChange{{
|
||||||
|
Subspace: cdptypes.ModuleName,
|
||||||
|
Key: "nonsense-key",
|
||||||
|
Value: "nonsense-value",
|
||||||
|
}},
|
||||||
|
),
|
||||||
|
suite.addresses[0],
|
||||||
|
1,
|
||||||
|
)
|
||||||
|
|
||||||
|
res := suite.handler(suite.ctx, msg)
|
||||||
|
|
||||||
|
suite.False(res.IsOK())
|
||||||
|
suite.keeper.IterateProposals(suite.ctx, func(p types.Proposal) bool {
|
||||||
|
suite.Fail("proposal found when none should exist")
|
||||||
|
return true
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
func (suite *HandlerTestSuite) TestMsgAddVote_ProposalPass() {
|
||||||
|
previousCDPDebtThreshold := suite.app.GetCDPKeeper().GetParams(suite.ctx).DebtAuctionThreshold
|
||||||
|
newDebtThreshold := previousCDPDebtThreshold.Add(i(1000000))
|
||||||
|
msg := types.NewMsgSubmitProposal(
|
||||||
|
params.NewParameterChangeProposal(
|
||||||
|
"A Title",
|
||||||
|
"A description of this proposal.",
|
||||||
|
[]params.ParamChange{{
|
||||||
|
Subspace: cdptypes.ModuleName,
|
||||||
|
Key: string(cdptypes.KeyDebtThreshold),
|
||||||
|
Value: string(types.ModuleCdc.MustMarshalJSON(newDebtThreshold)),
|
||||||
|
}},
|
||||||
|
),
|
||||||
|
suite.addresses[0],
|
||||||
|
1,
|
||||||
|
)
|
||||||
|
res := suite.handler(suite.ctx, msg)
|
||||||
|
suite.True(res.IsOK())
|
||||||
|
proposalID := types.Uint64FromBytes(res.Data)
|
||||||
|
res = suite.handler(suite.ctx, types.NewMsgVote(suite.addresses[0], proposalID))
|
||||||
|
suite.True(res.IsOK())
|
||||||
|
|
||||||
|
// Add a vote to make the proposal pass
|
||||||
|
res = suite.handler(suite.ctx, types.NewMsgVote(suite.addresses[1], proposalID))
|
||||||
|
|
||||||
|
suite.True(res.IsOK())
|
||||||
|
// Check the param has been updated
|
||||||
|
suite.Equal(newDebtThreshold, suite.app.GetCDPKeeper().GetParams(suite.ctx).DebtAuctionThreshold)
|
||||||
|
// Check proposal and votes are gone
|
||||||
|
_, found := suite.keeper.GetProposal(suite.ctx, proposalID)
|
||||||
|
suite.False(found)
|
||||||
|
suite.keeper.IterateVotes(suite.ctx, proposalID, func(v types.Vote) bool {
|
||||||
|
suite.Fail("vote found when there should be none")
|
||||||
|
return true
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
func (suite *HandlerTestSuite) TestMsgAddVote_ProposalFail() {
|
||||||
|
recipient := suite.addresses[4]
|
||||||
|
recipientCoins := suite.app.GetBankKeeper().GetCoins(suite.ctx, recipient)
|
||||||
|
msg := types.NewMsgSubmitProposal(
|
||||||
|
distribution.NewCommunityPoolSpendProposal(
|
||||||
|
"A Title",
|
||||||
|
"A description of this proposal.",
|
||||||
|
recipient,
|
||||||
|
cs(c("ukava", 500)),
|
||||||
|
),
|
||||||
|
suite.addresses[0],
|
||||||
|
1,
|
||||||
|
)
|
||||||
|
res := suite.handler(suite.ctx, msg)
|
||||||
|
suite.True(res.IsOK())
|
||||||
|
proposalID := types.Uint64FromBytes(res.Data)
|
||||||
|
res = suite.handler(suite.ctx, types.NewMsgVote(suite.addresses[0], proposalID))
|
||||||
|
suite.True(res.IsOK())
|
||||||
|
|
||||||
|
// invalidate the proposal by emptying community pool
|
||||||
|
suite.app.GetDistrKeeper().DistributeFromFeePool(suite.ctx, suite.communityPoolAmt, suite.addresses[0])
|
||||||
|
|
||||||
|
// Add a vote to make the proposal pass
|
||||||
|
res = suite.handler(suite.ctx, types.NewMsgVote(suite.addresses[1], proposalID))
|
||||||
|
|
||||||
|
suite.True(res.IsOK())
|
||||||
|
// Check the proposal was not enacted
|
||||||
|
suite.Equal(recipientCoins, suite.app.GetBankKeeper().GetCoins(suite.ctx, recipient))
|
||||||
|
// Check proposal and votes are gone
|
||||||
|
_, found := suite.keeper.GetProposal(suite.ctx, proposalID)
|
||||||
|
suite.False(found)
|
||||||
|
suite.keeper.IterateVotes(suite.ctx, proposalID, func(v types.Vote) bool {
|
||||||
|
suite.Fail("vote found when there should be none")
|
||||||
|
return true
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestHandlerTestSuite(t *testing.T) {
|
||||||
|
suite.Run(t, new(HandlerTestSuite))
|
||||||
|
}
|
20
x/committee/integration_test.go
Normal file
20
x/committee/integration_test.go
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
package committee_test
|
||||||
|
|
||||||
|
import (
|
||||||
|
"github.com/cosmos/cosmos-sdk/codec"
|
||||||
|
sdk "github.com/cosmos/cosmos-sdk/types"
|
||||||
|
|
||||||
|
"github.com/kava-labs/kava/app"
|
||||||
|
"github.com/kava-labs/kava/x/committee/types"
|
||||||
|
)
|
||||||
|
|
||||||
|
// Avoid cluttering test cases with long function names
|
||||||
|
func i(in int64) sdk.Int { return sdk.NewInt(in) }
|
||||||
|
func d(str string) sdk.Dec { return sdk.MustNewDecFromStr(str) }
|
||||||
|
func c(denom string, amount int64) sdk.Coin { return sdk.NewInt64Coin(denom, amount) }
|
||||||
|
func cs(coins ...sdk.Coin) sdk.Coins { return sdk.NewCoins(coins...) }
|
||||||
|
|
||||||
|
// NewCommitteeGenesisState marshals a committee genesis state into json for use in initializing test apps.
|
||||||
|
func NewCommitteeGenesisState(cdc *codec.Codec, gs types.GenesisState) app.GenesisState {
|
||||||
|
return app.GenesisState{types.ModuleName: cdc.MustMarshalJSON(gs)}
|
||||||
|
}
|
@ -1,8 +1,11 @@
|
|||||||
package keeper_test
|
package keeper_test
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"github.com/cosmos/cosmos-sdk/codec"
|
||||||
sdk "github.com/cosmos/cosmos-sdk/types"
|
sdk "github.com/cosmos/cosmos-sdk/types"
|
||||||
|
|
||||||
|
"github.com/kava-labs/kava/app"
|
||||||
|
"github.com/kava-labs/kava/x/committee"
|
||||||
"github.com/kava-labs/kava/x/committee/keeper"
|
"github.com/kava-labs/kava/x/committee/keeper"
|
||||||
"github.com/kava-labs/kava/x/committee/types"
|
"github.com/kava-labs/kava/x/committee/types"
|
||||||
)
|
)
|
||||||
@ -27,3 +30,8 @@ func getProposalVoteMap(k keeper.Keeper, ctx sdk.Context) map[uint64]([]types.Vo
|
|||||||
})
|
})
|
||||||
return proposalVoteMap
|
return proposalVoteMap
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// NewCommitteeGenesisState marshals a committee genesis state into json for use in initializing test apps.
|
||||||
|
func NewCommitteeGenesisState(cdc *codec.Codec, gs committee.GenesisState) app.GenesisState {
|
||||||
|
return app.GenesisState{committee.ModuleName: cdc.MustMarshalJSON(gs)}
|
||||||
|
}
|
||||||
|
@ -334,6 +334,19 @@ func (suite *KeeperTestSuite) TestValidatePubProposal() {
|
|||||||
),
|
),
|
||||||
expectErr: true,
|
expectErr: true,
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
name: "invalid (proposal handler fails - invalid json)",
|
||||||
|
pubProposal: params.NewParameterChangeProposal(
|
||||||
|
"A Title",
|
||||||
|
"A description of this proposal.",
|
||||||
|
[]params.ParamChange{{
|
||||||
|
Subspace: cdptypes.ModuleName,
|
||||||
|
Key: string(cdptypes.KeyGlobalDebtLimit),
|
||||||
|
Value: `{"denom": "usdx",`,
|
||||||
|
}},
|
||||||
|
),
|
||||||
|
expectErr: true,
|
||||||
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, tc := range testcases {
|
for _, tc := range testcases {
|
||||||
|
@ -13,7 +13,6 @@ import (
|
|||||||
abci "github.com/tendermint/tendermint/abci/types"
|
abci "github.com/tendermint/tendermint/abci/types"
|
||||||
|
|
||||||
"github.com/kava-labs/kava/app"
|
"github.com/kava-labs/kava/app"
|
||||||
"github.com/kava-labs/kava/x/committee"
|
|
||||||
"github.com/kava-labs/kava/x/committee/keeper"
|
"github.com/kava-labs/kava/x/committee/keeper"
|
||||||
"github.com/kava-labs/kava/x/committee/types"
|
"github.com/kava-labs/kava/x/committee/types"
|
||||||
)
|
)
|
||||||
@ -24,10 +23,6 @@ const (
|
|||||||
|
|
||||||
var testTime time.Time = time.Date(1998, time.January, 1, 0, 0, 0, 0, time.UTC)
|
var testTime time.Time = time.Date(1998, time.January, 1, 0, 0, 0, 0, time.UTC)
|
||||||
|
|
||||||
func NewCommitteeGenesisState(cdc *codec.Codec, gs committee.GenesisState) app.GenesisState {
|
|
||||||
return app.GenesisState{committee.ModuleName: cdc.MustMarshalJSON(gs)}
|
|
||||||
}
|
|
||||||
|
|
||||||
type QuerierTestSuite struct {
|
type QuerierTestSuite struct {
|
||||||
suite.Suite
|
suite.Suite
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user