-
Notifications
You must be signed in to change notification settings - Fork 101
/
msg_add_class_creator.go
91 lines (75 loc) · 3.21 KB
/
msg_add_class_creator.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
package simulation
import (
"math/rand"
"github.com/cosmos/cosmos-sdk/baseapp"
codectypes "github.com/cosmos/cosmos-sdk/codec/types"
simappparams "github.com/cosmos/cosmos-sdk/simapp/params"
sdk "github.com/cosmos/cosmos-sdk/types"
simtypes "github.com/cosmos/cosmos-sdk/types/simulation"
govtypes "github.com/cosmos/cosmos-sdk/x/gov/types/v1"
"github.com/cosmos/cosmos-sdk/x/simulation"
"github.com/regen-network/regen-ledger/x/ecocredit/v3"
types "github.com/regen-network/regen-ledger/x/ecocredit/v3/base/types/v1"
"github.com/regen-network/regen-ledger/x/ecocredit/v3/simulation/utils"
)
const OpWeightMsgAddClassCreator = "op_weight_msg_add_class_creator" //nolint:gosec
var TypeMsgAddClassCreator = sdk.MsgTypeURL(&types.MsgAddClassCreator{})
const WeightAddClassCreator = 33
// SimulateMsgAddClassCreator generates a MsgAddClassCreator with random values.
func SimulateMsgAddClassCreator(ak ecocredit.AccountKeeper, bk ecocredit.BankKeeper, govk ecocredit.GovKeeper,
qryClient types.QueryServer, authority sdk.AccAddress) simtypes.Operation {
return func(
r *rand.Rand, app *baseapp.BaseApp, sdkCtx sdk.Context, accs []simtypes.Account, chainID string,
) (simtypes.OperationMsg, []simtypes.FutureOperation, error) {
proposer, _ := simtypes.RandomAcc(r, accs)
proposerAddr := proposer.Address.String()
spendable, account, op, err := utils.GetAccountAndSpendableCoins(sdkCtx, bk, accs, proposerAddr, TypeMsgAddClassCreator)
if spendable == nil {
return op, nil, err
}
params := govk.GetDepositParams(sdkCtx)
deposit, skip, err := utils.RandomDeposit(r, sdkCtx, ak, bk, params, proposer.Address)
switch {
case skip:
return simtypes.NoOpMsg(ecocredit.ModuleName, TypeMsgAddClassCreator, "skip deposit"), nil, nil
case err != nil:
return simtypes.NoOpMsg(ecocredit.ModuleName, TypeMsgAddClassCreator, "unable to generate deposit"), nil, err
}
creatorsResult, err := qryClient.AllowedClassCreators(sdkCtx, &types.QueryAllowedClassCreatorsRequest{})
if err != nil {
return simtypes.NoOpMsg(ecocredit.ModuleName, TypeMsgAddClassCreator, err.Error()), nil, err
}
if stringInSlice(proposerAddr, creatorsResult.ClassCreators) {
return simtypes.NoOpMsg(ecocredit.ModuleName, TypeMsgAddClassCreator, "class creator already exists"), nil, nil
}
proposalMsg := types.MsgAddClassCreator{
Authority: authority.String(),
Creator: proposerAddr,
}
anyMsg, err := codectypes.NewAnyWithValue(&proposalMsg)
if err != nil {
return simtypes.NoOpMsg(ecocredit.ModuleName, TypeMsgAddClassCreator, err.Error()), nil, err
}
msg := &govtypes.MsgSubmitProposal{
Messages: []*codectypes.Any{anyMsg},
InitialDeposit: deposit,
Proposer: proposerAddr,
Metadata: simtypes.RandStringOfLength(r, 10),
}
txCtx := simulation.OperationInput{
R: r,
App: app,
TxGen: simappparams.MakeTestEncodingConfig().TxConfig,
Cdc: nil,
Msg: msg,
MsgType: msg.Type(),
Context: sdkCtx,
SimAccount: *account,
AccountKeeper: ak,
Bankkeeper: bk,
ModuleName: ecocredit.ModuleName,
CoinsSpentInMsg: spendable,
}
return utils.GenAndDeliverTxWithRandFees(r, txCtx)
}
}