2019-02-27 11:28:40 +00:00
|
|
|
import
|
2020-07-21 06:15:06 +00:00
|
|
|
eth/[common, rlp], stint,
|
|
|
|
chronicles, configuration,
|
|
|
|
eth/trie/[hexary, db]
|
2019-02-27 11:28:40 +00:00
|
|
|
|
|
|
|
import
|
2020-07-21 06:15:06 +00:00
|
|
|
../nimbus/db/[db_chain, select_backend],
|
2022-01-18 16:19:32 +00:00
|
|
|
../nimbus/[vm_state, vm_types],
|
2019-02-27 11:28:40 +00:00
|
|
|
../nimbus/p2p/executor
|
|
|
|
|
|
|
|
const
|
|
|
|
numBlocks = 256
|
|
|
|
|
|
|
|
proc validateBlock(chainDB: BaseChainDB, blockNumber: BlockNumber): BlockNumber =
|
|
|
|
var
|
|
|
|
parentNumber = blockNumber - 1
|
|
|
|
parent = chainDB.getBlockHeader(parentNumber)
|
|
|
|
headers = newSeq[BlockHeader](numBlocks)
|
|
|
|
bodies = newSeq[BlockBody](numBlocks)
|
2021-10-28 09:42:39 +00:00
|
|
|
lastBlockHash: Hash256
|
2019-02-27 11:28:40 +00:00
|
|
|
|
|
|
|
for i in 0 ..< numBlocks:
|
|
|
|
headers[i] = chainDB.getBlockHeader(blockNumber + i.u256)
|
|
|
|
bodies[i] = chainDB.getBlockBody(headers[i].blockHash)
|
|
|
|
|
|
|
|
let transaction = chainDB.db.beginTransaction()
|
|
|
|
defer: transaction.dispose()
|
|
|
|
|
|
|
|
for i in 0 ..< numBlocks:
|
|
|
|
stdout.write blockNumber + i.u256
|
|
|
|
stdout.write "\r"
|
|
|
|
|
|
|
|
let
|
2022-01-18 16:19:32 +00:00
|
|
|
vmState = BaseVMState.new(parent, headers[i], chainDB)
|
2021-07-30 14:06:51 +00:00
|
|
|
validationResult = vmState.processBlockNotPoA(headers[i], bodies[i])
|
2019-02-27 11:28:40 +00:00
|
|
|
|
|
|
|
if validationResult != ValidationResult.OK:
|
|
|
|
error "block validation error", validationResult, blockNumber = blockNumber + i.u256
|
|
|
|
|
|
|
|
parent = headers[i]
|
|
|
|
|
|
|
|
transaction.rollback()
|
|
|
|
result = blockNumber + numBlocks.u256
|
|
|
|
|
2020-07-21 06:15:06 +00:00
|
|
|
proc main() {.used.} =
|
2019-02-27 11:28:40 +00:00
|
|
|
let
|
|
|
|
conf = getConfiguration()
|
2022-04-08 04:54:11 +00:00
|
|
|
db = newChainDB(conf.dataDir)
|
2019-02-27 11:28:40 +00:00
|
|
|
trieDB = trieDB db
|
|
|
|
chainDB = newBaseChainDB(trieDB, false)
|
|
|
|
|
|
|
|
# move head to block number ...
|
|
|
|
if conf.head == 0.u256:
|
|
|
|
raise newException(ValueError, "please set block number with --head: blockNumber")
|
|
|
|
|
|
|
|
var counter = 0
|
|
|
|
var blockNumber = conf.head
|
|
|
|
|
|
|
|
while true:
|
|
|
|
blockNumber = chainDB.validateBlock(blockNumber)
|
|
|
|
|
|
|
|
inc counter
|
|
|
|
if conf.maxBlocks != 0 and counter >= conf.maxBlocks:
|
|
|
|
break
|
|
|
|
|
|
|
|
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()
|