Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

internal/ethapi: eth_simulateV1 #27720

Merged
merged 131 commits into from
Sep 6, 2024
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
131 commits
Select commit Hold shift + click to select a range
62d33d5
internal/ethapi: add multicall method
s1na May 26, 2023
80df50d
add test case for logs
s1na Jun 5, 2023
c3f1494
add ecrecover override
s1na Jun 6, 2023
a219206
forgot to commit other files
s1na Jun 6, 2023
0285f81
dont abort on call validation error
s1na Jun 6, 2023
c301ce4
add state buildup test
s1na Jun 6, 2023
922f72c
test block override defaults to base
s1na Jun 6, 2023
80bcb16
check block nums are in order
s1na Jun 6, 2023
4478f20
add method to web3ext
s1na Jun 8, 2023
2ae2fe5
add transfers
s1na Jun 8, 2023
0aaaf34
forgot the tracer
s1na Jun 8, 2023
2db37b9
minor
s1na Jun 8, 2023
04965a3
fix marshaling of empty values
s1na Jun 15, 2023
c78330d
rename to multicallV1
s1na Jun 30, 2023
8fff7fd
return block info except blockhash
s1na Jul 3, 2023
637acc5
Finalise state after call, add selfdestruct test
s1na Jul 13, 2023
d23eb89
Add status field to call result
s1na Jul 13, 2023
a7af5a9
wrap params into an object
s1na Jul 13, 2023
98882fc
blockhash = keccak(blockNum)
s1na Jul 13, 2023
b865824
name tests
s1na Jul 17, 2023
da3102e
persist precompiles in evm
s1na Jul 17, 2023
6a2c96c
add storage clearing test case for eth_call
s1na Jul 18, 2023
b3efbad
implement precompile override and moveTo feature
s1na Jul 18, 2023
9aed710
copy storage over in MoveTo
s1na Jul 18, 2023
2c25ab6
add todo comments
s1na Jul 24, 2023
5d351c9
add testcase moveto precompile
s1na Jul 31, 2023
63f4f6e
rm ecrecover override field
s1na Jul 31, 2023
80506ea
rename blocks to blockStateCalls
s1na Jul 31, 2023
fd786c0
rename to moveToAddress
s1na Aug 1, 2023
6845b5e
add optional validation of txes
s1na Aug 1, 2023
c5e33fa
test coinbase
s1na Aug 2, 2023
d4e332e
fix storage clearing
s1na Aug 3, 2023
b0e7869
Rename block override field names
s1na Sep 4, 2023
56b4402
auto-set and validate block number and timestamp
s1na Sep 4, 2023
7e17e4c
implement transfers as logs
s1na Sep 4, 2023
fe3bb83
add prevrandao to result
s1na Sep 5, 2023
906d93a
clear logs on call fail
s1na Sep 5, 2023
8e02675
add txhash to logs
s1na Sep 7, 2023
a0d2706
moveTo only for precompiles
s1na Sep 11, 2023
ed4cbaf
resolve merge conflicts
s1na Sep 13, 2023
3231291
optional block param
s1na Sep 20, 2023
3df0fec
rename return to returnData
s1na Sep 20, 2023
760f5e5
fix tx gaslimit and type default
s1na Sep 20, 2023
b3996e4
dont set defaults for calls
s1na Sep 20, 2023
100c593
fix crasher
s1na Sep 29, 2023
523e3d2
cover it in test case
s1na Sep 29, 2023
d5c0ff4
add error codes to calls
s1na Oct 4, 2023
45ba37e
compute block hash based on header
s1na Oct 5, 2023
973116c
repair logs
s1na Oct 5, 2023
a5ffd9a
serve blockhash requests
s1na Oct 6, 2023
cc1158a
possibly fix crasher
s1na Oct 10, 2023
2690445
fix block hash cache
s1na Oct 10, 2023
d1ce690
move multicall logic to struct
s1na Oct 10, 2023
e230258
move precompile list to own func
s1na Oct 10, 2023
c02d29d
limit number of blocks
s1na Oct 24, 2023
e4eb56a
add error code for blocks length check
s1na Oct 24, 2023
ed37821
rename types
s1na Oct 24, 2023
f5ac039
fix error codes
s1na Oct 26, 2023
23ef9c6
minor fix
s1na Nov 13, 2023
6da9202
Fix extra delegatecall value log
s1na Dec 14, 2023
12d59b5
update transfer log address
s1na Dec 14, 2023
1616559
resolve merge conflicts
s1na Dec 14, 2023
7fff1c4
Add cancun to precompiled contracts
s1na Dec 14, 2023
bf78094
safer api for getting active precompiles
s1na Dec 14, 2023
c594f74
fix godoc comment
s1na Jan 3, 2024
11133e0
fix precompileMove in eth_call
s1na Jan 3, 2024
ad24d2e
rename block overrides receiver name
s1na Jan 3, 2024
c77da8c
rename validate param
s1na Jan 3, 2024
3d29c1f
copy header prior to applying overrides
s1na Jan 3, 2024
31e2cc9
legacy tx if gasPrice provided
s1na Jan 4, 2024
5ed9958
resolve merge conflict
s1na Jan 4, 2024
2b1cf22
fix graphql test
s1na Jan 4, 2024
fd0f626
fix rpcgascap for ethclient tests
s1na Jan 4, 2024
1e7b497
fix block overrides in gethclient
s1na Jan 4, 2024
589107b
rename to blobGasPrice
s1na Jan 5, 2024
89df0e3
rename method to eth_simulateV1
s1na Jan 11, 2024
1a28a17
move call sanitization to own method
s1na Jan 15, 2024
115117c
move tx type detection check
s1na Jan 15, 2024
df14718
compute receipts
s1na Jan 16, 2024
ae33566
finish renaming to simulate
s1na Jan 17, 2024
12d7dd0
fix empty tx, receipts hash
s1na Jan 17, 2024
214e209
minor rename:
s1na Jan 17, 2024
af155c1
move block processing logic to func
s1na Jan 17, 2024
c73c10a
merge master
s1na Feb 19, 2024
489ef43
fix lint errs
s1na Feb 19, 2024
0c0b13d
rename to blobBaseFee
s1na Feb 19, 2024
86ce924
revert setDefaults changes, skip extra validations:
s1na Feb 21, 2024
4a017ff
rm obsolete test
s1na Feb 21, 2024
49bf257
resolve merge conflict
s1na Feb 21, 2024
9fa1556
fix makeHeaders using unpopulated parent
s1na Mar 5, 2024
7177f22
check gas fee in validation mode
s1na Mar 5, 2024
3daabda
add empty withdrawals obj
s1na Mar 29, 2024
c08ba25
resolve merge conflict
s1na Mar 29, 2024
81e7fe1
fix baseFee, add blobGasUsed and excessBlobGas to result
s1na Apr 5, 2024
8698221
default timestamp bump to 12
s1na May 6, 2024
48ca188
generate empty blocks for gaps
s1na May 7, 2024
81e065c
fix block hashes
s1na May 7, 2024
263cfd7
compute basefee prior to execution
s1na May 22, 2024
e382782
return full header
s1na May 28, 2024
9139685
add fullTx option
s1na May 28, 2024
569a2d7
move out base fee lowering to api code
s1na Jun 6, 2024
d7cd3a0
missed one file
s1na Jun 6, 2024
399812a
set base fee to 0 in non-validating mode
s1na Jun 6, 2024
1c154e9
check base fee in test block results
s1na Jun 6, 2024
638d82b
resolve merge conflict
s1na Jun 7, 2024
ac690f0
fix chainId default
s1na Jun 12, 2024
a9842e5
add td
s1na Jun 12, 2024
a6f80c7
add data on reverts
s1na Jun 12, 2024
5db0106
fix
s1na Jun 12, 2024
4c325ba
skip EoA check in validation mode
s1na Jun 12, 2024
102aa80
resolve merge conflict
s1na Jul 15, 2024
172ed02
refactors
s1na Jul 15, 2024
ddba7dd
rm stale todos
s1na Jul 15, 2024
c0d5dfb
resolve merge conflict
s1na Jul 25, 2024
e3cd999
default timestamp bump 1 sec
s1na Aug 14, 2024
33400fb
review comments, pt. 1
s1na Aug 16, 2024
5f0fafd
fix precompile moveTo
s1na Aug 16, 2024
73ff7e5
move timestamp sanitization
s1na Aug 19, 2024
5d8c058
Clean up sanitizeCall
s1na Aug 19, 2024
edf9e37
Fix lint errors
s1na Aug 19, 2024
e7bac20
add test comments
s1na Aug 19, 2024
9a963dc
add license to simulate_test
s1na Sep 4, 2024
7198fc1
update test to use fixed address
s1na Sep 4, 2024
6ec5083
Merge branch 'master' into multicall
s1na Sep 4, 2024
791719a
core/vm: use maps.Clone
holiman Sep 4, 2024
c216ef5
internal: refactored ToTransaction of transaction args
holiman Sep 4, 2024
2415110
Merge branch 'master' into multicall
s1na Sep 4, 2024
6205806
internal/ethapi: simplify
holiman Sep 5, 2024
098a448
internal/ethapi: abort when context is cancelled
holiman Sep 5, 2024
9da10f9
Merge branch 'master' into multicall
holiman Sep 6, 2024
f25fcd3
internal/ethapi: fix merge-conflicts
holiman Sep 6, 2024
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
Prev Previous commit
Next Next commit
resolve merge conflict
  • Loading branch information
