cosmos-sdk/simapp/sim_bench_test.go

119 lines
3.1 KiB
Go
Raw Normal View History

2019-09-26 09:07:15 -07:00
package simapp
import (
"fmt"
"os"
"testing"
tmproto "github.com/tendermint/tendermint/proto/tendermint/types"
simtypes "github.com/cosmos/cosmos-sdk/types/simulation"
"github.com/cosmos/cosmos-sdk/x/simulation"
2019-09-26 09:07:15 -07:00
)
// Profile with:
// /usr/local/go/bin/go test -benchmem -run=^$ github.com/cosmos/cosmos-sdk/simapp -bench ^BenchmarkFullAppSimulation$ -Commit=true -cpuprofile cpu.out
func BenchmarkFullAppSimulation(b *testing.B) {
config, db, dir, logger, _, err := SetupSimulation("goleveldb-app-sim", "Simulation")
if err != nil {
b.Fatalf("simulation setup failed: %s", err.Error())
}
2019-09-26 09:07:15 -07:00
defer func() {
db.Close()
err = os.RemoveAll(dir)
if err != nil {
b.Fatal(err)
}
2019-09-26 09:07:15 -07:00
}()
app := NewSimApp(logger, db, nil, true, map[int64]bool{}, DefaultNodeHome, FlagPeriodValue, MakeEncodingConfig(), interBlockCacheOpt())
2019-09-26 09:07:15 -07:00
// run randomized simulation
2019-09-26 09:07:15 -07:00
_, simParams, simErr := simulation.SimulateFromSeed(
b,
os.Stdout,
app.BaseApp,
AppStateFn(app.AppCodec(), app.SimulationManager()),
simtypes.RandomAccounts, // Replace with own random account function if using keys other than secp256k1
SimulationOperations(app, app.AppCodec(), config),
app.ModuleAccountAddrs(),
config,
2019-09-26 09:07:15 -07:00
)
// export state and simParams before the simulation error is checked
if err = CheckExportSimulation(app, config, simParams); err != nil {
b.Fatal(err)
2019-09-26 09:07:15 -07:00
}
if simErr != nil {
b.Fatal(simErr)
2019-09-26 09:07:15 -07:00
}
if config.Commit {
PrintStats(db)
2019-09-26 09:07:15 -07:00
}
}
func BenchmarkInvariants(b *testing.B) {
config, db, dir, logger, _, err := SetupSimulation("leveldb-app-invariant-bench", "Simulation")
if err != nil {
b.Fatalf("simulation setup failed: %s", err.Error())
}
2019-09-26 09:07:15 -07:00
config.AllInvariants = false
defer func() {
db.Close()
err = os.RemoveAll(dir)
if err != nil {
b.Fatal(err)
}
2019-09-26 09:07:15 -07:00
}()
app := NewSimApp(logger, db, nil, true, map[int64]bool{}, DefaultNodeHome, FlagPeriodValue, MakeEncodingConfig(), interBlockCacheOpt())
2019-09-26 09:07:15 -07:00
// run randomized simulation
2019-09-26 09:07:15 -07:00
_, simParams, simErr := simulation.SimulateFromSeed(
b,
os.Stdout,
app.BaseApp,
AppStateFn(app.AppCodec(), app.SimulationManager()),
simtypes.RandomAccounts, // Replace with own random account function if using keys other than secp256k1
SimulationOperations(app, app.AppCodec(), config),
app.ModuleAccountAddrs(),
config,
2019-09-26 09:07:15 -07:00
)
// export state and simParams before the simulation error is checked
if err = CheckExportSimulation(app, config, simParams); err != nil {
b.Fatal(err)
2019-09-26 09:07:15 -07:00
}
if simErr != nil {
b.Fatal(simErr)
2019-09-26 09:07:15 -07:00
}
if config.Commit {
PrintStats(db)
2019-09-26 09:07:15 -07:00
}
ctx := app.NewContext(true, tmproto.Header{Height: app.LastBlockHeight() + 1})
2019-09-26 09:07:15 -07:00
// 3. Benchmark each invariant separately
//
// NOTE: We use the crisis keeper as it has all the invariants registered with
// their respective metadata which makes it useful for testing/benchmarking.
for _, cr := range app.CrisisKeeper.Routes() {
2019-10-17 06:47:35 -07:00
cr := cr
2019-09-26 09:07:15 -07:00
b.Run(fmt.Sprintf("%s/%s", cr.ModuleName, cr.Route), func(b *testing.B) {
if res, stop := cr.Invar(ctx); stop {
b.Fatalf(
"broken invariant at block %d of %d\n%s",
ctx.BlockHeight()-1, config.NumBlocks, res,
)
2019-09-26 09:07:15 -07:00
}
})
}
}