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

Merge v1.11.2 #205

Merged
merged 441 commits into from
May 8, 2023
Merged
Show file tree
Hide file tree
Changes from 21 commits
Commits
Show all changes
441 commits
Select commit Hold shift + click to select a range
c539bda
metrics: improve reading Go runtime metrics (#25886)
fjl Nov 11, 2022
ea65eda
eth, catalyst: fix flaky tests (#26153)
holiman Nov 11, 2022
8334b5f
common/lru: fix race in lru (#26164)
holiman Nov 11, 2022
e34e540
accounts/keystore: replace inotify with fsnotify (#26176)
holiman Nov 14, 2022
8c5ce11
eth/filters: send rpctransactions in pending-subscription (#26126)
holiman Nov 14, 2022
f58ebd9
all: use github.com/deckarep/golang-set/v2 (generic set) (#26159)
Jolly23 Nov 14, 2022
9afc681
common/lru: add generic LRU implementation (#26162)
fjl Nov 14, 2022
ae42148
rpc: fix connection tracking set in Server (#26180)
fjl Nov 15, 2022
bc90a88
ethclient: docs, fix misleading comment (#26189)
ligi Nov 16, 2022
b4ea2bf
all: implement EIP-1153 transient storage (#26003)
tynes Nov 16, 2022
add337e
rpc: support injecting HTTP headers through context (#26023)
storyicon Nov 16, 2022
64067fb
eth/tracers: small refactor for native tracers (#26196)
s1na Nov 17, 2022
c3b4268
Dockerfile: upgrade to Go 1.19 (#26195)
fjl Nov 17, 2022
12df456
all: remove remaining uses of untyped golang-lru (#26194)
fjl Nov 17, 2022
722bb21
rlp: improve tests for Split functions (#26200)
therainisme Nov 17, 2022
97c563e
rpc, internal/guide: speed up tests a bit (#26193)
holiman Nov 17, 2022
c2e0abc
ethstats: set readlimit on ethstats server connection (#26207)
holiman Nov 17, 2022
6975f09
eth/catalyst: make tests less time-sensitive (#26201)
holiman Nov 21, 2022
64dccf7
cmd/utils: log path used when checking disk space (#26212)
kumavis Nov 21, 2022
ec2ec2d
core: implement EIP-3651, warm coinbase (#25819)
MariusVanDerWijden Nov 22, 2022
193f350
core/rawdb: improve freezerTable.Sync (#26245)
fjl Nov 24, 2022
8846c07
cmd/utils: print warning when --metrics.port set without --metrics.ad…
fjl Nov 24, 2022
e76813e
signer/core/apitypes: deep convert types in slice (#26203)
6xiaowu9 Nov 24, 2022
c5dc61c
cmd/utils: gofmt
fjl Nov 24, 2022
add1bff
core/rawdb: fix freezer validation (#26251)
rjl493456442 Nov 25, 2022
6a4e05c
signer: enable typed data signing from signer rpc (#26241)
holiman Nov 25, 2022
8c6e74e
rpc: decrease websocket ping interval (#26253)
Wihandebeer Nov 25, 2022
53d1ae0
p2p/nat: use IP.IsPrivate (#26252)
dbadoy Nov 25, 2022
1325fef
internal/web3ext: fix eth_call stateOverrides in console (#26265)
s1na Nov 28, 2022
0dc9b01
core: clarify code in forkchoice (#26257)
setunapo Nov 28, 2022
eb01927
tests: update evm-benchmarks (#26255)
chfast Nov 28, 2022
63ffda3
internal/web3ext: fix eth.call regression in console (#26266)
s1na Nov 28, 2022
0e06735
internal/web3ext: fix eth_call in console, part III (#26268)
s1na Nov 28, 2022
743e404
core, eth, les, tests, trie: abstract node scheme (#25532)
rjl493456442 Nov 28, 2022
1b8a392
console: use default APIs when server doesn't have rpc_modules (#26267)
fjl Nov 28, 2022
c1aa1db
p2p/discover: add config option for discv5 protocol ID (#26041)
richard-ramos Nov 30, 2022
e24d600
miner: fix potential goroutine leak in test (#26281)
BarrensZeppelin Dec 2, 2022
10347c6
core: drop legacy receipt types (#26225)
s1na Dec 3, 2022
06632da
all: assign zero after resize in implementations of heap.Interface (#…
estensen Dec 5, 2022
1f35988
eth/tracers, core/vm: remove `time` from trace output and tracing int…
holiman Dec 5, 2022
41306b0
cmd/evm: output stateroot in statetest result (#26297)
holiman Dec 5, 2022
01953b3
cmd/geth: fix typo in comment (#26308)
qiuhaohao Dec 5, 2022
b44abf5
cmd/devp2p: add --extaddr flag (#26312)
fjl Dec 6, 2022
f20eba4
graphql, node, rpc: improve HTTP write timeout handling (#25457)
s1na Dec 7, 2022
4221280
p2p/nat: handle responses with alternative port in NAT-PMP (#26321)
dbadoy Dec 7, 2022
6891288
core: fix state flushing for catalyst mode (#26319)
s1na Dec 7, 2022
a9dfac0
p2p/discover: improve nodesByDistance.push code (#26019)
zhiqiangxu Dec 7, 2022
890e2ef
eth, cmd: remove syncTarget from eth config (#26330)
rjl493456442 Dec 8, 2022
711afbc
core,eth: add `debug_setTrieFlushInterval` to change trie flush frequ…
s1na Dec 9, 2022
3315bad
core: pass block into collectLogs (#26335)
fjl Dec 9, 2022
3775e19
event: add FeedOf[T] (#26310)
fjl Dec 9, 2022
262bd38
eth/tracers: return proper error from debug_TraceTransaction when tx …
mdehoog Dec 10, 2022
250a80a
core: fix comment about recipient for contract creation (#26349)
ralexstokes Dec 13, 2022
cda051e
core, cmd: fill blockNumber in logs (#26345)
rjl493456442 Dec 13, 2022
fa97788
eth/tracers/native: fix possible crash in prestate tracer (#26351)
holiman Dec 13, 2022
502fa82
signer/core: handle gnosis safe problem with missing chain id (#26309)
holiman Dec 14, 2022
f51f6ed
core: fix typo in blockchain_snapshot_test.go (#26357)
eltociear Dec 14, 2022
f53ff0f
eth/filters, eth/tracers: add request cancellation checks (#26320)
fjl Dec 15, 2022
d3411b9
trie: wrap deletion in case trie.root is nil (#26365)
rjl493456442 Dec 19, 2022
79a478b
core/rawdb: implement resettable freezer (#26324)
rjl493456442 Dec 19, 2022
b818e73
tests: update tests (#26314)
holiman Dec 20, 2022
0180842
core/state: return error when storage trie can't be opened (#26350)
rjl493456442 Dec 21, 2022
577db2e
build: add support for Ubuntu 22.10 (Kinetic Kudu) (#26379)
n1charlie Dec 27, 2022
9921ca0
miner: allow for extradata in post-merge blocks (#26387)
MariusVanDerWijden Dec 28, 2022
c87f321
core/state: maintain destruction flag by default (#26371)
rjl493456442 Dec 28, 2022
db82ea2
core: reset txpool on sethead (#26392)
MariusVanDerWijden Dec 29, 2022
9d38466
eth/downloader: fix some typos (#26396)
hadv Jan 3, 2023
dad9250
cmd, internal: update copyright year to 2023 (#26382)
sandakersmann Jan 3, 2023
c6a2f77
cmd/devp2p/internal/v4test: add pong validation in bond (#26400)
strykerin Jan 3, 2023
efc9409
params: core: enable shanghai based on timestamps
MariusVanDerWijden Sep 27, 2022
a4e19c5
all: implement forkid changes for shanghai
MariusVanDerWijden Nov 10, 2022
0848102
core, les, params: add timestamp based fork compatibility checks
karalabe Dec 15, 2022
d021157
core, les, light: implement timestamp based sethead and genesis rewinds
karalabe Dec 16, 2022
9e6a1c3
common/mclock: add Alarm (#26333)
fjl Jan 3, 2023
a251bca
p2p/discover: add more packet information in logs (#26307)
fjl Jan 3, 2023
41fe9d6
cmd/evm: update documentation (#26385)
holiman Jan 3, 2023
6c149fd
core, eth, trie, light: clean up trie interface (#26388)
rjl493456442 Jan 3, 2023
f426805
build: upgrade -dlgo version to Go 1.19.4 (#26440)
sandakersmann Jan 6, 2023
fcf3d00
eth, les: polish forkid a bit, fix races and transition validation
karalabe Jan 3, 2023
b56c796
cmd, core, eth, els, params: disallow setheads below genesis, tweaks
karalabe Jan 6, 2023
2189773
Merge pull request #25878 from MariusVanDerWijden/shanghai-by-time
karalabe Jan 6, 2023
686f743
eth/downloader: fix unexpected skeleton header deletion
rjl493456442 Jan 9, 2023
71f7988
eth/downloader: create repro testcase for beacon header loss
karalabe Jan 9, 2023
43692c8
Merge pull request #26451 from rjl493456442/fix-beacon-sync-2
karalabe Jan 9, 2023
ccacb99
cmd/evm: support shanghai in tests + evm t8n (#26458)
marioevz Jan 10, 2023
faff980
crypto/bls12381: use worst case scalar for input to G1/G2 mul benchma…
jwasinger Jan 10, 2023
b8bc8c2
README.md: add website contribution instructions (#26442)
jmcook1186 Jan 10, 2023
4ada314
tests: fix DIFFICULTY error in state executor (#26465)
holiman Jan 10, 2023
7a48962
core/state: remove notion of fake storage (#24916)
holiman Jan 10, 2023
2c6dda5
eth/tracers: use non-threaded tracechain (#24283)
holiman Jan 10, 2023
452a12a
eth/downloader: move the pivot in beacon sync mode too (#26453)
karalabe Jan 10, 2023
793f0f9
core/vm: implement EIP-3860: Limit and meter initcode (#23847)
gumb0 Jan 11, 2023
c125e6e
core/vm: enable EIP-3855 (PUSH0) in Shanghai (#26475)
yperbasis Jan 12, 2023
6f858fa
rpc: fix setting client in DialHTTPWithClient (#26470)
lightclient Jan 12, 2023
b748709
eth/downloader: fix cornercase when clean stale beacon headers (#26441)
rjl493456442 Jan 12, 2023
d379e3f
ethclient/gethclient: ensure getProof keys parameter is not null (#26…
fjl Jan 12, 2023
a21e963
eth/catalyst: trigger beacon sync directly with provided chain head (…
rjl493456442 Jan 13, 2023
e04d63e
core/rawdb: fsync head data file before closing it (#26490)
rjl493456442 Jan 13, 2023
0e486a5
Use filepath.clean instead of path.clean (#26404)
MariusVanDerWijden Jan 13, 2023
450d771
readme: fix broken link to installation instructions (#26497)
dhij Jan 15, 2023
0b53b29
core/rawdb: fix cornercase shutdown behaviour in freezer (#26485)
holiman Jan 16, 2023
554c8d7
cmd/utils: update Rinkeby deprecation message (#26496)
n1charlie Jan 16, 2023
55c3b6f
swarm: fix outdated link (#26501)
ucwong Jan 16, 2023
d345a4a
cmd/bootnode, cmd/utils: add 'pmp:<IP>' to --nat flag description (#2…
dbadoy Jan 16, 2023
c858da5
cmd/evm: fix typo in README.md (#26500)
eltociear Jan 16, 2023
8d4c81d
build: upgrade -dlgo version to Go 1.19.5 (#26472)
sandakersmann Jan 16, 2023
f2758a8
cmd/evm: typo fix in docs (#26506)
ucwong Jan 16, 2023
297ec06
metrics/influxdb: fix time ticker leaks (#26507)
ucwong Jan 17, 2023
97401b6
eth/filters: fix typo in comment (#26515)
molecula451 Jan 17, 2023
4a3fb58
les/fetcher : fix requestTimer leak (#26514)
ucwong Jan 18, 2023
a35b654
core/txpool: check if initcode size is exceeded (#26504)
MariusVanDerWijden Jan 18, 2023
690338f
all: remove Kiln testnet (#26522)
n1charlie Jan 19, 2023
2d2c069
console, internal/jsre: fix autocomplete issues (#26518)
s1na Jan 19, 2023
24c7023
go.mod: upgrade to go-bip39 v1.1.0 (#26527)
meehow Jan 20, 2023
8748972
go.sum: tidy (#26525)
ucwong Jan 20, 2023
3f544ce
.travis.yml: go1.19.5 for android builds (#26524)
ucwong Jan 20, 2023
50e6539
params: define cancun and prague as timestamp based forks (#26481)
rjl493456442 Jan 20, 2023
4f4a25d
signer/core: don't require capital lettered reference types (#26462)
holiman Jan 20, 2023
2b44ef5
miner, cmd, eth: require explicit etherbase address (#26413)
rjl493456442 Jan 20, 2023
d36e6fc
go.mod: upgrade to latest goja (#26523)
s1na Jan 23, 2023
e4fa2cf
go.sum: go mod tidy (#26536)
ucwong Jan 23, 2023
163e996
all: use http package to replace http method names (#26535)
islishude Jan 24, 2023
59a48e0
cmd/utils: improve parsing of --miner.etherbase address (#26541)
fjl Jan 24, 2023
2b57a27
all: make timestamp-based fork checks based on uint64 (#26474)
holiman Jan 25, 2023
2a2b041
all: implement withdrawals (EIP-4895) (#26484)
MariusVanDerWijden Jan 25, 2023
55f41d1
cmd/utils: fix error at geth startup in --dev mode (#26550)
fjl Jan 26, 2023
245cff0
eth/catalyst: error on nil withdrawals post-shanghai (#26549)
MariusVanDerWijden Jan 27, 2023
2fecac6
eth/catalyst: implement exchangeCapabilities method (#26555)
MariusVanDerWijden Jan 27, 2023
34115c8
params: fix timestamp display in fork banner (#26553)
fjl Jan 27, 2023
abe4159
params: remove deprecated bootnodes (#26530)
ncocchiaro Jan 27, 2023
a63875b
go.mod: gnark-crypto upgrade (#26545)
ucwong Jan 27, 2023
90f15a0
cmd/evm: add blocktest subcommand to evm (#26526)
marioevz Jan 27, 2023
df52967
eth/catalyst: fix panic in TestWithdrawals (#26563)
fjl Jan 27, 2023
fd4230f
log: fix typo in comment (#26569)
ucwong Jan 30, 2023
3ff3d07
cmd/devp2p: fix broken link in readme(#26576)
pcaversaccio Jan 30, 2023
17017b2
log: better sanitation (#26556)
holiman Jan 30, 2023
78d089b
ethclient/gethclient: fix typo (#26580)
shimmeris Jan 31, 2023
efbd508
eth/tracer: rename to revertReason (#26574)
rjl493456442 Jan 31, 2023
bd6a05e
internal/ethapi: always return block withdrawals if present (#26565)
lightclient Jan 31, 2023
8ded6a9
cmd/puppeth: remove puppeth
holiman Jan 31, 2023
5c8cc10
core: improve ambiguous block validation message (#26582)
holiman Feb 1, 2023
5d8bff1
Merge pull request #26581 from holiman/nuke_puppet
karalabe Feb 2, 2023
a8cf439
eth/catalyst: return invalid params instead of invalid payload params…
MariusVanDerWijden Feb 2, 2023
d0a4989
cmd, eth, node: deprecate personal namespace (#26390)
MariusVanDerWijden Feb 2, 2023
d9699c8
accounts, build, mobile: remove Andriod and iOS support
karalabe Feb 3, 2023
3a79a99
Merge pull request #26599 from karalabe/mobile-nuke
karalabe Feb 3, 2023
877d217
core/vm: improve EVM instance reusability (#26341)
lmittmann Feb 5, 2023
9826cd6
eth/catalyst: implement engine_getPayloadBodiesByHash/Range methods (…
MariusVanDerWijden Feb 6, 2023
bd726f8
readme: fix broken link (#26612)
delihiros Feb 6, 2023
8e92881
rpc: fix off-by-one in ipc endpoint length check (#26614)
holiman Feb 6, 2023
918aed4
core/vm: add bn256ScalarMul testcase for zero scalar value (#26607)
raulk Feb 6, 2023
10c1484
README: remove text about GPU mining (#26609)
sandakersmann Feb 6, 2023
8860b39
all: prepare for path-based trie storage (#26603)
holiman Feb 6, 2023
3a5acee
beacon/engine: move core/beacon to beacon/engine (#26616)
zsfelfoldi Feb 6, 2023
37e3208
build: upgrade to golangci-lint v1.51.1 (#26618)
fjl Feb 6, 2023
91cb6f8
tests: update (#26548)
holiman Feb 6, 2023
cefc0fa
accounts/abi: fix integer encoding/decoding (#26568)
zhiqiangxu Feb 7, 2023
31d401e
rpc: remove DecimalOrHex type (#26629)
fjl Feb 7, 2023
2f73f4f
eth/catalyst,miner: include withdrawals in payload id calculation (#2…
MariusVanDerWijden Feb 7, 2023
00a9b80
light: fix receiver name from Python style to Go (#26631)
halilylm Feb 8, 2023
8c18b48
log: allow tabs in log messages (#26630)
fjl Feb 8, 2023
9842301
all: remove database commit callback, rework noderesolver (#26637)
rjl493456442 Feb 8, 2023
0c9eb8c
eth/catalyst: make getPayloadBodiesByRange take hex inputs (#26624)
jwasinger Feb 8, 2023
095e365
all: remove support for Ropsten (#26644)
karalabe Feb 9, 2023
ed51b8c
ethdb: pebble backend (64bit platforms only) (#26517)
holiman Feb 9, 2023
6a148dd
eth/catalyst: disallow forkchoiceupdate v1 post-shanghai (#26645)
MariusVanDerWijden Feb 9, 2023
bf1798e
common/prque: generic priority queue (#26290)
karalabe Feb 9, 2023
da3c974
ethdb/pebble: fix nil callbacks (#26650)
karalabe Feb 9, 2023
3086c25
eth/downloader: fix timeout resurrection panic (#26652)
karalabe Feb 9, 2023
22c3ad1
core/state, trie: remove unused error-return from trie Commit operati…
holiman Feb 9, 2023
77380b9
go.mod: update pebble to latest master (#26654)
karalabe Feb 9, 2023
b0cd8c4
core/vm: set tracer-observable `value` of a delegatecall to match par…
ziogaschr Feb 10, 2023
0ea65d4
ethdb: add benchmark test suite (#26659)
rjl493456442 Feb 10, 2023
241cf62
params: schedule shanghai fork on sepolia (#26662)
MariusVanDerWijden Feb 10, 2023
2def62b
eth/filters: avoid block body retrieval when no matching logs (#25199)
s1na Feb 13, 2023
7d29fff
eth/tracers: more fork overrides in traceBlockToFile (#26655)
darioush Feb 13, 2023
03585ed
tests/fuzzers: supply gnark multiexp config, fixes #26669 (#26670)
holiman Feb 13, 2023
1c5fa40
cmd/devp2p: reduce output of node crawler (#26674)
holiman Feb 14, 2023
f44ebc4
params: update mainnet + rinkeby CHT (#26677)
holiman Feb 14, 2023
ff38c9e
eth/filters: replace atomic pointer with value (#26689)
s1na Feb 14, 2023
101587b
p2p/dnsdisc: fix tests with Go 1.20 (#26690)
fjl Feb 14, 2023
dbd6c13
eth/catalyst: return error if withdrawals are nil post-shanghai (#26691)
MariusVanDerWijden Feb 14, 2023
5967a22
ethdb/pebble: Fix `MemTableStopWritesThreshold` (#26692)
patrick-ogrady Feb 15, 2023
7fb42e6
eth/downloader: handle missing withdrawals if empty list is expected …
MariusVanDerWijden Feb 15, 2023
18b641b
params: go-ethereum v1.11.0 stable
holiman Feb 15, 2023
194b5c9
params: begin v1.11.1 release cycle
holiman Feb 15, 2023
5ccc99b
travis, build: update Go to 1.20.1 (#26653)
karalabe Feb 16, 2023
08bf8a6
core: check genesis state presence by disk read (#26703)
rjl493456442 Feb 16, 2023
645e3e8
core, eth/downloader: make body validation more strict (#26704)
holiman Feb 16, 2023
13d7de7
eth/downloader: fix empty-body case in queue fetchresult (#26707)
holiman Feb 16, 2023
e9d4249
eth/downloader: fix typo (#26716)
ucwong Feb 16, 2023
4d35256
all: remove deprecated uses of math.rand (#26710)
holiman Feb 16, 2023
7696106
params: go-ethereum v1.11.1 stable
holiman Feb 16, 2023
b40c109
params: begin v1.11.2 release cycle
holiman Feb 16, 2023
6428663
eth/catalyst: send INVALID instead of INVALID_BLOCK_HASH (#26696)
MariusVanDerWijden Feb 17, 2023
15e5e61
eth/catalyst: request too large error (#26722)
rkrasiuk Feb 17, 2023
7c749c9
core/trie: remove trie tracer (#26665)
holiman Feb 19, 2023
1db978c
rpc: fix unmarshaling of null result in CallContext (#26723)
fjl Feb 19, 2023
2166c86
build: ship bootstrapper Go along with builder for PPA (#26731)
karalabe Feb 20, 2023
e1e2781
build: fix setting env var, temp early exit
karalabe Feb 20, 2023
4ec4235
build: fix gobootstrap path for the PPA
karalabe Feb 20, 2023
a43efce
build: add some PPA debug logs, sigh
karalabe Feb 20, 2023
1652684
internal/build: revert raising the chunk size for PPA
karalabe Feb 20, 2023
c02334b
build: yet another weird PPA fix
karalabe Feb 20, 2023
4519054
build: fix (finaly?) the PPA env vars for Go bootstrapping
karalabe Feb 20, 2023
41dee26
build: fix Go 1.19.0 bootstrapper issues on 386 PPA
karalabe Feb 20, 2023
ba4267f
build: enable Lunar Lobster PPA builds
karalabe Feb 20, 2023
13ef21d
Revert "core/trie: remove trie tracer (#26665)" (#26732)
rjl493456442 Feb 20, 2023
7d4db69
cmd/geth: clarify dumpconfig options (#26729)
swkim101 Feb 21, 2023
90d2551
core, eth: merge snap-sync chain download progress logs (#26676)
karalabe Feb 21, 2023
6d2d126
core: fix accessor mismatch for genesis state (#26747)
holiman Feb 21, 2023
2f20fd3
core/rawdb: expose chain freezer constructor without internals (#26748)
karalabe Feb 21, 2023
fe01a2f
all: use unified emptyRootHash and emptyCodeHash (#26718)
rjl493456442 Feb 21, 2023
4034c67
eth/filters: fix a breaking change and return rpctransaction (#26757)
yierx Feb 22, 2023
f86f048
common/math: allow HexOrDecimal to accept unquoted decimals too (#26758)
karalabe Feb 22, 2023
73b01f4
params: release Geth v1.11.2
karalabe Feb 22, 2023
200f18a
Merge tag 'v1.11.2'
Tristan-Wilson Feb 28, 2023
5b323d5
go mod tidy
Tristan-Wilson Feb 28, 2023
c863fd8
Compatibility fns now have block in name
Tristan-Wilson Feb 28, 2023
2c6866f
Remove refs to dropped legacy types
Tristan-Wilson Feb 28, 2023
619f528
rlp decoding merge fix
Tristan-Wilson Feb 28, 2023
3e96f97
Fix arbitrum tx marshalling for tx rename
Tristan-Wilson Feb 28, 2023
5061259
Fix batchCallBuffer timeout handling
Tristan-Wilson Feb 28, 2023
11ec7fe
Remove fastcache finalizer, not using fastcache
Tristan-Wilson Feb 28, 2023
7d84c94
Fix merge of blockchain.go timestamp limit
Tristan-Wilson Feb 28, 2023
7d93587
Fix merge of applyTransaction missing filter arg
Tristan-Wilson Feb 28, 2023
8cf1b94
Fix snap sync.go merge
Tristan-Wilson Feb 28, 2023
5c973ad
Fix GetStorageAt, key decoding for classic
Tristan-Wilson Feb 28, 2023
3b2bb0a
Fix merge of arbitrum tracing functions
Tristan-Wilson Feb 28, 2023
d6fffd9
Fix arbitrum state transaction fn
Tristan-Wilson Feb 28, 2023
252be1d
Fix arbitrum package build
Tristan-Wilson Feb 28, 2023
3800745
Make storedReceiptRLP rawdb redef match core type
Tristan-Wilson Mar 2, 2023
1a3622e
Fix merge of rpc/client.go CallContext unmarshal
Tristan-Wilson Mar 2, 2023
1e33eb0
Fix refs to DefaultTriesInMemory
Tristan-Wilson Mar 3, 2023
f2975a0
Add Arbitrum specific APIs to backendMock
Tristan-Wilson Mar 3, 2023
3f45f11
More references to DefaultTriesInMemory
Tristan-Wilson Mar 3, 2023
6484970
add gasUsedForL1 to expected output for T8n tests
Tristan-Wilson Mar 3, 2023
1193877
Fix CallContext merge attempt 2
Tristan-Wilson Mar 3, 2023
94f91bc
Make console test know about git version
Tristan-Wilson Mar 3, 2023
d62d1b4
Revert "Merge remote-tracking branch 'origin/master' into ws_jwt_client"
Tristan-Wilson Mar 30, 2023
24d6a56
Merge branch 'revert-offchain-jwt' into merge-v1.11.2
Tristan-Wilson Mar 30, 2023
06b5ef6
Use flushInterval instead of TrieTimeLimit
Tristan-Wilson Mar 30, 2023
d6ee418
Rename root to triegcEntry
Tristan-Wilson Apr 4, 2023
b8f10c7
Fix moved DiskDB TODO
Tristan-Wilson Apr 4, 2023
a1cc048
Merge remote-tracking branch 'origin/master' into merge-v1.11.2
Tristan-Wilson Apr 18, 2023
503ffe6
Fix handling of statedb.StorageTrie returning err
Tristan-Wilson Apr 18, 2023
ac74403
Add IsArbitrum special case to NewBlockChain
Tristan-Wilson May 1, 2023
e272e4e
Merge remote-tracking branch 'origin/master' into merge-v1.11.2
Tristan-Wilson May 2, 2023
c2794dd
Update core.NewBlockChain call sites in tests
Tristan-Wilson May 2, 2023
558c5fe
Move parens
Tristan-Wilson May 8, 2023
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
19 changes: 13 additions & 6 deletions arbitrum/apibackend.go
Original file line number Diff line number Diff line change
Expand Up @@ -137,6 +137,13 @@ func (a *APIBackend) GetArbitrumNode() interface{} {
return a.b.arb.ArbNode()
}

func (a *APIBackend) GetBody(ctx context.Context, hash common.Hash, number rpc.BlockNumber) (*types.Body, error) {
if body := a.blockChain().GetBody(hash); body != nil {
return body, nil
}
return nil, errors.New("block body not found")
}

// General Ethereum API
func (a *APIBackend) SyncProgressMap() map[string]interface{} {
return a.sync.SyncProgressMap()
Expand Down Expand Up @@ -419,20 +426,20 @@ func (a *APIBackend) StateAndHeaderByNumberOrHash(ctx context.Context, blockNrOr
return a.stateAndHeaderFromHeader(a.HeaderByNumberOrHash(ctx, blockNrOrHash))
}

func (a *APIBackend) StateAtBlock(ctx context.Context, block *types.Block, reexec uint64, base *state.StateDB, checkLive bool, preferDisk bool) (statedb *state.StateDB, err error) {
func (a *APIBackend) StateAtBlock(ctx context.Context, block *types.Block, reexec uint64, base *state.StateDB, checkLive bool, preferDisk bool) (statedb *state.StateDB, release tracers.StateReleaseFunc, err error) {
if !a.blockChain().Config().IsArbitrumNitro(block.Number()) {
return nil, types.ErrUseFallback
return nil, nil, types.ErrUseFallback
}
// DEV: This assumes that `StateAtBlock` only accesses the blockchain and chainDb fields
return eth.NewArbEthereum(a.b.arb.BlockChain(), a.ChainDb()).StateAtBlock(block, reexec, base, checkLive, preferDisk)
return eth.NewArbEthereum(a.b.arb.BlockChain(), a.ChainDb()).StateAtBlock(ctx, block, reexec, base, checkLive, preferDisk)
}

func (a *APIBackend) StateAtTransaction(ctx context.Context, block *types.Block, txIndex int, reexec uint64) (core.Message, vm.BlockContext, *state.StateDB, error) {
func (a *APIBackend) StateAtTransaction(ctx context.Context, block *types.Block, txIndex int, reexec uint64) (core.Message, vm.BlockContext, *state.StateDB, tracers.StateReleaseFunc, error) {
if !a.blockChain().Config().IsArbitrumNitro(block.Number()) {
return nil, vm.BlockContext{}, nil, types.ErrUseFallback
return nil, vm.BlockContext{}, nil, nil, types.ErrUseFallback
}
// DEV: This assumes that `StateAtTransaction` only accesses the blockchain and chainDb fields
return eth.NewArbEthereum(a.b.arb.BlockChain(), a.ChainDb()).StateAtTransaction(block, txIndex, reexec)
return eth.NewArbEthereum(a.b.arb.BlockChain(), a.ChainDb()).StateAtTransaction(ctx, block, txIndex, reexec)
}

func (a *APIBackend) GetReceipts(ctx context.Context, hash common.Hash) (types.Receipts, error) {
Expand Down
2 changes: 1 addition & 1 deletion arbitrum/recordingdb.go
Original file line number Diff line number Diff line change
Expand Up @@ -187,7 +187,7 @@ func (r *RecordingDatabase) Dereference(header *types.Header) {

func (r *RecordingDatabase) WriteStateToDatabase(header *types.Header) error {
if header != nil {
return r.db.TrieDB().Commit(header.Root, true, nil)
return r.db.TrieDB().Commit(header.Root, true)
}
return nil
}
Expand Down
1 change: 1 addition & 0 deletions cmd/evm/testdata/1/exp.json
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@
"logsBloom": "0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000",
"receipts": [
{
"gasUsedForL1": "0x0",
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

instead of all of those - maybe we could just add omitempty to receipt's Un/MarshalJson?

		GasUsedForL1      hexutil.Uint64 `json:"gasUsedForL1"`

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Hmm.. people might be expecting this from our RPC even for L1->L2 txs unfortunately

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Ok, will leave it as-is

"root": "0x",
"status": "0x1",
"cumulativeGasUsed": "0x5208",
Expand Down
2 changes: 2 additions & 0 deletions cmd/evm/testdata/13/exp2.json
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@
"logsBloom": "0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000",
"receipts": [
{
"gasUsedForL1": "0x0",
"type": "0x2",
"root": "0x",
"status": "0x0",
Expand All @@ -20,6 +21,7 @@
"transactionIndex": "0x0"
},
{
"gasUsedForL1": "0x0",
"type": "0x2",
"root": "0x",
"status": "0x0",
Expand Down
1 change: 1 addition & 0 deletions cmd/evm/testdata/23/exp.json
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@
"logsBloom": "0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000",
"receipts": [
{
"gasUsedForL1": "0x0",
"root": "0x",
"status": "0x1",
"cumulativeGasUsed": "0x520b",
Expand Down
2 changes: 2 additions & 0 deletions cmd/evm/testdata/24/exp.json
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@
"logsBloom": "0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000",
"receipts": [
{
"gasUsedForL1": "0x0",
"root": "0x",
"status": "0x1",
"cumulativeGasUsed": "0xa861",
Expand All @@ -35,6 +36,7 @@
"transactionIndex": "0x0"
},
{
"gasUsedForL1": "0x0",
"root": "0x",
"status": "0x1",
"cumulativeGasUsed": "0x10306",
Expand Down
1 change: 1 addition & 0 deletions cmd/evm/testdata/25/exp.json
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@
"logsBloom": "0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000",
"receipts": [
{
"gasUsedForL1": "0x0",
"root": "0x",
"status": "0x1",
"cumulativeGasUsed": "0x5208",
Expand Down
1 change: 1 addition & 0 deletions cmd/evm/testdata/3/exp.json
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@
"logsBloom": "0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000",
"receipts": [
{
"gasUsedForL1": "0x0",
"root": "0x",
"status": "0x1",
"cumulativeGasUsed": "0x521f",
Expand Down
7 changes: 5 additions & 2 deletions cmd/geth/consolecmd_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@ import (
"testing"
"time"

"github.com/ethereum/go-ethereum/internal/version"
"github.com/ethereum/go-ethereum/params"
)

Expand Down Expand Up @@ -59,7 +60,8 @@ func TestConsoleWelcome(t *testing.T) {
geth.SetTemplateFunc("goos", func() string { return runtime.GOOS })
geth.SetTemplateFunc("goarch", func() string { return runtime.GOARCH })
geth.SetTemplateFunc("gover", runtime.Version)
geth.SetTemplateFunc("gethver", func() string { return params.VersionWithCommit("", "") })
git, _ := version.VCS()
geth.SetTemplateFunc("gethver", func() string { return params.VersionWithCommit(git.Commit, "") })
geth.SetTemplateFunc("niltime", func() string {
return time.Unix(1548854791, 0).Format("Mon Jan 02 2006 15:04:05 GMT-0700 (MST)")
})
Expand Down Expand Up @@ -129,7 +131,8 @@ func testAttachWelcome(t *testing.T, geth *testgeth, endpoint, apis string) {
attach.SetTemplateFunc("goos", func() string { return runtime.GOOS })
attach.SetTemplateFunc("goarch", func() string { return runtime.GOARCH })
attach.SetTemplateFunc("gover", runtime.Version)
attach.SetTemplateFunc("gethver", func() string { return params.VersionWithCommit("", "") })
git, _ := version.VCS()
attach.SetTemplateFunc("gethver", func() string { return params.VersionWithCommit(git.Commit, "") })
attach.SetTemplateFunc("etherbase", func() string { return geth.Etherbase })
attach.SetTemplateFunc("niltime", func() string {
return time.Unix(1548854791, 0).Format("Mon Jan 02 2006 15:04:05 GMT-0700 (MST)")
Expand Down
26 changes: 13 additions & 13 deletions core/blockchain.go
Original file line number Diff line number Diff line change
Expand Up @@ -1409,7 +1409,7 @@ func (bc *BlockChain) writeBlockWithState(block *types.Block, receipts []*types.
}

// Full but not archive node, do proper garbage collection
triedb.Reference(root, common.Hash{}) // metadata reference to keep trie alive
bc.triedb.Reference(root, common.Hash{}) // metadata reference to keep trie alive
bc.triegc.Push(trieGcEntry{root, block.Header().Time}, -int64(block.NumberU64()))

blockLimit := int64(block.NumberU64()) - int64(bc.cacheConfig.TriesInMemory) // only cleared if below that
Expand All @@ -1418,28 +1418,28 @@ func (bc *BlockChain) writeBlockWithState(block *types.Block, receipts []*types.
if blockLimit > 0 && timeLimit > 0 {
// If we exceeded our memory allowance, flush matured singleton nodes to disk
var (
nodes, imgs = triedb.Size()
nodes, imgs = bc.triedb.Size()
limit = common.StorageSize(bc.cacheConfig.TrieDirtyLimit) * 1024 * 1024
)
if nodes > limit || imgs > 4*1024*1024 {
triedb.Cap(limit - ethdb.IdealBatchSize)
bc.triedb.Cap(limit - ethdb.IdealBatchSize)
}
var prevEntry *trieGcEntry
var prevNum uint64
// Garbage collect anything below our required write retention
for !bc.triegc.Empty() {
tmp, number := bc.triegc.Pop()
triegcEntry := tmp.(trieGcEntry)
if uint64(-number) > uint64(blockLimit) || triegcEntry.Timestamp > uint64(timeLimit) {
bc.triegc.Push(triegcEntry, number)
root, number := bc.triegc.Pop()
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

our variable (unlike mainline) is not a root, but a triegc entry that has both root and timestamp.. rename "root" to triegcEntry, or something similar..

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Done

if uint64(-number) > uint64(blockLimit) || root.Timestamp > uint64(timeLimit) {
bc.triegc.Push(root, number)
break
}
if prevEntry != nil {
triedb.Dereference(prevEntry.Root)
bc.triedb.Dereference(prevEntry.Root)
}
prevEntry = &triegcEntry
prevEntry = &root
prevNum = uint64(-number)
}
flushInterval := time.Duration(atomic.LoadInt64(&bc.flushInterval))
// If we exceeded out time allowance, flush an entire trie to disk
if bc.gcproc > bc.cacheConfig.TrieTimeLimit && prevEntry != nil {
Copy link
Collaborator

@tsahee tsahee Mar 26, 2023

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

this should be if gcproc > flushInterval

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Alright, changed it. I think they should be the same value anyway because flushInterval is set with TrieTimeLimit in NewBlockChain.

// If the header is missing (canonical chain behind), we're reorging a low
Expand All @@ -1450,17 +1450,17 @@ func (bc *BlockChain) writeBlockWithState(block *types.Block, receipts []*types.
} else {
// If we're exceeding limits but haven't reached a large enough memory gap,
// warn the user that the system is becoming unstable.
if chosen < bc.lastWrite+bc.cacheConfig.TriesInMemory && bc.gcproc >= 2*flushInterval {
log.Info("State in memory for too long, committing", "time", bc.gcproc, "allowance", flushInterval, "optimum", float64(prevNum-bc.lastWrite)/bc.cacheConfig.TriesInMemory)
if blockLimit < int64(bc.lastWrite+bc.cacheConfig.TriesInMemory) && bc.gcproc >= 2*flushInterval {
log.Info("State in memory for too long, committing", "time", bc.gcproc, "allowance", flushInterval, "optimum", float64(prevNum-bc.lastWrite)/float64(bc.cacheConfig.TriesInMemory))
}
// Flush an entire trie and restart the counters
triedb.Commit(header.Root, true, nil)
bc.triedb.Commit(header.Root, true)
bc.lastWrite = prevNum
bc.gcproc = 0
}
}
if prevEntry != nil {
triedb.Dereference(prevEntry.Root)
bc.triedb.Dereference(prevEntry.Root)
}
}
return nil
Expand Down
36 changes: 18 additions & 18 deletions core/blockchain_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -1669,7 +1669,7 @@ func TestTrieForkGC(t *testing.T) {
Config: params.TestChainConfig,
BaseFee: big.NewInt(params.InitialBaseFee),
}
genDb, blocks, _ := GenerateChainWithGenesis(genesis, engine, 2*TriesInMemory, func(i int, b *BlockGen) { b.SetCoinbase(common.Address{1}) })
genDb, blocks, _ := GenerateChainWithGenesis(genesis, engine, 2*DefaultTriesInMemory, func(i int, b *BlockGen) { b.SetCoinbase(common.Address{1}) })

// Generate a bunch of fork blocks, each side forking from the canonical chain
forks := make([]*types.Block, len(blocks))
Expand Down Expand Up @@ -1697,7 +1697,7 @@ func TestTrieForkGC(t *testing.T) {
}
}
// Dereference all the recent tries and ensure no past trie is left in
for i := 0; i < TriesInMemory; i++ {
for i := 0; i < DefaultTriesInMemory; i++ {
chain.stateCache.TrieDB().Dereference(blocks[len(blocks)-1-i].Root())
chain.stateCache.TrieDB().Dereference(forks[len(blocks)-1-i].Root())
}
Expand All @@ -1716,8 +1716,8 @@ func TestLargeReorgTrieGC(t *testing.T) {
BaseFee: big.NewInt(params.InitialBaseFee),
}
genDb, shared, _ := GenerateChainWithGenesis(genesis, engine, 64, func(i int, b *BlockGen) { b.SetCoinbase(common.Address{1}) })
original, _ := GenerateChain(genesis.Config, shared[len(shared)-1], engine, genDb, 2*TriesInMemory, func(i int, b *BlockGen) { b.SetCoinbase(common.Address{2}) })
competitor, _ := GenerateChain(genesis.Config, shared[len(shared)-1], engine, genDb, 2*TriesInMemory+1, func(i int, b *BlockGen) { b.SetCoinbase(common.Address{3}) })
original, _ := GenerateChain(genesis.Config, shared[len(shared)-1], engine, genDb, 2*DefaultTriesInMemory, func(i int, b *BlockGen) { b.SetCoinbase(common.Address{2}) })
competitor, _ := GenerateChain(genesis.Config, shared[len(shared)-1], engine, genDb, 2*DefaultTriesInMemory+1, func(i int, b *BlockGen) { b.SetCoinbase(common.Address{3}) })

// Import the shared chain and the original canonical one
chain, err := NewBlockChain(rawdb.NewMemoryDatabase(), nil, genesis, nil, engine, vm.Config{}, nil, nil)
Expand Down Expand Up @@ -1751,7 +1751,7 @@ func TestLargeReorgTrieGC(t *testing.T) {
if _, err := chain.InsertChain(competitor[len(competitor)-2:]); err != nil {
t.Fatalf("failed to finalize competitor chain: %v", err)
}
for i, block := range competitor[:len(competitor)-TriesInMemory] {
for i, block := range competitor[:len(competitor)-DefaultTriesInMemory] {
if node, _ := chain.stateCache.TrieDB().Node(block.Root()); node != nil {
t.Fatalf("competitor %d: competing chain state missing", i)
}
Expand Down Expand Up @@ -1895,7 +1895,7 @@ func TestLowDiffLongChain(t *testing.T) {
}
// We must use a pretty long chain to ensure that the fork doesn't overtake us
// until after at least 128 blocks post tip
genDb, blocks, _ := GenerateChainWithGenesis(genesis, engine, 6*TriesInMemory, func(i int, b *BlockGen) {
genDb, blocks, _ := GenerateChainWithGenesis(genesis, engine, 6*DefaultTriesInMemory, func(i int, b *BlockGen) {
b.SetCoinbase(common.Address{1})
b.OffsetTime(-9)
})
Expand All @@ -1912,7 +1912,7 @@ func TestLowDiffLongChain(t *testing.T) {
}
// Generate fork chain, starting from an early block
parent := blocks[10]
fork, _ := GenerateChain(genesis.Config, parent, engine, genDb, 8*TriesInMemory, func(i int, b *BlockGen) {
fork, _ := GenerateChain(genesis.Config, parent, engine, genDb, 8*DefaultTriesInMemory, func(i int, b *BlockGen) {
b.SetCoinbase(common.Address{2})
})

Expand Down Expand Up @@ -1978,7 +1978,7 @@ func testSideImport(t *testing.T, numCanonBlocksInSidechain, blocksBetweenCommon
// Set the terminal total difficulty in the config
gspec.Config.TerminalTotalDifficulty = big.NewInt(0)
}
genDb, blocks, _ := GenerateChainWithGenesis(gspec, engine, 2*TriesInMemory, func(i int, gen *BlockGen) {
genDb, blocks, _ := GenerateChainWithGenesis(gspec, engine, 2*DefaultTriesInMemory, func(i int, gen *BlockGen) {
tx, err := types.SignTx(types.NewTransaction(nonce, common.HexToAddress("deadbeef"), big.NewInt(100), 21000, big.NewInt(int64(i+1)*params.GWei), nil), signer, key)
if err != nil {
t.Fatalf("failed to create tx: %v", err)
Expand All @@ -1993,9 +1993,9 @@ func testSideImport(t *testing.T, numCanonBlocksInSidechain, blocksBetweenCommon
t.Fatalf("block %d: failed to insert into chain: %v", n, err)
}

lastPrunedIndex := len(blocks) - TriesInMemory - 1
lastPrunedIndex := len(blocks) - DefaultTriesInMemory - 1
lastPrunedBlock := blocks[lastPrunedIndex]
firstNonPrunedBlock := blocks[len(blocks)-TriesInMemory]
firstNonPrunedBlock := blocks[len(blocks)-DefaultTriesInMemory]

// Verify pruning of lastPrunedBlock
if chain.HasBlockAndState(lastPrunedBlock.Hash(), lastPrunedBlock.NumberU64()) {
Expand Down Expand Up @@ -2024,7 +2024,7 @@ func testSideImport(t *testing.T, numCanonBlocksInSidechain, blocksBetweenCommon
// Generate fork chain, make it longer than canon
parentIndex := lastPrunedIndex + blocksBetweenCommonAncestorAndPruneblock
parent := blocks[parentIndex]
fork, _ := GenerateChain(gspec.Config, parent, engine, genDb, 2*TriesInMemory, func(i int, b *BlockGen) {
fork, _ := GenerateChain(gspec.Config, parent, engine, genDb, 2*DefaultTriesInMemory, func(i int, b *BlockGen) {
b.SetCoinbase(common.Address{2})
if int(b.header.Number.Uint64()) >= mergeBlock {
b.SetPoS()
Expand Down Expand Up @@ -2822,7 +2822,7 @@ func TestSideImportPrunedBlocks(t *testing.T) {
BaseFee: big.NewInt(params.InitialBaseFee),
}
// Generate and import the canonical chain
_, blocks, _ := GenerateChainWithGenesis(genesis, engine, 2*TriesInMemory, nil)
_, blocks, _ := GenerateChainWithGenesis(genesis, engine, 2*DefaultTriesInMemory, nil)

chain, err := NewBlockChain(rawdb.NewMemoryDatabase(), nil, genesis, nil, engine, vm.Config{}, nil, nil)
if err != nil {
Expand All @@ -2834,14 +2834,14 @@ func TestSideImportPrunedBlocks(t *testing.T) {
t.Fatalf("block %d: failed to insert into chain: %v", n, err)
}

lastPrunedIndex := len(blocks) - TriesInMemory - 1
lastPrunedIndex := len(blocks) - DefaultTriesInMemory - 1
lastPrunedBlock := blocks[lastPrunedIndex]

// Verify pruning of lastPrunedBlock
if chain.HasBlockAndState(lastPrunedBlock.Hash(), lastPrunedBlock.NumberU64()) {
t.Errorf("Block %d not pruned", lastPrunedBlock.NumberU64())
}
firstNonPrunedBlock := blocks[len(blocks)-TriesInMemory]
firstNonPrunedBlock := blocks[len(blocks)-DefaultTriesInMemory]
// Verify firstNonPrunedBlock is not pruned
if !chain.HasBlockAndState(firstNonPrunedBlock.Hash(), firstNonPrunedBlock.NumberU64()) {
t.Errorf("Block %d pruned", firstNonPrunedBlock.NumberU64())
Expand Down Expand Up @@ -3672,7 +3672,7 @@ func TestSetCanonical(t *testing.T) {
engine = ethash.NewFaker()
)
// Generate and import the canonical chain
_, canon, _ := GenerateChainWithGenesis(gspec, engine, 2*TriesInMemory, func(i int, gen *BlockGen) {
_, canon, _ := GenerateChainWithGenesis(gspec, engine, 2*DefaultTriesInMemory, func(i int, gen *BlockGen) {
tx, err := types.SignTx(types.NewTransaction(gen.TxNonce(address), common.Address{0x00}, big.NewInt(1000), params.TxGas, gen.header.BaseFee, nil), signer, key)
if err != nil {
panic(err)
Expand All @@ -3690,7 +3690,7 @@ func TestSetCanonical(t *testing.T) {
}

// Generate the side chain and import them
_, side, _ := GenerateChainWithGenesis(gspec, engine, 2*TriesInMemory, func(i int, gen *BlockGen) {
_, side, _ := GenerateChainWithGenesis(gspec, engine, 2*DefaultTriesInMemory, func(i int, gen *BlockGen) {
tx, err := types.SignTx(types.NewTransaction(gen.TxNonce(address), common.Address{0x00}, big.NewInt(1), params.TxGas, gen.header.BaseFee, nil), signer, key)
if err != nil {
panic(err)
Expand Down Expand Up @@ -3729,8 +3729,8 @@ func TestSetCanonical(t *testing.T) {
verify(side[len(side)-1])

// Reset the chain head to original chain
chain.SetCanonical(canon[TriesInMemory-1])
verify(canon[TriesInMemory-1])
chain.SetCanonical(canon[DefaultTriesInMemory-1])
verify(canon[DefaultTriesInMemory-1])
}

// TestCanonicalHashMarker tests all the canonical hash markers are updated/deleted
Expand Down
1 change: 1 addition & 0 deletions core/rawdb/accessors_chain.go
Original file line number Diff line number Diff line change
Expand Up @@ -673,6 +673,7 @@ func DeleteReceipts(db ethdb.KeyValueWriter, hash common.Hash, number uint64) {
type storedReceiptRLP struct {
PostStateOrStatus []byte
CumulativeGasUsed uint64
L1GasUsed uint64 // Arbitrum specific
Logs []*types.Log
}

Expand Down
Loading