s1na committed Jun 7, 2024
commit 638d82bdf7608032245cd5c96cd5ca5c45d208e8
100 changes: 57 additions & 43 deletions core/vm/contracts.go
Original file line number Diff line number Diff line change
Expand Up @@ -52,56 +52,56 @@ type PrecompiledContracts map[common.Address]PrecompiledContract
// PrecompiledContractsHomestead contains the default set of pre-compiled Ethereum
// contracts used in the Frontier and Homestead releases.
var PrecompiledContractsHomestead = PrecompiledContracts{
common.BytesToAddress([]byte{1}): &ecrecover{},
common.BytesToAddress([]byte{2}): &sha256hash{},
common.BytesToAddress([]byte{3}): &ripemd160hash{},
common.BytesToAddress([]byte{4}): &dataCopy{},
common.BytesToAddress([]byte{0x1}): &ecrecover{},
common.BytesToAddress([]byte{0x2}): &sha256hash{},
common.BytesToAddress([]byte{0x3}): &ripemd160hash{},
common.BytesToAddress([]byte{0x4}): &dataCopy{},
}

// PrecompiledContractsByzantium contains the default set of pre-compiled Ethereum
// contracts used in the Byzantium release.
var PrecompiledContractsByzantium = PrecompiledContracts{
common.BytesToAddress([]byte{1}): &ecrecover{},
common.BytesToAddress([]byte{2}): &sha256hash{},
common.BytesToAddress([]byte{3}): &ripemd160hash{},
common.BytesToAddress([]byte{4}): &dataCopy{},
common.BytesToAddress([]byte{5}): &bigModExp{eip2565: false},
common.BytesToAddress([]byte{6}): &bn256AddByzantium{},
common.BytesToAddress([]byte{7}): &bn256ScalarMulByzantium{},
common.BytesToAddress([]byte{8}): &bn256PairingByzantium{},
common.BytesToAddress([]byte{0x1}): &ecrecover{},
common.BytesToAddress([]byte{0x2}): &sha256hash{},
common.BytesToAddress([]byte{0x3}): &ripemd160hash{},
common.BytesToAddress([]byte{0x4}): &dataCopy{},
common.BytesToAddress([]byte{0x5}): &bigModExp{eip2565: false},
common.BytesToAddress([]byte{0x6}): &bn256AddByzantium{},
common.BytesToAddress([]byte{0x7}): &bn256ScalarMulByzantium{},
common.BytesToAddress([]byte{0x8}): &bn256PairingByzantium{},
}

