nimbus-eth1/tests/persistBlockTestGen.nim

109 lines
3.6 KiB
Nim
Raw Normal View History

2018-12-25 12:10:04 +00:00
import
Unified database frontend integration (#1670) * Nimbus folder environment update details: * Integrated `CoreDbRef` for the sources in the `nimbus` sub-folder. * The `nimbus` program does not compile yet as it needs the updates in the parallel `stateless` sub-folder. * Stateless environment update details: * Integrated `CoreDbRef` for the sources in the `stateless` sub-folder. * The `nimbus` program compiles now. * Premix environment update details: * Integrated `CoreDbRef` for the sources in the `premix` sub-folder. * Fluffy environment update details: * Integrated `CoreDbRef` for the sources in the `fluffy` sub-folder. * Tools environment update details: * Integrated `CoreDbRef` for the sources in the `tools` sub-folder. * Nodocker environment update details: * Integrated `CoreDbRef` for the sources in the `hive_integration/nodocker` sub-folder. * Tests environment update details: * Integrated `CoreDbRef` for the sources in the `tests` sub-folder. * The unit tests compile and run cleanly now. * Generalise `CoreDbRef` to any `select_backend` supported database why: Generalisation was just missed due to overcoming some compiler oddity which was tied to rocksdb for testing. * Suppress compiler warning for `newChainDB()` why: Warning was added to this function which must be wrapped so that any `CatchableError` is re-raised as `Defect`. * Split off persistent `CoreDbRef` constructor into separate file why: This allows to compile a memory only database version without linking the backend library. * Use memory `CoreDbRef` database by default detail: Persistent DB constructor needs to import `db/core_db/persistent why: Most tests use memory DB anyway. This avoids linking `-lrocksdb` or any other backend by default. * fix `toLegacyBackend()` availability check why: got garbled after memory/persistent split. * Clarify raw access to MPT for snap sync handler why: Logically, `kvt` is not the raw access for the hexary trie (although this holds for the legacy database)
2023-08-04 11:10:09 +00:00
json, stint,
2020-07-21 06:15:06 +00:00
../nimbus/[tracer, config],
2022-12-02 04:39:12 +00:00
../nimbus/core/chain,
Unified database frontend integration (#1670) * Nimbus folder environment update details: * Integrated `CoreDbRef` for the sources in the `nimbus` sub-folder. * The `nimbus` program does not compile yet as it needs the updates in the parallel `stateless` sub-folder. * Stateless environment update details: * Integrated `CoreDbRef` for the sources in the `stateless` sub-folder. * The `nimbus` program compiles now. * Premix environment update details: * Integrated `CoreDbRef` for the sources in the `premix` sub-folder. * Fluffy environment update details: * Integrated `CoreDbRef` for the sources in the `fluffy` sub-folder. * Tools environment update details: * Integrated `CoreDbRef` for the sources in the `tools` sub-folder. * Nodocker environment update details: * Integrated `CoreDbRef` for the sources in the `hive_integration/nodocker` sub-folder. * Tests environment update details: * Integrated `CoreDbRef` for the sources in the `tests` sub-folder. * The unit tests compile and run cleanly now. * Generalise `CoreDbRef` to any `select_backend` supported database why: Generalisation was just missed due to overcoming some compiler oddity which was tied to rocksdb for testing. * Suppress compiler warning for `newChainDB()` why: Warning was added to this function which must be wrapped so that any `CatchableError` is re-raised as `Defect`. * Split off persistent `CoreDbRef` constructor into separate file why: This allows to compile a memory only database version without linking the backend library. * Use memory `CoreDbRef` database by default detail: Persistent DB constructor needs to import `db/core_db/persistent why: Most tests use memory DB anyway. This avoids linking `-lrocksdb` or any other backend by default. * fix `toLegacyBackend()` availability check why: got garbled after memory/persistent split. * Clarify raw access to MPT for snap sync handler why: Logically, `kvt` is not the raw access for the hexary trie (although this holds for the legacy database)
2023-08-04 11:10:09 +00:00
../nimbus/common/common,
../nimbus/db/core_db/persistent
2018-12-25 12:10:04 +00:00
2022-12-02 04:39:12 +00:00
proc dumpTest(com: CommonRef, blockNumber: int) =
2018-12-25 12:10:04 +00:00
let
blockNumber = blockNumber.u256
parentNumber = blockNumber - 1
var
Unified database frontend integration (#1670) * Nimbus folder environment update details: * Integrated `CoreDbRef` for the sources in the `nimbus` sub-folder. * The `nimbus` program does not compile yet as it needs the updates in the parallel `stateless` sub-folder. * Stateless environment update details: * Integrated `CoreDbRef` for the sources in the `stateless` sub-folder. * The `nimbus` program compiles now. * Premix environment update details: * Integrated `CoreDbRef` for the sources in the `premix` sub-folder. * Fluffy environment update details: * Integrated `CoreDbRef` for the sources in the `fluffy` sub-folder. * Tools environment update details: * Integrated `CoreDbRef` for the sources in the `tools` sub-folder. * Nodocker environment update details: * Integrated `CoreDbRef` for the sources in the `hive_integration/nodocker` sub-folder. * Tests environment update details: * Integrated `CoreDbRef` for the sources in the `tests` sub-folder. * The unit tests compile and run cleanly now. * Generalise `CoreDbRef` to any `select_backend` supported database why: Generalisation was just missed due to overcoming some compiler oddity which was tied to rocksdb for testing. * Suppress compiler warning for `newChainDB()` why: Warning was added to this function which must be wrapped so that any `CatchableError` is re-raised as `Defect`. * Split off persistent `CoreDbRef` constructor into separate file why: This allows to compile a memory only database version without linking the backend library. * Use memory `CoreDbRef` database by default detail: Persistent DB constructor needs to import `db/core_db/persistent why: Most tests use memory DB anyway. This avoids linking `-lrocksdb` or any other backend by default. * fix `toLegacyBackend()` availability check why: got garbled after memory/persistent split. * Clarify raw access to MPT for snap sync handler why: Logically, `kvt` is not the raw access for the hexary trie (although this holds for the legacy database)
2023-08-04 11:10:09 +00:00
capture = com.db.capture()
captureCom = com.clone(capture.recorder)
2018-12-25 12:10:04 +00:00
let
2022-12-02 04:39:12 +00:00
parent = captureCom.db.getBlockHeader(parentNumber)
header = captureCom.db.getBlockHeader(blockNumber)
2018-12-25 12:10:04 +00:00
headerHash = header.blockHash
2022-12-02 04:39:12 +00:00
blockBody = captureCom.db.getBlockBody(headerHash)
chain = newChain(captureCom)
2018-12-25 12:10:04 +00:00
headers = @[header]
bodies = @[blockBody]
2022-12-02 04:39:12 +00:00
discard captureCom.db.setHead(parent, true)
2018-12-25 12:10:04 +00:00
discard chain.persistBlocks(headers, bodies)
var metaData = %{
"blockNumber": %blockNumber.toHex
}
Unified database frontend integration (#1670) * Nimbus folder environment update details: * Integrated `CoreDbRef` for the sources in the `nimbus` sub-folder. * The `nimbus` program does not compile yet as it needs the updates in the parallel `stateless` sub-folder. * Stateless environment update details: * Integrated `CoreDbRef` for the sources in the `stateless` sub-folder. * The `nimbus` program compiles now. * Premix environment update details: * Integrated `CoreDbRef` for the sources in the `premix` sub-folder. * Fluffy environment update details: * Integrated `CoreDbRef` for the sources in the `fluffy` sub-folder. * Tools environment update details: * Integrated `CoreDbRef` for the sources in the `tools` sub-folder. * Nodocker environment update details: * Integrated `CoreDbRef` for the sources in the `hive_integration/nodocker` sub-folder. * Tests environment update details: * Integrated `CoreDbRef` for the sources in the `tests` sub-folder. * The unit tests compile and run cleanly now. * Generalise `CoreDbRef` to any `select_backend` supported database why: Generalisation was just missed due to overcoming some compiler oddity which was tied to rocksdb for testing. * Suppress compiler warning for `newChainDB()` why: Warning was added to this function which must be wrapped so that any `CatchableError` is re-raised as `Defect`. * Split off persistent `CoreDbRef` constructor into separate file why: This allows to compile a memory only database version without linking the backend library. * Use memory `CoreDbRef` database by default detail: Persistent DB constructor needs to import `db/core_db/persistent why: Most tests use memory DB anyway. This avoids linking `-lrocksdb` or any other backend by default. * fix `toLegacyBackend()` availability check why: got garbled after memory/persistent split. * Clarify raw access to MPT for snap sync handler why: Logically, `kvt` is not the raw access for the hexary trie (although this holds for the legacy database)
2023-08-04 11:10:09 +00:00
metaData.dumpMemoryDB(capture)
2018-12-25 12:10:04 +00:00
writeFile("block" & $blockNumber & ".json", metaData.pretty())
2020-07-21 06:15:06 +00:00
proc main() {.used.} =
2018-12-25 12:10:04 +00:00
# 97 block with uncles
# 46147 block with first transaction
# 46400 block with transaction
# 46402 block with first contract: failed
# 47205 block with first success contract
# 48712 block with 5 transactions
# 48915 block with contract
# 49018 first problematic block
# 52029 first block with receipts logs
# 66407 failed transaction
# nimbus --rpcapi: eth, debug --prune: archive
var conf = makeConfig()
Unified database frontend integration (#1670) * Nimbus folder environment update details: * Integrated `CoreDbRef` for the sources in the `nimbus` sub-folder. * The `nimbus` program does not compile yet as it needs the updates in the parallel `stateless` sub-folder. * Stateless environment update details: * Integrated `CoreDbRef` for the sources in the `stateless` sub-folder. * The `nimbus` program compiles now. * Premix environment update details: * Integrated `CoreDbRef` for the sources in the `premix` sub-folder. * Fluffy environment update details: * Integrated `CoreDbRef` for the sources in the `fluffy` sub-folder. * Tools environment update details: * Integrated `CoreDbRef` for the sources in the `tools` sub-folder. * Nodocker environment update details: * Integrated `CoreDbRef` for the sources in the `hive_integration/nodocker` sub-folder. * Tests environment update details: * Integrated `CoreDbRef` for the sources in the `tests` sub-folder. * The unit tests compile and run cleanly now. * Generalise `CoreDbRef` to any `select_backend` supported database why: Generalisation was just missed due to overcoming some compiler oddity which was tied to rocksdb for testing. * Suppress compiler warning for `newChainDB()` why: Warning was added to this function which must be wrapped so that any `CatchableError` is re-raised as `Defect`. * Split off persistent `CoreDbRef` constructor into separate file why: This allows to compile a memory only database version without linking the backend library. * Use memory `CoreDbRef` database by default detail: Persistent DB constructor needs to import `db/core_db/persistent why: Most tests use memory DB anyway. This avoids linking `-lrocksdb` or any other backend by default. * fix `toLegacyBackend()` availability check why: got garbled after memory/persistent split. * Clarify raw access to MPT for snap sync handler why: Logically, `kvt` is not the raw access for the hexary trie (although this holds for the legacy database)
2023-08-04 11:10:09 +00:00
let db = newCoreDbRef(LegacyDbPersistent, string conf.dataDir)
let com = CommonRef.new(db, false)
2018-12-25 12:10:04 +00:00
2022-12-02 04:39:12 +00:00
com.dumpTest(97)
com.dumpTest(98) # no uncles and no tx
com.dumpTest(46147)
com.dumpTest(46400)
com.dumpTest(46402)
com.dumpTest(47205)
com.dumpTest(48712)
com.dumpTest(48915)
com.dumpTest(49018)
com.dumpTest(49439) # call opcode bug
com.dumpTest(49891) # number opcode bug
com.dumpTest(50111) # apply message bug
com.dumpTest(78458 )
com.dumpTest(81383 ) # tracer gas cost, stop opcode
com.dumpTest(81666 ) # create opcode
com.dumpTest(85858 ) # call oog
com.dumpTest(116524) # codecall address
com.dumpTest(146675) # precompiled contracts ecRecover
com.dumpTest(196647) # not enough gas to call
com.dumpTest(226147) # create return gas
com.dumpTest(226522) # return
com.dumpTest(231501) # selfdestruct
com.dumpTest(243826) # create contract self destruct
com.dumpTest(248032) # signextend over/undeflow
com.dumpTest(299804) # GasInt overflow
com.dumpTest(420301) # computation gas cost LTE(<=) 0 to LT(<) 0
com.dumpTest(512335) # create apply message
com.dumpTest(47216) # regression
com.dumpTest(652148) # contract transfer bug
com.dumpTest(668910) # uncleared logs bug
com.dumpTest(1_017_395) # sha256 and ripemd precompiles wordcount bug
com.dumpTest(1_149_150) # need to swallow precompiles errors
com.dumpTest(1_155_095) # homestead codeCost OOG
com.dumpTest(1_317_742) # CREATE childmsg sender
com.dumpTest(1_352_922) # first ecrecover precompile with 0x0 input
com.dumpTest(1_368_834) # writepadded regression padding len
com.dumpTest(1_417_555) # writepadded regression zero len
com.dumpTest(1_431_916) # deep recursion stack overflow problem
com.dumpTest(1_487_668) # getScore uint64 vs uint256 overflow
com.dumpTest(1_920_000) # the DAO fork
com.dumpTest(1_927_662) # fork comparison bug in postExecuteVM
2018-12-25 12:10:04 +00:00
2019-04-15 04:17:24 +00:00
# too big and too slow, we can skip it
# because it already covered by GST
#chainDB.dumpTest(2_283_416) # first DDOS spam attack block
2022-12-02 04:39:12 +00:00
com.dumpTest(2_463_413) # tangerine call* gas cost bug
com.dumpTest(2_675_000) # spurious dragon first block
com.dumpTest(2_675_002) # EIP155 tx.getSender
com.dumpTest(4_370_000) # Byzantium first block
2019-04-15 04:17:24 +00:00
when isMainModule:
try:
main()
except:
echo getCurrentExceptionMsg()