2020-05-19 20:48:52 +03:00
|
|
|
import
|
2020-05-29 22:06:35 +03:00
|
|
|
testutils/fuzzing, faststreams/inputs, serialization/testing/tracing,
|
2021-08-12 15:08:20 +02:00
|
|
|
../../beacon_chain/spec/datatypes/base
|
2020-05-19 20:48:52 +03:00
|
|
|
|
|
|
|
export
|
2021-08-12 15:08:20 +02:00
|
|
|
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)
|
|
|
|
|
2020-06-03 14:59:50 +03:00
|
|
|
when T isnot SignedBeaconBlock:
|
|
|
|
let hash = hash_tree_root(decoded)
|
|
|
|
|
2020-05-19 20:48:52 +03:00
|
|
|
if payload != reEncoded:
|
2020-05-29 22:06:35 +03:00
|
|
|
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
|
|
|
|
|
2020-06-03 14:59:50 +03:00
|
|
|
when T isnot SignedBeaconBlock:
|
|
|
|
echo "HTR: ", hash
|
|
|
|
|
2020-05-19 20:48:52 +03:00
|
|
|
echo repr(decoded)
|
|
|
|
|
|
|
|
doAssert false
|