// PrecompiledContractsIstanbul contains the default set of pre-compiled Ethereum
// contracts used in the Istanbul release.
var PrecompiledContractsIstanbul = PrecompiledContracts{
common.BytesToAddress([]byte{1}): &ecrecover{},
common.BytesToAddress([]byte{2}): &sha256hash{},
common.BytesToAddress([]byte{3}): &ripemd160hash{},
common.BytesToAddress([]byte{4}): &dataCopy{},
common.BytesToAddress([]byte{5}): &bigModExp{eip2565: false},
common.BytesToAddress([]byte{6}): &bn256AddIstanbul{},
common.BytesToAddress([]byte{7}): &bn256ScalarMulIstanbul{},
common.BytesToAddress([]byte{8}): &bn256PairingIstanbul{},
common.BytesToAddress([]byte{9}): &blake2F{},
common.BytesToAddress([]byte{0x1}): &ecrecover{},
common.BytesToAddress([]byte{0x2}): &sha256hash{},
common.BytesToAddress([]byte{0x3}): &ripemd160hash{},
common.BytesToAddress([]byte{0x4}): &dataCopy{},
common.BytesToAddress([]byte{0x5}): &bigModExp{eip2565: false},
common.BytesToAddress([]byte{0x6}): &bn256AddIstanbul{},
common.BytesToAddress([]byte{0x7}): &bn256ScalarMulIstanbul{},
common.BytesToAddress([]byte{0x8}): &bn256PairingIstanbul{},
common.BytesToAddress([]byte{0x9}): &blake2F{},
}

