nimbus-eth2/tests/fuzzing/ssz_fuzzing.nim

41 lines
1.1 KiB
Nim
Raw Normal View History

2020-05-19 20:48:52 +03:00
import
testutils/fuzzing, faststreams/inputs, serialization/testing/tracing,
../../beacon_chain/spec/datatypes/base
2020-05-19 20:48:52 +03:00
export
ssz, base, fuzzing
2020-05-19 20:48:52 +03:00
template sszFuzzingTest*(T: type) =
test:
block:
let input = unsafeMemoryInput(payload)
let decoded = try: input.readValue(SSZ, T)
except SSZError: break
if input.len.get > 0:
# Some unconsumed input remained, this is not a valid test case
break
let reEncoded = SSZ.encode(decoded)
when T isnot SignedBeaconBlock:
let hash = hash_tree_root(decoded)
2020-05-19 20:48:52 +03:00
if payload != reEncoded:
when hasSerializationTracing:
# Run deserialization again to produce a seriazation trace
# (this is useful for comparing with the initial deserialization)
discard SSZ.decode(reEncoded, T)
2020-05-19 20:48:52 +03:00
echo "Payload with len = ", payload.len
echo payload
echo "Re-encoided payload with len = ", reEncoded.len
echo reEncoded
when T isnot SignedBeaconBlock:
echo "HTR: ", hash
2020-05-19 20:48:52 +03:00
echo repr(decoded)
doAssert false