2018-11-29 22:11:05 +00:00
|
|
|
# beacon_chain
|
2019-02-27 13:58:07 +00:00
|
|
|
# Copyright (c) 2018-2019 Status Research & Development GmbH
|
2018-11-29 22:11:05 +00:00
|
|
|
# Licensed and distributed under either of
|
2019-11-25 15:30:02 +00:00
|
|
|
# * MIT license (license terms in the root directory or at https://opensource.org/licenses/MIT).
|
|
|
|
# * Apache v2 license (license terms in the root directory or at https://www.apache.org/licenses/LICENSE-2.0).
|
2018-11-29 22:11:05 +00:00
|
|
|
# at your option. This file may not be copied, modified, or distributed except according to those terms.
|
|
|
|
|
|
|
|
import
|
2019-12-05 10:27:00 +00:00
|
|
|
algorithm, strformat, stats, times, std/monotimes, stew/endians2,
|
2019-03-28 12:00:21 +00:00
|
|
|
chronicles, eth/trie/[db],
|
2019-12-19 13:02:28 +00:00
|
|
|
../beacon_chain/[beacon_chain_db, block_pool, extras, ssz, beacon_node_types],
|
|
|
|
../beacon_chain/spec/[digest, beaconstate, datatypes],
|
|
|
|
testblockutil
|
2018-11-29 22:11:05 +00:00
|
|
|
|
2019-12-05 10:27:00 +00:00
|
|
|
type
|
|
|
|
TestDuration = tuple[duration: float, label: string]
|
|
|
|
|
2019-05-27 12:48:13 +00:00
|
|
|
func preset*(): string =
|
|
|
|
" [Preset: " & const_preset & ']'
|
|
|
|
|
2019-12-05 10:27:00 +00:00
|
|
|
# For state_sim
|
2019-12-03 16:45:12 +00:00
|
|
|
template withTimer*(stats: var RunningStat, body: untyped) =
|
|
|
|
let start = getMonoTime()
|
2018-12-13 16:00:55 +00:00
|
|
|
|
2019-12-03 16:45:12 +00:00
|
|
|
block:
|
|
|
|
body
|
2018-12-13 16:00:55 +00:00
|
|
|
|
2019-12-03 16:45:12 +00:00
|
|
|
let stop = getMonoTime()
|
|
|
|
stats.push (stop - start).inMicroseconds.float / 1000000.0
|
2019-07-24 06:19:52 +00:00
|
|
|
|
2019-12-05 10:27:00 +00:00
|
|
|
template withTimer*(duration: var float, body: untyped) =
|
|
|
|
let start = getMonoTime()
|
|
|
|
|
|
|
|
block:
|
|
|
|
body
|
|
|
|
|
|
|
|
duration = (getMonoTime() - start).inMicroseconds.float / 1000000.0
|
|
|
|
|
|
|
|
# For state_sim
|
2019-12-03 16:45:12 +00:00
|
|
|
template withTimerRet*(stats: var RunningStat, body: untyped): untyped =
|
|
|
|
let start = getMonoTime()
|
|
|
|
let tmp = block:
|
|
|
|
body
|
|
|
|
let stop = getMonoTime()
|
|
|
|
stats.push (stop - start).inMicroseconds.float / 1000000.0
|
2018-12-13 16:00:55 +00:00
|
|
|
|
2019-12-03 16:45:12 +00:00
|
|
|
tmp
|
2019-11-27 22:48:12 +00:00
|
|
|
|
2019-12-05 10:27:00 +00:00
|
|
|
var testTimes: seq[TestDuration]
|
|
|
|
|
|
|
|
proc summarizeLongTests*() =
|
|
|
|
# TODO clean-up and make machine-readable/storable the output
|
|
|
|
# TODO this is too hard-coded and mostly a demo for using the
|
|
|
|
# timedTest wrapper template for unittest
|
|
|
|
sort(testTimes, system.cmp, SortOrder.Descending)
|
|
|
|
|
|
|
|
echo ""
|
|
|
|
echo "10 longest individual test durations"
|
|
|
|
echo "------------------------------------"
|
|
|
|
for i, item in testTimes:
|
|
|
|
echo &"{item.duration:6.2f}s for {item.label}"
|
|
|
|
if i >= 10:
|
|
|
|
break
|
|
|
|
|
|
|
|
template timedTest*(name, body) =
|
|
|
|
var f: float
|
|
|
|
test name:
|
|
|
|
withTimer f:
|
|
|
|
body
|
|
|
|
|
|
|
|
# TODO reached for a failed test; maybe defer or similar
|
|
|
|
# TODO noto thread-safe as-is
|
|
|
|
testTimes.add (f, name)
|
|
|
|
|
2019-12-16 18:08:50 +00:00
|
|
|
proc makeTestDB*(tailState: BeaconState, tailBlock: SignedBeaconBlock): BeaconChainDB =
|
2019-02-28 21:21:29 +00:00
|
|
|
result = init(BeaconChainDB, newMemoryDB())
|
2019-03-28 06:10:48 +00:00
|
|
|
BlockPool.preInit(result, tailState, tailBlock)
|
2019-12-05 10:27:00 +00:00
|
|
|
|
2019-12-19 13:02:28 +00:00
|
|
|
proc makeTestDB*(validators: int): BeaconChainDB =
|
|
|
|
let
|
|
|
|
genState = initialize_beacon_state_from_eth1(
|
|
|
|
Eth2Digest(), 0,
|
|
|
|
makeInitialDeposits(validators, flags = {skipValidation}), {skipValidation})
|
|
|
|
genBlock = get_initial_beacon_block(genState)
|
|
|
|
makeTestDB(genState, genBlock)
|
|
|
|
|
2019-12-05 10:27:00 +00:00
|
|
|
export inMicroseconds
|