mirror of
https://github.com/status-im/eth2.0-specs.git
synced 2025-01-23 00:50:03 +00:00
b15669b7a5
* p2p-interface: clarify that signing_root is used for block requests * hash cleanups * one more hash tree root gone for blocks - block hashes are always signing roots! * use simple serialize data types consistently * Describe which finalized root/epoch to use * remove custody_bits from attestation * remove AttestationDataAndCustodyBit * Specify inclusive range for genesis deposits * add initial fork choice bounce prevention and tests * PR feedback * further test bounce attack * wipe queued justified after epoch transition * remove extra var * minor fmt * only allow attestatiosn to be considered from current and previous epoch * use best_justified_checkpoint instead of queued_justified_checkpoints * use helper for slots since epoch start * be explicit about use of genesis epoch for previous epoch in fork choice on_block * pr feedback * add note aboutgenesis attestations * cleanup get_eth1_vote * make eth1_follow_distance clearer * Update the expected proposer period Since `SECONDS_PER_SLOT` is now `12` * minor fix to comment in mainnet config * Update 0_beacon-chain.md
36 lines
1.6 KiB
Python
36 lines
1.6 KiB
Python
from eth2spec.fuzzing.decoder import translate_typ, translate_value
|
|
from eth2spec.phase0 import spec
|
|
from eth2spec.utils.ssz import ssz_impl as spec_ssz_impl
|
|
from random import Random
|
|
from eth2spec.debug import random_value
|
|
|
|
|
|
def test_decoder():
|
|
rng = Random(123)
|
|
|
|
# check these types only, Block covers a lot of operation types already.
|
|
for typ in [spec.Attestation, spec.BeaconState, spec.BeaconBlock]:
|
|
# create a random pyspec value
|
|
original = random_value.get_random_ssz_object(rng, typ, 100, 10,
|
|
mode=random_value.RandomizationMode.mode_random,
|
|
chaos=True)
|
|
# serialize it, using pyspec
|
|
pyspec_data = spec_ssz_impl.serialize(original)
|
|
# get the py-ssz type for it
|
|
block_sedes = translate_typ(typ)
|
|
# try decoding using the py-ssz type
|
|
raw_value = block_sedes.deserialize(pyspec_data)
|
|
|
|
# serialize it using py-ssz
|
|
pyssz_data = block_sedes.serialize(raw_value)
|
|
# now check if the serialized form is equal. If so, we confirmed decoding and encoding to work.
|
|
assert pyspec_data == pyssz_data
|
|
|
|
# now translate the py-ssz value in a pyspec-value
|
|
block = translate_value(raw_value, typ)
|
|
|
|
# and see if the hash-tree-root of the original matches the hash-tree-root of the decoded & translated value.
|
|
original_hash_tree_root = spec_ssz_impl.hash_tree_root(original)
|
|
assert original_hash_tree_root == spec_ssz_impl.hash_tree_root(block)
|
|
assert original_hash_tree_root == block_sedes.get_hash_tree_root(raw_value)
|