Skip to content
This repository has been archived by the owner on Apr 4, 2024. It is now read-only.

fix: simulations don't generate EVM transactions #996

Merged
merged 65 commits into from
Apr 19, 2022
Merged
Show file tree
Hide file tree
Changes from 51 commits
Commits
Show all changes
65 commits
Select commit Hold shift + click to select a range
de71644
use SimAppChainId instead of the default cosmos-sdk simulation chainid
adu-web3 Mar 16, 2022
9bccb19
implement custom RandomGenesisAccounts for auth module simulation
adu-web3 Mar 16, 2022
2cee1bc
use customized RandomGenesisAccounts
adu-web3 Mar 20, 2022
5e5201a
generate random ethereum txs operations
adu-web3 Mar 20, 2022
2af14bf
use sdk.DefaultBondDenom
adu-web3 Mar 20, 2022
0d2afd0
implement WeightedOperations
adu-web3 Mar 20, 2022
7d366c3
fix self assignment
adu-web3 Mar 21, 2022
4ab9534
use customized RandomAccounts to generate accounts with ethsecp256k1 …
adu-web3 Mar 24, 2022
3ca68cc
RandomAccounts generate random accounts with ethsecp256k1 private key
adu-web3 Mar 24, 2022
582558a
implement SimulateEthSimpleTransfer
adu-web3 Mar 24, 2022
5d6bf3d
implement SimulateEthCreateContract
adu-web3 Mar 28, 2022
b2e991a
refactor and implement operationSimulateEthCallContract as future ope…
adu-web3 Mar 30, 2022
fa4c327
Update app/app.go
adu-web3 Mar 30, 2022
161eea5
Update app/test_helpers.go
adu-web3 Mar 30, 2022
2ddd4b3
Update x/evm/simulation/operations.go
adu-web3 Mar 30, 2022
6a06c83
Update x/evm/simulation/operations.go
adu-web3 Mar 30, 2022
4720c35
Update app/test_helpers.go
adu-web3 Mar 30, 2022
6b027bf
fix r.Read return only 1 result
adu-web3 Mar 31, 2022
c9dddff
fix linter errors
adu-web3 Mar 31, 2022
b53c633
change SimulateContext to private
adu-web3 Mar 31, 2022
8a556d7
return transferable amount immediately
adu-web3 Mar 31, 2022
bbff196
fix linter errors
adu-web3 Mar 31, 2022
cc9463f
fix linter errors: append assign to different slice
adu-web3 Mar 31, 2022
594acd0
fix linter error: remove else block
adu-web3 Mar 31, 2022
205dd54
use gofumpt
adu-web3 Mar 31, 2022
0902155
Merge branch 'main' into evm-simulation
fedekunze Apr 5, 2022
2ac8af8
Merge branch 'main' into evm-simulation
fedekunze Apr 5, 2022
c1f584f
Update x/evm/simulation/operations.go
crypto-facs Apr 5, 2022
7c94884
Update x/evm/simulation/operations.go
crypto-facs Apr 5, 2022
760dbc3
Update x/evm/simulation/operations.go
crypto-facs Apr 5, 2022
538acdc
Update x/evm/simulation/operations.go
crypto-facs Apr 5, 2022
8a5f6f0
Merge branch 'main' into evm-simulation
crypto-facs Apr 6, 2022
9318807
fix recipient typo
crypto-facs Apr 6, 2022
61cf53d
add nosec comment to escape Potential hardcoded credentials check
adu-web3 Apr 7, 2022
1ae5730
add comments
adu-web3 Apr 7, 2022
d5631a9
use SimAppChainID as valid chainID
adu-web3 Apr 7, 2022
cd4f8ab
do not specify genesis.json to create random genesis state for simula…
adu-web3 Apr 7, 2022
dae71a5
sub estimateGas to avoid overflow
adu-web3 Apr 7, 2022
c8c1800
correct RandomGenesisAccounts comments
adu-web3 Apr 8, 2022
b53e690
correct app/test_helpers.go comments
adu-web3 Apr 8, 2022
4f5bd58
Merge branch 'main' into evm-simulation
fedekunze Apr 12, 2022
54501d1
Merge branch 'main' into evm-simulation
fedekunze Apr 12, 2022
53689aa
remove NewTxConfig
adu-web3 Apr 11, 2022
90af055
implement RegisterStoreDecoder
adu-web3 Apr 13, 2022
ec377e7
remove WeightMsgEthCallContract and adjust weights
adu-web3 Apr 13, 2022
ff49ca9
use gofmt
adu-web3 Apr 13, 2022
744e9f6
Merge branch 'main' into evm-simulation
fedekunze Apr 13, 2022
6865918
update godoc
adu-web3 Apr 14, 2022
b251a2f
use types.DefaultEVMDenom in evm genesis params
adu-web3 Apr 14, 2022
f7de910
use types.DefaultEVMDenom
adu-web3 Apr 14, 2022
0e7fc56
update godoc
adu-web3 Apr 14, 2022
ac5500a
Update x/evm/simulation/genesis.go
fedekunze Apr 14, 2022
521cb9c
replace evmdenom with bonddenom in AppStateFn
adu-web3 Apr 14, 2022
c587e23
fix AppStateFn
adu-web3 Apr 15, 2022
52e4331
fix lint error
adu-web3 Apr 15, 2022
7694a7c
Merge branch 'main' into evm-simulation
fedekunze Apr 15, 2022
7abc387
add ParamChanges for RandomizedParams
adu-web3 Apr 18, 2022
1d565ae
rename app/test_helpers.go -> app/utils.go
adu-web3 Apr 18, 2022
1b17bee
testing for RandomGenesisAccounts
adu-web3 Apr 18, 2022
bb31e56
Merge branch 'main' into evm-simulation
fedekunze Apr 19, 2022
300d671
Merge branch 'main' into evm-simulation
fedekunze Apr 19, 2022
90aaede
use cdc for marshaling
fedekunze Apr 19, 2022
27879c4
lint
fedekunze Apr 19, 2022
85a29c4
changelog
fedekunze Apr 19, 2022
29cc44b
changelog 2
fedekunze Apr 19, 2022
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
10 changes: 4 additions & 6 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -342,10 +342,9 @@ test-sim-nondeterminism:
@go test -mod=readonly $(SIMAPP) -run TestAppStateDeterminism -Enabled=true \
-NumBlocks=100 -BlockSize=200 -Commit=true -Period=0 -v -timeout 24h

