set block header tests to automatically enumerate all relevant tests (#717)

* set block header tests to automatically enumerate all relevant tests

* add several attester slashing tests and run all tests by default, rather than only explicitly listed test vectors

* print something relating to skipped tests

* set voluntary exits to automatically enumerate all tests
This commit is contained in:
tersec 2020-02-06 11:41:06 +00:00 committed by GitHub
parent cd1c8155bf
commit 989559cd2d
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 29 additions and 58 deletions

View File

@ -20,13 +20,13 @@ import
const OpAttSlashingDir = SszTestsDir/const_preset/"phase0"/"operations"/"attester_slashing"/"pyspec_tests" const OpAttSlashingDir = SszTestsDir/const_preset/"phase0"/"operations"/"attester_slashing"/"pyspec_tests"
template runTest(identifier: untyped) = proc runTest(identifier: string) =
# We wrap the tests in a proc to avoid running out of globals # We wrap the tests in a proc to avoid running out of globals
# in the future: Nim supports up to 3500 globals # in the future: Nim supports up to 3500 globals
# but unittest with the macro/templates put everything as globals # but unittest with the macro/templates put everything as globals
# https://github.com/nim-lang/Nim/issues/12084#issue-486866402 # https://github.com/nim-lang/Nim/issues/12084#issue-486866402
const testDir = OpAttSlashingDir / astToStr(identifier) let testDir = OpAttSlashingDir / identifier
proc `testImpl _ operations_attester_slashing _ identifier`() = proc `testImpl _ operations_attester_slashing _ identifier`() =
@ -39,7 +39,7 @@ template runTest(identifier: untyped) =
else: else:
prefix = "[Invalid] " prefix = "[Invalid] "
timedTest prefix & astToStr(identifier): timedTest prefix & identifier:
var stateRef, postRef: ref BeaconState var stateRef, postRef: ref BeaconState
var attesterSlashingRef: ref AttesterSlashing var attesterSlashingRef: ref AttesterSlashing
new attesterSlashingRef new attesterSlashingRef
@ -68,27 +68,17 @@ template runTest(identifier: untyped) =
`testImpl _ operations_attester_slashing _ identifier`() `testImpl _ operations_attester_slashing _ identifier`()
suite "Official - Operations - Attester slashing " & preset(): suite "Official - Operations - Attester slashing " & preset():
runTest(success_double) # TODO these are both valid and check BLS signatures, which isn't working
runTest(success_surround) # since 0.10.x introduces new BLS signing/verifying interface with domain
when false: # in particular handled differently through compute_signing_root() rather
# TODO these are both valid and check BLS signatures, which isn't working # than through the bls_verify(...) call directly. This did not become the
# since 0.10.x introduces new BLS signing/verifying interface with domain # visible issue it now is because another bug had been masking it wherein
# in particular handled differently through compute_signing_root() rather # crypto.nim's bls_verify(...) call had been creating false positives, in
# than through the bls_verify(...) call directly. This did not become the # which cases signature checks had been incorrectly passing.
# visible issue it now is because another bug had been masking it wherein const expected_failures =
# crypto.nim's bls_verify(...) call had been creating false positives, in ["success_already_exited_recent", "success_already_exited_long_ago"]
# which cases signature checks had been incorrectly passing. for kind, path in walkDir(OpAttSlashingDir, true):
runTest(success_already_exited_recent) if path in expected_failures:
runTest(success_already_exited_long_ago) echo "Skipping test: ", path
runTest(invalid_sig_1) continue
when false: # TODO - https://github.com/status-im/nim-beacon-chain/issues/429 runTest(path)
runTest(invalid_sig_2)
runTest(invalid_sig_1_and_2)
runTest(same_data)
runTest(no_double_or_surround)
runTest(participants_already_slashed)
when false: # TODO - https://github.com/status-im/nim-beacon-chain/issues/429
runTest(att1_bad_extra_index)
runTest(att1_bad_replaced_index)
runTest(att2_bad_extra_index)
runTest(att2_bad_replaced_index)

View File

@ -20,26 +20,23 @@ import
const OpBlockHeaderDir = SszTestsDir/const_preset/"phase0"/"operations"/"block_header"/"pyspec_tests" const OpBlockHeaderDir = SszTestsDir/const_preset/"phase0"/"operations"/"block_header"/"pyspec_tests"
template runTest(identifier: untyped) = proc runTest(identifier: string) =
# We wrap the tests in a proc to avoid running out of globals # We wrap the tests in a proc to avoid running out of globals
# in the future: Nim supports up to 3500 globals # in the future: Nim supports up to 3500 globals
# but unittest with the macro/templates put everything as globals # but unittest with the macro/templates put everything as globals
# https://github.com/nim-lang/Nim/issues/12084#issue-486866402 # https://github.com/nim-lang/Nim/issues/12084#issue-486866402
const testDir = OpBlockHeaderDir / astToStr(identifier) let testDir = OpBlockHeaderDir / identifier
proc `testImpl _ blockheader _ identifier`() = proc `testImpl _ blockheader _ identifier`() =
var flags: UpdateFlags
var prefix: string var prefix: string
if not existsFile(testDir/"meta.yaml"):
flags.incl skipValidation
if existsFile(testDir/"post.ssz"): if existsFile(testDir/"post.ssz"):
prefix = "[Valid] " prefix = "[Valid] "
else: else:
prefix = "[Invalid] " prefix = "[Invalid] "
timedTest prefix & astToStr(identifier): timedTest prefix & identifier:
var stateRef, postRef: ref BeaconState var stateRef, postRef: ref BeaconState
var blck: ref BeaconBlock var blck: ref BeaconBlock
new blck new blck
@ -55,10 +52,10 @@ template runTest(identifier: untyped) =
postRef[] = parseTest(testDir/"post.ssz", SSZ, BeaconState) postRef[] = parseTest(testDir/"post.ssz", SSZ, BeaconState)
if postRef.isNil: if postRef.isNil:
let done = process_block_header(stateRef[], blck[], flags, cache) let done = process_block_header(stateRef[], blck[], {}, cache)
doAssert done == false, "We didn't expect this invalid block header to be processed." doAssert done == false, "We didn't expect this invalid block header to be processed."
else: else:
let done = process_block_header(stateRef[], blck[], flags, cache) let done = process_block_header(stateRef[], blck[], {}, cache)
doAssert done, "Valid block header not processed" doAssert done, "Valid block header not processed"
check: stateRef.hash_tree_root() == postRef.hash_tree_root() check: stateRef.hash_tree_root() == postRef.hash_tree_root()
reportDiff(stateRef, postRef) reportDiff(stateRef, postRef)
@ -66,8 +63,5 @@ template runTest(identifier: untyped) =
`testImpl _ blockheader _ identifier`() `testImpl _ blockheader _ identifier`()
suite "Official - Operations - Block header " & preset(): suite "Official - Operations - Block header " & preset():
runTest(success_block_header) for kind, path in walkDir(OpBlockHeaderDir, true):
runTest(invalid_slot_block_header) runTest(path)
when false: # skipValidation needs to be split https://github.com/status-im/nim-beacon-chain/issues/407
runTest(invalid_parent_root)
runTest(proposer_slashed)

View File

@ -20,13 +20,13 @@ import
const OpVoluntaryExitDir = SszTestsDir/const_preset/"phase0"/"operations"/"voluntary_exit"/"pyspec_tests" const OpVoluntaryExitDir = SszTestsDir/const_preset/"phase0"/"operations"/"voluntary_exit"/"pyspec_tests"
template runTest(identifier: untyped) = proc runTest(identifier: string) =
# We wrap the tests in a proc to avoid running out of globals # We wrap the tests in a proc to avoid running out of globals
# in the future: Nim supports up to 3500 globals # in the future: Nim supports up to 3500 globals
# but unittest with the macro/templates put everything as globals # but unittest with the macro/templates put everything as globals
# https://github.com/nim-lang/Nim/issues/12084#issue-486866402 # https://github.com/nim-lang/Nim/issues/12084#issue-486866402
const testDir = OpVoluntaryExitDir / astToStr(identifier) let testDir = OpVoluntaryExitDir / identifier
proc `testImpl _ voluntary_exit _ identifier`() = proc `testImpl _ voluntary_exit _ identifier`() =
@ -39,7 +39,7 @@ template runTest(identifier: untyped) =
else: else:
prefix = "[Invalid] " prefix = "[Invalid] "
timedTest prefix & astToStr(identifier): timedTest prefix & identifier:
var stateRef, postRef: ref BeaconState var stateRef, postRef: ref BeaconState
var voluntaryExit: ref SignedVoluntaryExit var voluntaryExit: ref SignedVoluntaryExit
new voluntaryExit new voluntaryExit
@ -64,18 +64,5 @@ template runTest(identifier: untyped) =
`testImpl _ voluntary_exit _ identifier`() `testImpl _ voluntary_exit _ identifier`()
suite "Official - Operations - Voluntary exit " & preset(): suite "Official - Operations - Voluntary exit " & preset():
# https://github.com/ethereum/eth2.0-spec-tests/tree/v0.10.1/tests/minimal/phase0/operations/voluntary_exit/pyspec_tests for kind, path in walkDir(OpVoluntaryExitDir, true):
# https://github.com/ethereum/eth2.0-spec-tests/tree/v0.10.1/tests/mainnet/phase0/operations/voluntary_exit/pyspec_tests runTest(path)
runTest(success)
when false:
# TODO not sure how this particularly could falsely succeed
runTest(invalid_signature)
runTest(validator_invalid_validator_index)
runTest(validator_already_exited)
runTest(success_exit_queue)
runTest(validator_exit_in_future)
runTest(default_exit_epoch_subsequent_exit)
runTest(validator_not_active_long_enough)
runTest(validator_not_active)