// PrecompiledContractsBerlin contains the default set of pre-compiled Ethereum
// contracts used in the Berlin release.
var PrecompiledContractsBerlin = PrecompiledContracts{
common.BytesToAddress([]byte{1}): &ecrecover{},
common.BytesToAddress([]byte{2}): &sha256hash{},
common.BytesToAddress([]byte{3}): &ripemd160hash{},
common.BytesToAddress([]byte{4}): &dataCopy{},
common.BytesToAddress([]byte{5}): &bigModExp{eip2565: true},
common.BytesToAddress([]byte{6}): &bn256AddIstanbul{},
common.BytesToAddress([]byte{7}): &bn256ScalarMulIstanbul{},
common.BytesToAddress([]byte{8}): &bn256PairingIstanbul{},
common.BytesToAddress([]byte{9}): &blake2F{},
common.BytesToAddress([]byte{0x1}): &ecrecover{},
common.BytesToAddress([]byte{0x2}): &sha256hash{},
common.BytesToAddress([]byte{0x3}): &ripemd160hash{},
common.BytesToAddress([]byte{0x4}): &dataCopy{},
common.BytesToAddress([]byte{0x5}): &bigModExp{eip2565: true},
common.BytesToAddress([]byte{0x6}): &bn256AddIstanbul{},
common.BytesToAddress([]byte{0x7}): &bn256ScalarMulIstanbul{},
common.BytesToAddress([]byte{0x8}): &bn256PairingIstanbul{},
common.BytesToAddress([]byte{0x9}): &blake2F{},
}