test-sim-custom-genesis-fast:
test-sim-random-genesis-fast:
@echo "Running custom genesis simulation..."
@echo "By default, ${HOME}/.$(ETHERMINT_DIR)/config/genesis.json will be used."
@go test -mod=readonly $(SIMAPP) -run TestFullAppSimulation -Genesis=${HOME}/.$(ETHERMINT_DIR)/config/genesis.json \
@go test -mod=readonly $(SIMAPP) -run TestFullAppSimulation \
-Enabled=true -NumBlocks=100 -BlockSize=200 -Commit=true -Seed=99 -Period=5 -v -timeout 24h

test-sim-import-export: runsim
Expand All @@ -356,10 +355,9 @@ test-sim-after-import: runsim
@echo "Running application simulation-after-import. This may take several minutes..."
@$(BINDIR)/runsim -Jobs=4 -SimAppPkg=$(SIMAPP) -ExitOnFail 50 5 TestAppSimulationAfterImport

test-sim-custom-genesis-multi-seed: runsim
test-sim-random-genesis-multi-seed: runsim
@echo "Running multi-seed custom genesis simulation..."
@echo "By default, ${HOME}/.$(ETHERMINT_DIR)/config/genesis.json will be used."
@$(BINDIR)/runsim -Genesis=${HOME}/.$(ETHERMINT_DIR)/config/genesis.json -SimAppPkg=$(SIMAPP) -ExitOnFail 400 5 TestFullAppSimulation
@$(BINDIR)/runsim -SimAppPkg=$(SIMAPP) -ExitOnFail 400 5 TestFullAppSimulation

