mirror of
https://github.com/0glabs/0g-chain.git
synced 2025-01-01 11:15:17 +00:00
b0932f7062
* update params * stub out methods * delete legacy migration test * feat: add infrastructure inflation and payouts * fix: load same module account blocked addrs in kavadist as app * fix: testing edge case where period starts and ends same block * fix: add store key for infra params, update newparams function * fix: testing edge case where period starts and ends in same block * add test for basic infra minting * add test for stand-alone core, partner rewards * fix: set time elapsed in each case * add e2e test for infra rewards * fix: use standard method for naming infra params key
88 lines
2.7 KiB
Go
88 lines
2.7 KiB
Go
package simulation
|
|
|
|
import (
|
|
"encoding/json"
|
|
"fmt"
|
|
"math/rand"
|
|
"time"
|
|
|
|
sdk "github.com/cosmos/cosmos-sdk/types"
|
|
"github.com/cosmos/cosmos-sdk/types/module"
|
|
"github.com/cosmos/cosmos-sdk/types/simulation"
|
|
|
|
"github.com/kava-labs/kava/x/kavadist/types"
|
|
)
|
|
|
|
// SecondsPerYear is the number of seconds in a year
|
|
const (
|
|
SecondsPerYear = 31536000
|
|
// BaseAprPadding sets the minimum inflation to the calculated SPR inflation rate from being 0.0
|
|
BaseAprPadding = "0.000000003022265980"
|
|
)
|
|
|
|
// RandomizedGenState generates a random GenesisState for kavadist module
|
|
func RandomizedGenState(simState *module.SimulationState) {
|
|
params := genRandomParams(simState)
|
|
if err := params.Validate(); err != nil {
|
|
panic(err)
|
|
}
|
|
|
|
kavadistGenesis := types.NewGenesisState(params, types.DefaultPreviousBlockTime)
|
|
if err := kavadistGenesis.Validate(); err != nil {
|
|
panic(err)
|
|
}
|
|
|
|
bz, err := json.MarshalIndent(&kavadistGenesis, "", " ")
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
fmt.Printf("Selected randomly generated %s parameters:\n%s\n", types.ModuleName, bz)
|
|
simState.GenState[types.ModuleName] = simState.Cdc.MustMarshalJSON(kavadistGenesis)
|
|
}
|
|
|
|
func genRandomParams(simState *module.SimulationState) types.Params {
|
|
periods := genRandomPeriods(simState.Rand, simState.GenTimestamp)
|
|
params := types.NewParams(true, periods, types.DefaultInfraParams)
|
|
return params
|
|
}
|
|
|
|
func genRandomPeriods(r *rand.Rand, timestamp time.Time) []types.Period {
|
|
var periods []types.Period
|
|
numPeriods := simulation.RandIntBetween(r, 1, 10)
|
|
periodStart := timestamp
|
|
for i := 0; i < numPeriods; i++ {
|
|
// set periods to be between 1-3 days
|
|
durationMultiplier := simulation.RandIntBetween(r, 1, 3)
|
|
duration := time.Duration(int64(24*durationMultiplier)) * time.Hour
|
|
periodEnd := periodStart.Add(duration)
|
|
inflation := genRandomInflation(r)
|
|
period := types.NewPeriod(periodStart, periodEnd, inflation)
|
|
periods = append(periods, period)
|
|
periodStart = periodEnd
|
|
}
|
|
return periods
|
|
}
|
|
|
|
func genRandomInflation(r *rand.Rand) sdk.Dec {
|
|
// If sim.RandomDecAmount is less than base apr padding, add base apr padding
|
|
aprPadding, _ := sdk.NewDecFromStr(BaseAprPadding)
|
|
extraAprInflation := simulation.RandomDecAmount(r, sdk.MustNewDecFromStr("0.25"))
|
|
for extraAprInflation.LT(aprPadding) {
|
|
extraAprInflation = extraAprInflation.Add(aprPadding)
|
|
}
|
|
aprInflation := sdk.OneDec().Add(extraAprInflation)
|
|
|
|
// convert APR inflation to SPR (inflation per second)
|
|
inflationSpr, err := aprInflation.ApproxRoot(uint64(SecondsPerYear))
|
|
if err != nil {
|
|
panic(fmt.Sprintf("error generating random inflation %v", err))
|
|
}
|
|
return inflationSpr
|
|
}
|
|
|
|
func genRandomActive(r *rand.Rand) bool {
|
|
threshold := 50
|
|
value := simulation.RandIntBetween(r, 1, 100)
|
|
return value > threshold
|
|
}
|