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

tests: block gas limit tests #1500

Merged
merged 14 commits into from
Dec 2, 2022
12 changes: 12 additions & 0 deletions app/ante/eth_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@ import (
"github.com/evmos/ethermint/app/ante"
"github.com/evmos/ethermint/server/config"
"github.com/evmos/ethermint/tests"
ethermint "github.com/evmos/ethermint/types"
"github.com/evmos/ethermint/x/evm/statedb"
evmtypes "github.com/evmos/ethermint/x/evm/types"

Expand Down Expand Up @@ -180,6 +181,9 @@ func (suite AnteTestSuite) TestEthGasConsumeDecorator() {
tx2.From = addr.Hex()
tx2Priority := int64(1)

tx3GasLimit := ethermint.BlockGasLimit(suite.ctx) + uint64(1)
tx3 := evmtypes.NewTxContract(suite.app.EvmKeeper.ChainID(), 1, big.NewInt(10), tx3GasLimit, gasPrice, nil, nil, nil, &ethtypes.AccessList{{Address: addr, StorageKeys: nil}})

dynamicFeeTx := evmtypes.NewTxContract(suite.app.EvmKeeper.ChainID(), 1, big.NewInt(10), tx2GasLimit,
nil, // gasPrice
new(big.Int).Add(baseFee, big.NewInt(evmtypes.DefaultPriorityReduction.Int64()*2)), // gasFeeCap
Expand Down Expand Up @@ -216,6 +220,14 @@ func (suite AnteTestSuite) TestEthGasConsumeDecorator() {
false, false,
0,
},
{
"gas limit above block gas limit",
tx3,
math.MaxUint64,
func() {},
false, false,
0,
},
{
"not enough balance for fees",
tx2,
Expand Down
89 changes: 68 additions & 21 deletions tests/integration_tests/test_gas.py
100755 → 100644
Original file line number Diff line number Diff line change
@@ -1,4 +1,13 @@
from .utils import ADDRS, CONTRACTS, KEYS, deploy_contract, send_transaction
import pytest

from .utils import (
ADDRS,
CONTRACTS,
KEYS,
deploy_contract,
send_transaction,
w3_wait_for_new_blocks,
)


def test_gas_eth_tx(geth, ethermint):
Expand All @@ -21,12 +30,10 @@ def test_gas_eth_tx(geth, ethermint):
def test_gas_deployment(geth, ethermint):
# deploy an identical contract on geth and ethermint
# ensure that the gasUsed is equivalent
_, geth_contract_receipt = deploy_contract(
geth.w3,
CONTRACTS["TestERC20A"])
_, geth_contract_receipt = deploy_contract(geth.w3, CONTRACTS["TestERC20A"])
_, ethermint_contract_receipt = deploy_contract(
ethermint.w3,
CONTRACTS["TestERC20A"])
ethermint.w3, CONTRACTS["TestERC20A"]
)
assert geth_contract_receipt.gasUsed == ethermint_contract_receipt.gasUsed


Expand All @@ -35,28 +42,68 @@ def test_gas_call(geth, ethermint):

# deploy an identical contract on geth and ethermint
# ensure that the contract has a function which consumes non-trivial gas
geth_contract, _ = deploy_contract(
geth.w3,
CONTRACTS["BurnGas"])
ethermint_contract, _ = deploy_contract(
ethermint.w3,
CONTRACTS["BurnGas"])
geth_contract, _ = deploy_contract(geth.w3, CONTRACTS["BurnGas"])
ethermint_contract, _ = deploy_contract(ethermint.w3, CONTRACTS["BurnGas"])

# call the contract and get tx receipt for geth
geth_gas_price = geth.w3.eth.gas_price
geth_txhash = (geth_contract.functions
.burnGas(function_input)
.transact({'from': ADDRS["validator"], "gasPrice": geth_gas_price}))
geth_txhash = geth_contract.functions.burnGas(function_input).transact(
{"from": ADDRS["validator"], "gasPrice": geth_gas_price}
)
geth_call_receipt = geth.w3.eth.wait_for_transaction_receipt(geth_txhash)

# repeat the above for ethermint
ethermint_gas_price = ethermint.w3.eth.gas_price
ethermint_txhash = (ethermint_contract.functions
.burnGas(function_input)
.transact({'from': ADDRS["validator"],
"gasPrice": ethermint_gas_price}))
ethermint_call_receipt = (ethermint.w3.
eth.wait_for_transaction_receipt(ethermint_txhash))
ethermint_txhash = ethermint_contract.functions.burnGas(function_input).transact(
{"from": ADDRS["validator"], "gasPrice": ethermint_gas_price}
)
ethermint_call_receipt = ethermint.w3.eth.wait_for_transaction_receipt(
ethermint_txhash
)

# ensure that the gasUsed is equivalent
assert geth_call_receipt.gasUsed == ethermint_call_receipt.gasUsed


def test_block_gas_limit(ethermint):
tx_value = 10

# get the block gas limit from the latest block
w3_wait_for_new_blocks(ethermint.w3, 5)
block = ethermint.w3.eth.get_block("latest")
exceededGasLimit = block.gasLimit + 100

# send a transaction exceeding the block gas limit
ethermint_gas_price = ethermint.w3.eth.gas_price
tx = {
"to": ADDRS["community"],
"value": tx_value,
"gas": exceededGasLimit,
fedekunze marked this conversation as resolved.
Show resolved Hide resolved
"gasPrice": ethermint_gas_price,
}

# expect an error due to the block gas limit
with pytest.raises(Exception):
send_transaction(ethermint.w3, tx, KEYS["validator"])

# deploy a contract on ethermint
ethermint_contract, _ = deploy_contract(ethermint.w3, CONTRACTS["BurnGas"])

# expect an error on contract call due to block gas limit
with pytest.raises(Exception):
ethermint_txhash = ethermint_contract.functions.burnGas(
exceededGasLimit
).transact(
{
"from": ADDRS["validator"],
"gas": exceededGasLimit,
fedekunze marked this conversation as resolved.
Show resolved Hide resolved
"gasPrice": ethermint_gas_price,
}
)
(ethermint.w3.eth.wait_for_transaction_receipt(ethermint_txhash))


# todo: implement block gas limit being checked for sum of block transactions
# requires the ability to send batch transactions with web3.py
def test_many_block_gas_limit(ethermint):
fedekunze marked this conversation as resolved.
Show resolved Hide resolved
return