test-sim-multi-seed-long: runsim
@echo "Running long multi-seed application simulation. This may take awhile!"
Expand Down
3 changes: 2 additions & 1 deletion app/app.go
Original file line number Diff line number Diff line change
Expand Up @@ -536,7 +536,8 @@ func NewEthermintApp(
// NOTE: this is not required apps that don't use the simulator for fuzz testing
// transactions
app.sm = module.NewSimulationManager(
auth.NewAppModule(appCodec, app.AccountKeeper, authsims.RandomGenesisAccounts),
// Use custom RandomGenesisAccounts so that auth module could create random EthAccounts in genesis state when genesis.json not specified
auth.NewAppModule(appCodec, app.AccountKeeper, RandomGenesisAccounts),
bank.NewAppModule(appCodec, app.BankKeeper, app.AccountKeeper),
capability.NewAppModule(appCodec, *app.CapabilityKeeper),
gov.NewAppModule(appCodec, app.GovKeeper, app.AccountKeeper, app.BankKeeper),
Expand Down
22 changes: 14 additions & 8 deletions app/simulation_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,6 @@ import (
"github.com/cosmos/cosmos-sdk/simapp/params"
"github.com/cosmos/cosmos-sdk/store"
sdk "github.com/cosmos/cosmos-sdk/types"
simtypes "github.com/cosmos/cosmos-sdk/types/simulation"
authtypes "github.com/cosmos/cosmos-sdk/x/auth/types"
banktypes "github.com/cosmos/cosmos-sdk/x/bank/types"
capabilitytypes "github.com/cosmos/cosmos-sdk/x/capability/types"
Expand Down Expand Up @@ -72,6 +71,8 @@ func TestFullAppSimulation(t *testing.T) {
}
require.NoError(t, err, "simulation setup failed")

config.ChainID = SimAppChainID

defer func() {
db.Close()
require.NoError(t, os.RemoveAll(dir))
Expand All @@ -86,7 +87,7 @@ func TestFullAppSimulation(t *testing.T) {
os.Stdout,
app.BaseApp,
simapp.AppStateFn(app.AppCodec(), app.SimulationManager()),
simtypes.RandomAccounts, // Replace with own random account function if using keys other than secp256k1
RandomAccounts, // Replace with own random account function if using keys other than secp256k1
simapp.SimulationOperations(app, app.AppCodec(), config),
app.ModuleAccountAddrs(),
config,
Expand All @@ -110,6 +111,8 @@ func TestAppImportExport(t *testing.T) {
}
require.NoError(t, err, "simulation setup failed")

config.ChainID = SimAppChainID

defer func() {
db.Close()
require.NoError(t, os.RemoveAll(dir))
Expand All @@ -124,7 +127,7 @@ func TestAppImportExport(t *testing.T) {
os.Stdout,
app.BaseApp,
simapp.AppStateFn(app.AppCodec(), app.SimulationManager()),
simtypes.RandomAccounts, // Replace with own random account function if using keys other than secp256k1
RandomAccounts, // Replace with own random account function if using keys other than secp256k1
simapp.SimulationOperations(app, app.AppCodec(), config),
app.ModuleAccountAddrs(),
config,
Expand Down Expand Up @@ -163,8 +166,8 @@ func TestAppImportExport(t *testing.T) {
err = json.Unmarshal(exported.AppState, &genesisState)
require.NoError(t, err)

ctxA := app.NewContext(true, tmproto.Header{Height: app.LastBlockHeight()})
ctxB := newApp.NewContext(true, tmproto.Header{Height: app.LastBlockHeight()})
ctxA := app.NewContext(true, tmproto.Header{Height: app.LastBlockHeight(), ChainID: SimAppChainID})
ctxB := newApp.NewContext(true, tmproto.Header{Height: app.LastBlockHeight(), ChainID: SimAppChainID})
newApp.mm.InitGenesis(ctxB, app.AppCodec(), genesisState)
newApp.StoreConsensusParams(ctxB, exported.ConsensusParams)

Expand Down Expand Up @@ -210,6 +213,8 @@ func TestAppSimulationAfterImport(t *testing.T) {
}
require.NoError(t, err, "simulation setup failed")

config.ChainID = SimAppChainID

defer func() {
db.Close()
require.NoError(t, os.RemoveAll(dir))
Expand All @@ -224,7 +229,7 @@ func TestAppSimulationAfterImport(t *testing.T) {
os.Stdout,
app.BaseApp,
simapp.AppStateFn(app.AppCodec(), app.SimulationManager()),
simtypes.RandomAccounts, // Replace with own random account function if using keys other than secp256k1
RandomAccounts, // Replace with own random account function if using keys other than secp256k1
simapp.SimulationOperations(app, app.AppCodec(), config),
app.ModuleAccountAddrs(),
config,
Expand Down Expand Up @@ -264,6 +269,7 @@ func TestAppSimulationAfterImport(t *testing.T) {
require.Equal(t, appName, newApp.Name())

newApp.InitChain(abci.RequestInitChain{
ChainId: SimAppChainID,
AppStateBytes: exported.AppState,
})

Expand All @@ -272,7 +278,7 @@ func TestAppSimulationAfterImport(t *testing.T) {
os.Stdout,
newApp.BaseApp,
simapp.AppStateFn(app.AppCodec(), app.SimulationManager()),
simtypes.RandomAccounts, // Replace with own random account function if using keys other than secp256k1
RandomAccounts, // Replace with own random account function if using keys other than secp256k1
simapp.SimulationOperations(newApp, newApp.AppCodec(), config),
app.ModuleAccountAddrs(),
config,
Expand Down Expand Up @@ -323,7 +329,7 @@ func TestAppStateDeterminism(t *testing.T) {
os.Stdout,
app.BaseApp,
simapp.AppStateFn(app.AppCodec(), app.SimulationManager()),
simtypes.RandomAccounts, // Replace with own random account function if using keys other than secp256k1
RandomAccounts, // Replace with own random account function if using keys other than secp256k1
simapp.SimulationOperations(app, app.AppCodec(), config),
app.ModuleAccountAddrs(),
config,
Expand Down
53 changes: 53 additions & 0 deletions app/test_helpers.go
Original file line number Diff line number Diff line change
Expand Up @@ -2,16 +2,28 @@ package app

import (
"encoding/json"
"math/rand"
"time"

"github.com/cosmos/cosmos-sdk/crypto/keys/secp256k1"
"github.com/cosmos/cosmos-sdk/simapp"
"github.com/cosmos/cosmos-sdk/types/module"
authtypes "github.com/cosmos/cosmos-sdk/x/auth/types"

"github.com/tharsis/ethermint/encoding"
ethermint "github.com/tharsis/ethermint/types"

"github.com/cosmos/cosmos-sdk/crypto/keys/ed25519"
sdk "github.com/cosmos/cosmos-sdk/types"
simtypes "github.com/cosmos/cosmos-sdk/types/simulation"
"github.com/ethereum/go-ethereum/common"
"github.com/ethereum/go-ethereum/crypto"
abci "github.com/tendermint/tendermint/abci/types"
"github.com/tendermint/tendermint/libs/log"
tmproto "github.com/tendermint/tendermint/proto/tendermint/types"
tmtypes "github.com/tendermint/tendermint/types"
dbm "github.com/tendermint/tm-db"
"github.com/tharsis/ethermint/crypto/ethsecp256k1"
)

// DefaultConsensusParams defines the default Tendermint consensus params used in
Expand Down Expand Up @@ -62,3 +74,44 @@ func Setup(isCheckTx bool, patchGenesis func(*EthermintApp, simapp.GenesisState)

return app
}

// RandomGenesisAccounts is used by the auth module to create random genesis accounts in simulation when a genesis.json is not specified.
// In contrast, the default auth module's RandomGenesisAccounts implementation creates only base accounts and vestings accounts.
func RandomGenesisAccounts(simState *module.SimulationState) authtypes.GenesisAccounts {
adu-web3 marked this conversation as resolved.
Show resolved Hide resolved
emptyCodeHash := crypto.Keccak256(nil)
genesisAccs := make(authtypes.GenesisAccounts, len(simState.Accounts))
for i, acc := range simState.Accounts {
bacc := authtypes.NewBaseAccountWithAddress(acc.Address)

ethacc := &ethermint.EthAccount{
BaseAccount: bacc,
CodeHash: common.BytesToHash(emptyCodeHash).String(),
}
genesisAccs[i] = ethacc
}

return genesisAccs
}

// RandomAccounts creates random accounts with an ethsecp256k1 private key
// TODO: replace secp256k1.GenPrivKeyFromSecret() with similar function in go-ethereum
func RandomAccounts(r *rand.Rand, n int) []simtypes.Account {
adu-web3 marked this conversation as resolved.
Show resolved Hide resolved
accs := make([]simtypes.Account, n)

for i := 0; i < n; i++ {
// don't need that much entropy for simulation
privkeySeed := make([]byte, 15)
_, _ = r.Read(privkeySeed)

prv := secp256k1.GenPrivKeyFromSecret(privkeySeed)
fedekunze marked this conversation as resolved.
Show resolved Hide resolved
ethPrv := &ethsecp256k1.PrivKey{}
_ = ethPrv.UnmarshalAmino(prv.Bytes())
accs[i].PrivKey = ethPrv
accs[i].PubKey = accs[i].PrivKey.PubKey()
accs[i].Address = sdk.AccAddress(accs[i].PubKey.Address())

accs[i].ConsKey = ed25519.GenPrivKeyFromSecret(privkeySeed)
}

return accs
}
8 changes: 6 additions & 2 deletions x/evm/module.go
Original file line number Diff line number Diff line change
Expand Up @@ -174,7 +174,9 @@ func (AppModule) RandomizedParams(r *rand.Rand) []simtypes.ParamChange {
}

// RegisterStoreDecoder registers a decoder for evm module's types
func (am AppModule) RegisterStoreDecoder(sdr sdk.StoreDecoderRegistry) {}
func (am AppModule) RegisterStoreDecoder(sdr sdk.StoreDecoderRegistry) {
sdr[types.StoreKey] = simulation.NewDecodeStore()
}

// ProposalContents doesn't return any content functions for governance proposals.
func (AppModule) ProposalContents(simState module.SimulationState) []simtypes.WeightedProposalContent {
Expand All @@ -188,5 +190,7 @@ func (AppModule) GenerateGenesisState(simState *module.SimulationState) {

// WeightedOperations returns the all the evm module operations with their respective weights.
fedekunze marked this conversation as resolved.
Show resolved Hide resolved
func (am AppModule) WeightedOperations(simState module.SimulationState) []simtypes.WeightedOperation {
return nil
return simulation.WeightedOperations(
simState.AppParams, simState.Cdc, am.ak, am.keeper,
)
}
31 changes: 31 additions & 0 deletions x/evm/simulation/decoder.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
package simulation

import (
"bytes"
"fmt"

"github.com/cosmos/cosmos-sdk/types/kv"
"github.com/ethereum/go-ethereum/common"
"github.com/tharsis/ethermint/x/evm/types"
)

// NewDecodeStore returns a decoder function closure that unmarshals the KVPair's
// Value to the corresponding evm type.
func NewDecodeStore() func(kvA, kvB kv.Pair) string {
return func(kvA, kvB kv.Pair) string {
switch {
case bytes.Equal(kvA.Key[:1], types.KeyPrefixStorage):
storageHashA := common.BytesToHash(kvA.Value).Hex()
storageHashB := common.BytesToHash(kvB.Value).Hex()

return fmt.Sprintf("%v\n%v", storageHashA, storageHashB)
case bytes.Equal(kvA.Key[:1], types.KeyPrefixCode):
codeHashA := common.BytesToHash(kvA.Value).Hex()
codeHashB := common.BytesToHash(kvB.Value).Hex()

return fmt.Sprintf("%v\n%v", codeHashA, codeHashB)
default:
panic(fmt.Sprintf("invalid evm key prefix %X", kvA.Key[:1]))
}
}
}
1 change: 1 addition & 0 deletions x/evm/simulation/genesis.go
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ import (
"encoding/json"
"fmt"

sdk "github.com/cosmos/cosmos-sdk/types"
fedekunze marked this conversation as resolved.
Show resolved Hide resolved
fedekunze marked this conversation as resolved.
Show resolved Hide resolved
"github.com/cosmos/cosmos-sdk/types/module"

"github.com/tharsis/ethermint/x/evm/types"
Expand Down
Loading