6c1e7fec01
* evm: keeper statedb refactor * keeper: implement stateDB account, balance, nonce and suicide functions * keeper: implement stateDB code and iterator functions * keeper: implement stateDB log and preimage functions * update code to use CommitStateDB * tests updates * journal changes (wip) * cache fields * journal and logs * minor cleanup * evm: remove journal related changes * evm: delete empty account code and storage state * app, evm: transient store * ante, evm: refund gas transient * evm: remove transient keeper state fields * address comments from review * evm: undo revision change
139 lines
3.4 KiB
Go
139 lines
3.4 KiB
Go
package keeper_test
|
|
|
|
import (
|
|
"math/big"
|
|
|
|
authtypes "github.com/cosmos/cosmos-sdk/x/auth/types"
|
|
"github.com/cosmos/ethermint/crypto/ethsecp256k1"
|
|
ethermint "github.com/cosmos/ethermint/types"
|
|
ethcmn "github.com/ethereum/go-ethereum/common"
|
|
)
|
|
|
|
func (suite *KeeperTestSuite) TestBalanceInvariant() {
|
|
privkey, err := ethsecp256k1.GenerateKey()
|
|
suite.Require().NoError(err)
|
|
|
|
address := ethcmn.HexToAddress(privkey.PubKey().Address().String())
|
|
|
|
testCases := []struct {
|
|
name string
|
|
malleate func()
|
|
expBroken bool
|
|
}{
|
|
{
|
|
"balance mismatch",
|
|
func() {
|
|
acc := suite.app.AccountKeeper.NewAccountWithAddress(suite.ctx, address.Bytes())
|
|
suite.Require().NotNil(acc)
|
|
suite.app.BankKeeper.SetBalance(suite.ctx, acc.GetAddress(), ethermint.NewPhotonCoinInt64(1))
|
|
suite.Require().NoError(err)
|
|
suite.app.AccountKeeper.SetAccount(suite.ctx, acc)
|
|
|
|
suite.app.EvmKeeper.CommitStateDB.SetBalance(address, big.NewInt(1000))
|
|
},
|
|
true,
|
|
},
|
|
{
|
|
"balance ok",
|
|
func() {
|
|
acc := suite.app.AccountKeeper.NewAccountWithAddress(suite.ctx, address.Bytes())
|
|
suite.Require().NotNil(acc)
|
|
suite.app.BankKeeper.SetBalance(suite.ctx, acc.GetAddress(), ethermint.NewPhotonCoinInt64(1))
|
|
suite.Require().NoError(err)
|
|
suite.app.AccountKeeper.SetAccount(suite.ctx, acc)
|
|
|
|
suite.app.EvmKeeper.CommitStateDB.SetBalance(address, big.NewInt(1))
|
|
},
|
|
false,
|
|
},
|
|
{
|
|
"invalid account type",
|
|
func() {
|
|
acc := authtypes.NewBaseAccountWithAddress(address.Bytes())
|
|
suite.app.AccountKeeper.SetAccount(suite.ctx, acc)
|
|
},
|
|
false,
|
|
},
|
|
}
|
|
|
|
for _, tc := range testCases {
|
|
suite.Run(tc.name, func() {
|
|
suite.SetupTest() // reset values
|
|
|
|
suite.app.EvmKeeper.CommitStateDB.WithContext(suite.ctx)
|
|
tc.malleate()
|
|
|
|
_, broken := suite.app.EvmKeeper.BalanceInvariant()(suite.ctx)
|
|
if tc.expBroken {
|
|
suite.Require().True(broken)
|
|
} else {
|
|
suite.Require().False(broken)
|
|
}
|
|
})
|
|
}
|
|
}
|
|
|
|
func (suite *KeeperTestSuite) TestNonceInvariant() {
|
|
privkey, err := ethsecp256k1.GenerateKey()
|
|
suite.Require().NoError(err)
|
|
|
|
address := ethcmn.HexToAddress(privkey.PubKey().Address().String())
|
|
|
|
testCases := []struct {
|
|
name string
|
|
malleate func()
|
|
expBroken bool
|
|
}{
|
|
{
|
|
"nonce mismatch",
|
|
func() {
|
|
acc := suite.app.AccountKeeper.NewAccountWithAddress(suite.ctx, address.Bytes())
|
|
suite.Require().NotNil(acc)
|
|
err := acc.SetSequence(1)
|
|
suite.Require().NoError(err)
|
|
suite.app.AccountKeeper.SetAccount(suite.ctx, acc)
|
|
|
|
suite.app.EvmKeeper.CommitStateDB.SetNonce(address, 100)
|
|
},
|
|
true,
|
|
},
|
|
{
|
|
"nonce ok",
|
|
func() {
|
|
acc := suite.app.AccountKeeper.NewAccountWithAddress(suite.ctx, address.Bytes())
|
|
suite.Require().NotNil(acc)
|
|
err := acc.SetSequence(1)
|
|
suite.Require().NoError(err)
|
|
suite.app.AccountKeeper.SetAccount(suite.ctx, acc)
|
|
|
|
suite.app.EvmKeeper.CommitStateDB.SetNonce(address, 1)
|
|
},
|
|
false,
|
|
},
|
|
{
|
|
"invalid account type",
|
|
func() {
|
|
acc := authtypes.NewBaseAccountWithAddress(address.Bytes())
|
|
suite.app.AccountKeeper.SetAccount(suite.ctx, acc)
|
|
},
|
|
false,
|
|
},
|
|
}
|
|
|
|
for _, tc := range testCases {
|
|
suite.Run(tc.name, func() {
|
|
suite.SetupTest() // reset values
|
|
|
|
suite.app.EvmKeeper.CommitStateDB.WithContext(suite.ctx)
|
|
tc.malleate()
|
|
|
|
_, broken := suite.app.EvmKeeper.NonceInvariant()(suite.ctx)
|
|
if tc.expBroken {
|
|
suite.Require().True(broken)
|
|
} else {
|
|
suite.Require().False(broken)
|
|
}
|
|
})
|
|
}
|
|
}
|