from eth2spec.test.helpers.state import get_state_root from eth2spec.test.context import spec_state_test, with_phases @with_phases(['phase0', 'phase1']) @spec_state_test def test_slots_1(spec, state): pre_slot = state.slot pre_root = state.hash_tree_root() yield 'pre', state slots = 1 yield 'slots', slots spec.process_slots(state, state.slot + slots) yield 'post', state assert state.slot == pre_slot + 1 assert get_state_root(spec, state, pre_slot) == pre_root @with_phases(['phase0', 'phase1']) @spec_state_test def test_slots_2(spec, state): yield 'pre', state slots = 2 yield 'slots', slots spec.process_slots(state, state.slot + slots) yield 'post', state @with_phases(['phase0', 'phase1']) @spec_state_test def test_empty_epoch(spec, state): yield 'pre', state slots = spec.SLOTS_PER_EPOCH yield 'slots', slots spec.process_slots(state, state.slot + slots) yield 'post', state @with_phases(['phase0', 'phase1']) @spec_state_test def test_double_empty_epoch(spec, state): yield 'pre', state slots = spec.SLOTS_PER_EPOCH * 2 yield 'slots', slots spec.process_slots(state, state.slot + slots) yield 'post', state @with_phases(['phase0', 'phase1']) @spec_state_test def test_over_epoch_boundary(spec, state): spec.process_slots(state, state.slot + (spec.SLOTS_PER_EPOCH // 2)) yield 'pre', state slots = spec.SLOTS_PER_EPOCH yield 'slots', slots spec.process_slots(state, state.slot + slots) yield 'post', state