// PrecompiledContractsCancun contains the default set of pre-compiled Ethereum
// contracts used in the Cancun release.
var PrecompiledContractsCancun = map[common.Address]PrecompiledContract{
var PrecompiledContractsCancun = PrecompiledContracts{
common.BytesToAddress([]byte{0x1}): &ecrecover{},
common.BytesToAddress([]byte{0x2}): &sha256hash{},
common.BytesToAddress([]byte{0x3}): &ripemd160hash{},
Expand All @@ -114,18 +114,28 @@ var PrecompiledContractsCancun = map[common.Address]PrecompiledContract{
common.BytesToAddress([]byte{0xa}): &kzgPointEvaluation{},
}

// PrecompiledContractsBLS contains the set of pre-compiled Ethereum
// contracts specified in EIP-2537. These are exported for testing purposes.
var PrecompiledContractsBLS = PrecompiledContracts{
common.BytesToAddress([]byte{10}): &bls12381G1Add{},
common.BytesToAddress([]byte{11}): &bls12381G1Mul{},
common.BytesToAddress([]byte{12}): &bls12381G1MultiExp{},
common.BytesToAddress([]byte{13}): &bls12381G2Add{},
common.BytesToAddress([]byte{14}): &bls12381G2Mul{},
common.BytesToAddress([]byte{15}): &bls12381G2MultiExp{},
common.BytesToAddress([]byte{16}): &bls12381Pairing{},
common.BytesToAddress([]byte{17}): &bls12381MapG1{},
common.BytesToAddress([]byte{18}): &bls12381MapG2{},
// PrecompiledContractsPrague contains the set of pre-compiled Ethereum
// contracts used in the Prague release.
var PrecompiledContractsPrague = PrecompiledContracts{
common.BytesToAddress([]byte{0x01}): &ecrecover{},
common.BytesToAddress([]byte{0x02}): &sha256hash{},
common.BytesToAddress([]byte{0x03}): &ripemd160hash{},
common.BytesToAddress([]byte{0x04}): &dataCopy{},
common.BytesToAddress([]byte{0x05}): &bigModExp{eip2565: true},
common.BytesToAddress([]byte{0x06}): &bn256AddIstanbul{},
common.BytesToAddress([]byte{0x07}): &bn256ScalarMulIstanbul{},
common.BytesToAddress([]byte{0x08}): &bn256PairingIstanbul{},
common.BytesToAddress([]byte{0x09}): &blake2F{},
common.BytesToAddress([]byte{0x0a}): &kzgPointEvaluation{},
common.BytesToAddress([]byte{0x0b}): &bls12381G1Add{},
common.BytesToAddress([]byte{0x0c}): &bls12381G1Mul{},
common.BytesToAddress([]byte{0x0d}): &bls12381G1MultiExp{},
common.BytesToAddress([]byte{0x0e}): &bls12381G2Add{},
common.BytesToAddress([]byte{0x0f}): &bls12381G2Mul{},
common.BytesToAddress([]byte{0x10}): &bls12381G2MultiExp{},
common.BytesToAddress([]byte{0x11}): &bls12381Pairing{},
common.BytesToAddress([]byte{0x12}): &bls12381MapG1{},
common.BytesToAddress([]byte{0x13}): &bls12381MapG2{},
}

var PrecompiledContractsBLS = PrecompiledContractsPrague
Expand Down Expand Up @@ -173,6 +183,10 @@ func (p PrecompiledContracts) Copy() PrecompiledContracts {

func activePrecompiledContracts(rules params.Rules) PrecompiledContracts {
switch {
case rules.IsVerkle:
return PrecompiledContractsVerkle
case rules.IsPrague:
return PrecompiledContractsPrague
case rules.IsCancun:
return PrecompiledContractsCancun
case rules.IsBerlin:
Expand Down
1 change: 1 addition & 0 deletions eth/tracers/api.go
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,7 @@ import (
"encoding/json"
"errors"
"fmt"
"math/big"
"os"
"runtime"
"sync"
Expand Down
9 changes: 7 additions & 2 deletions internal/ethapi/api.go
Original file line number Diff line number Diff line change
Expand Up @@ -1291,12 +1291,17 @@ func DoEstimateGas(ctx context.Context, b Backend, args TransactionArgs, blockNr
State: state,
ErrorRatio: estimateGasErrorRatio,
}

// Set any required transaction default, but make sure the gas cap itself is not messed with
// if it was not specified in the original argument list.
if args.Gas == nil {
args.Gas = new(hexutil.Uint64)
}
if err := args.CallDefaults(gasCap, header.BaseFee, b.ChainConfig().ChainID); err != nil {
return 0, err
}
call := args.ToMessage(header.BaseFee, true)
// Run the gas estimation andwrap any revertals into a custom return

// Run the gas estimation and wrap any revertals into a custom return
estimate, revert, err := gasestimator.Estimate(ctx, call, opts, gasCap)
if err != nil {
if len(revert) > 0 {
Expand Down
22 changes: 17 additions & 5 deletions internal/ethapi/api_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -815,6 +815,7 @@ func TestCall(t *testing.T) {
}))
randomAccounts := newAccounts(3)
var testSuite = []struct {
name string
blockNumber rpc.BlockNumber
overrides StateOverride
call TransactionArgs
Expand All @@ -824,6 +825,7 @@ func TestCall(t *testing.T) {
}{
// transfer on genesis
{
name: "transfer-on-genesis",
blockNumber: rpc.BlockNumber(0),
call: TransactionArgs{
From: &accounts[0].addr,
Expand All @@ -835,6 +837,7 @@ func TestCall(t *testing.T) {
},
// transfer on the head
{
name: "transfer-on-the-head",
blockNumber: rpc.BlockNumber(genBlocks),
call: TransactionArgs{
From: &accounts[0].addr,
Expand All @@ -846,6 +849,7 @@ func TestCall(t *testing.T) {
},
// transfer on a non-existent block, error expects
{
name: "transfer-non-existent-block",
blockNumber: rpc.BlockNumber(genBlocks + 1),
call: TransactionArgs{
From: &accounts[0].addr,
Expand All @@ -856,6 +860,7 @@ func TestCall(t *testing.T) {
},
// transfer on the latest block
{
name: "transfer-latest-block",
blockNumber: rpc.LatestBlockNumber,
call: TransactionArgs{
From: &accounts[0].addr,
Expand All @@ -867,6 +872,7 @@ func TestCall(t *testing.T) {
},
// Call which can only succeed if state is state overridden
{
name: "state-override-success",
blockNumber: rpc.LatestBlockNumber,
call: TransactionArgs{
From: &randomAccounts[0].addr,
Expand All @@ -880,6 +886,7 @@ func TestCall(t *testing.T) {
},
// Invalid call without state overriding
{
name: "insufficient-funds-simple",
blockNumber: rpc.LatestBlockNumber,
call: TransactionArgs{
From: &randomAccounts[0].addr,
Expand All @@ -905,6 +912,7 @@ func TestCall(t *testing.T) {
// }
// }
{
name: "simple-contract-call",
blockNumber: rpc.LatestBlockNumber,
call: TransactionArgs{
From: &randomAccounts[0].addr,
Expand All @@ -921,6 +929,7 @@ func TestCall(t *testing.T) {
},
// Block overrides should work
{
name: "block-override",
blockNumber: rpc.LatestBlockNumber,
call: TransactionArgs{
From: &accounts[1].addr,
Expand All @@ -935,6 +944,7 @@ func TestCall(t *testing.T) {
},
// Clear storage trie
{
name: "clear-storage-trie",
blockNumber: rpc.LatestBlockNumber,
call: TransactionArgs{
From: &accounts[1].addr,
Expand All @@ -961,6 +971,7 @@ func TestCall(t *testing.T) {
},
// Invalid blob tx
{
name: "invalid-blob-tx",
blockNumber: rpc.LatestBlockNumber,
call: TransactionArgs{
From: &accounts[1].addr,
Expand All @@ -971,6 +982,7 @@ func TestCall(t *testing.T) {
},
// BLOBHASH opcode
{
name: "blobhash-opcode",
blockNumber: rpc.LatestBlockNumber,
call: TransactionArgs{
From: &accounts[1].addr,
Expand All @@ -986,27 +998,27 @@ func TestCall(t *testing.T) {
want: "0x0122000000000000000000000000000000000000000000000000000000000000",
},
}
for i, tc := range testSuite {
for _, tc := range testSuite {
result, err := api.Call(context.Background(), tc.call, &rpc.BlockNumberOrHash{BlockNumber: &tc.blockNumber}, &tc.overrides, &tc.blockOverrides)
if tc.expectErr != nil {
if err == nil {
t.Errorf("test %d: want error %v, have nothing", i, tc.expectErr)
t.Errorf("test %s: want error %v, have nothing", tc.name, tc.expectErr)
continue
}
if !errors.Is(err, tc.expectErr) {
// Second try
if !reflect.DeepEqual(err, tc.expectErr) {
t.Errorf("test %d: error mismatch, want %v, have %v", i, tc.expectErr, err)
t.Errorf("test %s: error mismatch, want %v, have %v", tc.name, tc.expectErr, err)
}
}
continue
}
if err != nil {
t.Errorf("test %d: want no error, have %v", i, err)
t.Errorf("test %s: want no error, have %v", tc.name, err)
continue
}
if !reflect.DeepEqual(result.String(), tc.want) {
t.Errorf("test %d, result mismatch, have\n%v\n, want\n%v\n", i, result.String(), tc.want)
t.Errorf("test %s, result mismatch, have\n%v\n, want\n%v\n", tc.name, result.String(), tc.want)
}
}
}
Expand Down
2 changes: 1 addition & 1 deletion internal/ethapi/simulate.go
Original file line number Diff line number Diff line change
Expand Up @@ -240,7 +240,7 @@ func (sim *simulator) processBlock(ctx context.Context, block *simBlock, header,
if config.IsShanghai(header.Number, header.Time) {
withdrawals = make([]*types.Withdrawal, 0)
}
b := types.NewBlockWithWithdrawals(header, txes, nil, receipts, withdrawals, trie.NewStackTrie(nil))
b := types.NewBlock(header, &types.Body{Transactions: txes, Withdrawals: withdrawals}, receipts, trie.NewStackTrie(nil))
res := RPCMarshalBlock(b, true, sim.fullTx, config)
repairLogs(callResults, res["hash"].(common.Hash))
res["calls"] = callResults
Expand Down
Loading
You are viewing a condensed version of this merge commit. You can view the full changes here.