nimbus-eth1/tests/tracerTestGen.nim

80 lines
2.1 KiB
Nim
Raw Normal View History

2018-12-12 22:18:46 +07:00
import
2020-07-21 13:15:06 +07:00
json, eth/common, stint, chronicles,
2019-02-05 20:15:50 +01:00
eth/trie/db, ../nimbus/db/[db_chain, capturedb, select_backend],
2018-12-14 14:32:45 +07:00
../nimbus/[tracer, vm_types, config]
2018-12-12 22:18:46 +07:00
proc dumpTest(chainDB: BaseChainDB, blockNumber: int) =
2018-12-25 17:31:51 +07:00
let
blockNumber = blockNumber.u256
2018-12-12 22:18:46 +07:00
var
memoryDB = newMemoryDB()
captureDB = newCaptureDB(chainDB.db, memoryDB)
captureTrieDB = trieDB captureDB
captureChainDB = newBaseChainDB(captureTrieDB, false)
2018-12-25 17:31:51 +07:00
let
header = captureChainDB.getBlockHeader(blockNumber)
headerHash = header.blockHash
blockBody = captureChainDB.getBlockBody(headerHash)
txTrace = traceTransactions(captureChainDB, header, blockBody)
stateDump = dumpBlockState(captureChainDB, header, blockBody)
blockTrace = traceBlock(captureChainDB, header, blockBody, {DisableState})
receipts = dumpReceipts(captureChainDB, header)
2018-12-12 22:18:46 +07:00
2018-12-25 17:31:51 +07:00
var metaData = %{
"blockNumber": %blockNumber.toHex,
"txTraces": txTrace,
"stateDump": stateDump,
"blockTrace": blockTrace,
"receipts": receipts
}
2018-12-12 22:18:46 +07:00
2018-12-25 17:31:51 +07:00
metaData.dumpMemoryDB(memoryDB)
writeFile("block" & $blockNumber & ".json", metaData.pretty())
2018-12-12 22:18:46 +07:00
2020-07-21 13:15:06 +07:00
proc main() {.used.} =
2018-12-12 22:18:46 +07: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 = getConfiguration()
let db = newChainDb(conf.dataDir)
let trieDB = trieDB db
let chainDB = newBaseChainDB(trieDB, false)
chainDB.dumpTest(97)
chainDB.dumpTest(46147)
chainDB.dumpTest(46400)
chainDB.dumpTest(46402)
chainDB.dumpTest(47205)
chainDB.dumpTest(48712)
chainDB.dumpTest(48915)
2018-12-31 10:28:12 +07:00
chainDB.dumpTest(49018)
2018-12-12 22:18:46 +07:00
when isMainModule:
var message: string
## Processing command line arguments
if processArguments(message) != Success:
echo message
quit(QuitFailure)
else:
if len(message) > 0:
echo message
quit(QuitSuccess)
try:
main()
except:
echo getCurrentExceptionMsg()