Jordan/ttd debugging helpers (#1013)

* De-noisify some Clique logging

why:
  Too annoying when syncing against Goerly

* Replay devnet# and kiln sessions

why:
  Compiled as local program, the unit test was used for TDD.
This commit is contained in:
Jordan Hrycaj 2022-03-28 09:35:26 +01:00 committed by GitHub
parent 97c0cea767
commit a64da329e8
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 45 additions and 19 deletions

View File

@ -180,7 +180,7 @@ proc findSnapshot(d: var LocalSnaps): bool
# why there should be any, though) # why there should be any, though)
d.trail.snaps = rc.value.cloneSnapshot d.trail.snaps = rc.value.cloneSnapshot
# d.say "findSnapshot cached ", d.trail.pp # d.say "findSnapshot cached ", d.trail.pp
debug "Found recently cached voting snapshot", trace "Found recently cached voting snapshot",
blockNumber = number, blockNumber = number,
blockHash = hash blockHash = hash
return true return true

View File

@ -191,7 +191,7 @@ proc snapshotApplySeq*(s: Snapshot; headers: var seq[BlockHeader],
# If we're taking too much time (ecrecover), notify the user once a while # If we're taking too much time (ecrecover), notify the user once a while
if s.cfg.logInterval < getTime() - logged: if s.cfg.logInterval < getTime() - logged:
info "Reconstructing voting history", debug "Reconstructing voting history",
processed = headersIndex, processed = headersIndex,
total = headers.len, total = headers.len,
elapsed = getTime() - start elapsed = getTime() - start
@ -199,7 +199,7 @@ proc snapshotApplySeq*(s: Snapshot; headers: var seq[BlockHeader],
let sinceStart = getTime() - start let sinceStart = getTime() - start
if s.cfg.logInterval < sinceStart: if s.cfg.logInterval < sinceStart:
info "Reconstructed voting history", debug "Reconstructed voting history",
processed = headers.len, processed = headers.len,
elapsed = sinceStart elapsed = sinceStart

View File

@ -148,6 +148,11 @@ iterator undumpNextGroup*(gzFile: string): (seq[BlockHeader],seq[BlockBody]) =
echo &"*** Ignoring line({lno}): {line}." echo &"*** Ignoring line({lno}): {line}."
waitFor = "transaction" waitFor = "transaction"
iterator undumpNextGroup*(gzs: seq[string]): (seq[BlockHeader],seq[BlockBody])=
for f in gzs:
for w in f.undumpNextGroup:
yield w
# ------------------------------------------------------------------------------ # ------------------------------------------------------------------------------
# End # End
# ------------------------------------------------------------------------------ # ------------------------------------------------------------------------------

View File

@ -8,7 +8,10 @@
# at your option. This file may not be copied, modified, or distributed except # at your option. This file may not be copied, modified, or distributed except
# according to those terms. # according to those terms.
## This unit test was roughly inspired by repeated failings of running nimbus ## This test has two different parts:
##
## :CI:
## This was roughly inspired by repeated failings of running nimbus
## similar to ## similar to
## :: ## ::
## nimbus \ ## nimbus \
@ -18,6 +21,11 @@
## --prune-mode:full ... ## --prune-mode:full ...
## ##
## from `issue 932` <https://github.com/status-im/nimbus-eth1/issues/932>`_. ## from `issue 932` <https://github.com/status-im/nimbus-eth1/issues/932>`_.
##
## :TDD (invoked as local executable):
## Test driven develomment to prepare for The Merge using real data, in
## particular studying TTD.
##
import import
std/[distros, os], std/[distros, os],
@ -36,7 +44,8 @@ type
fancyName: string # display name fancyName: string # display name
genesisFile: string # json file base name genesisFile: string # json file base name
termTotalDff: UInt256 # terminal total difficulty (to verify) termTotalDff: UInt256 # terminal total difficulty (to verify)
captureFile: string # gzipped RPL data dump mergeFork: uint64 # block number, merge fork (to verify)
captures: seq[string] # list of gzipped RPL data dumps
ttdReachedAt: uint64 # block number where total difficulty becomes `true` ttdReachedAt: uint64 # block number where total difficulty becomes `true`
failBlockAt: uint64 # stop here and expect that block to fail failBlockAt: uint64 # stop here and expect that block to fail
@ -49,8 +58,9 @@ const
devnet4 = ReplaySession( devnet4 = ReplaySession(
fancyName: "Devnet4", fancyName: "Devnet4",
genesisFile: "devnet4.json", genesisFile: "devnet4.json",
captureFile: "devnetfour5664.txt.gz", captures: @["devnetfour5664.txt.gz"],
termTotalDff: 5_000_000_000.u256, termTotalDff: 5_000_000_000.u256,
mergeFork: 100,
ttdReachedAt: 5645, ttdReachedAt: 5645,
# Previously failed at `ttdReachedAt` (needed `state.nim` fix/update) # Previously failed at `ttdReachedAt` (needed `state.nim` fix/update)
failBlockAt: 99999999) failBlockAt: 99999999)
@ -58,17 +68,24 @@ const
devnet5 = ReplaySession( devnet5 = ReplaySession(
fancyName: "Devnet5", fancyName: "Devnet5",
genesisFile: "devnet5.json", genesisFile: "devnet5.json",
captureFile: "devnetfive43968.txt.gz", captures: @["devnetfive43968.txt.gz"],
termTotalDff: 500_000_000_000.u256, termTotalDff: 500_000_000_000.u256,
mergeFork: 1000,
ttdReachedAt: 43711, ttdReachedAt: 43711,
failBlockAt: 99999999) failBlockAt: 99999999)
kiln = ReplaySession( kiln = ReplaySession(
fancyName: "Kiln", fancyName: "Kiln",
genesisFile: "kiln.json", genesisFile: "kiln.json",
captureFile: "kiln25872.txt.gz", captures: @[
"kiln048000.txt.gz",
"kiln048001-55296.txt.gz",
# "kiln055297-109056.txt.gz",
# "kiln109057-119837.txt.gz",
],
termTotalDff: 20_000_000_000_000.u256, termTotalDff: 20_000_000_000_000.u256,
ttdReachedAt: 9999999, mergeFork: 1000,
ttdReachedAt: 55127,
failBlockAt: 9999999) failBlockAt: 9999999)
when not defined(linux): when not defined(linux):
@ -217,6 +234,8 @@ proc genesisLoadRunner(noisy = true;
params = params) params = params)
check mdb.ttd == sSpcs.termTotalDff check mdb.ttd == sSpcs.termTotalDff
check mdb.config.mergeForkBlock.isSome
check mdb.config.mergeForkBlock.get == sSpcs.mergeFork.u256
test &"Construct persistent BaseChainDB on {tmpDir}, {persistPruneInfo}": test &"Construct persistent BaseChainDB on {tmpDir}, {persistPruneInfo}":
if disablePersistentDB: if disablePersistentDB:
@ -235,7 +254,9 @@ proc genesisLoadRunner(noisy = true;
pruneTrie = persistPruneTrie, pruneTrie = persistPruneTrie,
params = params) params = params)
check mdb.ttd == sSpcs.termTotalDff check ddb.ttd == sSpcs.termTotalDff
check ddb.config.mergeForkBlock.isSome
check ddb.config.mergeForkBlock.get == sSpcs.mergeFork.u256
test "Initialise in-memory Genesis": test "Initialise in-memory Genesis":
mdb.initializeEmptyDb mdb.initializeEmptyDb
@ -266,8 +287,8 @@ proc testnetChainRunner(noisy = true;
memoryDB = true; memoryDB = true;
stopAfterBlock = 999999999) = stopAfterBlock = 999999999) =
let let
cFileInfo = sSpcs.captureFile.splitFile.name.split(".")[0] cFileInfo = sSpcs.captures[0].splitFile.name.split(".")[0]
cFilePath = sSpcs.captureFile.findFilePath cFilePath = sSpcs.captures.mapIt(it.findFilePath)
dbInfo = if memoryDB: "in-memory" else: "persistent" dbInfo = if memoryDB: "in-memory" else: "persistent"
pivotBlockNumber = sSpcs.failBlockAt.u256 pivotBlockNumber = sSpcs.failBlockAt.u256
@ -295,11 +316,11 @@ proc testnetChainRunner(noisy = true;
test &"Replay {cFileInfo} capture, may fail ~#{pivotBlockNumber} "& test &"Replay {cFileInfo} capture, may fail ~#{pivotBlockNumber} "&
&"(slow -- time for coffee break)": &"(slow -- time for coffee break)":
noisy.say "***", "capture-file=", cFilePath noisy.say "***", "capture-files=[", cFilePath.join(","), "]"
discard discard
test &"Processing {sSpcs.fancyName} blocks": test &"Processing {sSpcs.fancyName} blocks":
for w in cFilePath.undumpNextGroup: for w in cFilePath.mapIt(it.string).undumpNextGroup:
let (fromBlock, toBlock) = (w[0][0].blockNumber, w[0][^1].blockNumber) let (fromBlock, toBlock) = (w[0][0].blockNumber, w[0][^1].blockNumber)
# Install & verify Genesis # Install & verify Genesis
@ -358,7 +379,7 @@ when isMainModule:
noisy.genesisLoadRunner( noisy.genesisLoadRunner(
# any of: devnet4, devnet5, kiln, etc. # any of: devnet4, devnet5, kiln, etc.
captureSession = devnet4) captureSession = kiln)
# Note that the `testnetChainRunner()` finds the replay dump files # Note that the `testnetChainRunner()` finds the replay dump files
# typically on the `nimbus-eth1-blobs` module. # typically on the `nimbus-eth1-blobs` module.