fix tests for mainnet preset

This commit is contained in:
dapplion 2023-12-07 22:22:49 +01:00
parent f14900fc45
commit 42d91d5482
5 changed files with 16 additions and 12 deletions

View File

@ -126,7 +126,7 @@ def build_empty_block(spec, state, slot=None, proposer_index=None):
# Create valid whisk opening proof # Create valid whisk opening proof
# TODO: Use k_initial or k_final to handle first and subsequent proposals # TODO: Use k_initial or k_final to handle first and subsequent proposals
k_initial = whisk_ks_initial[proposer_index] k_initial = whisk_ks_initial(proposer_index)
# Sanity check proposer is correct # Sanity check proposer is correct
proposer_k_commitment = state.whisk_k_commitments[proposer_index] proposer_k_commitment = state.whisk_k_commitments[proposer_index]
@ -156,7 +156,7 @@ def build_empty_block(spec, state, slot=None, proposer_index=None):
# Branching logic depending if first proposal or not # Branching logic depending if first proposal or not
if is_first_proposal(spec, state, proposer_index): if is_first_proposal(spec, state, proposer_index):
# Register new tracker # Register new tracker
k_final = whisk_ks_final[proposer_index] k_final = whisk_ks_final(proposer_index)
# TODO: Actual logic should pick a random r, but may need to do something fancy to locate trackers quickly # TODO: Actual logic should pick a random r, but may need to do something fancy to locate trackers quickly
r = 2 r = 2
tracker, k_commitment = compute_whisk_tracker_and_commitment(k_final, r) tracker, k_commitment = compute_whisk_tracker_and_commitment(k_final, r)

View File

@ -5,13 +5,17 @@ privkeys = [i + 1 for i in range(32 * 256)]
pubkeys = [bls.SkToPk(privkey) for privkey in privkeys] pubkeys = [bls.SkToPk(privkey) for privkey in privkeys]
pubkey_to_privkey = {pubkey: privkey for privkey, pubkey in zip(privkeys, pubkeys)} pubkey_to_privkey = {pubkey: privkey for privkey, pubkey in zip(privkeys, pubkeys)}
MAX_KEYS = 32 * 256
whisk_ks_initial = [i for i in range(MAX_KEYS)]
# Must be unique among the set `whisk_ks_initial + whisk_ks_final`
whisk_ks_final = [MAX_KEYS + i for i in range(MAX_KEYS)]
known_whisk_trackers = {} known_whisk_trackers = {}
def register_known_whisk_tracker(k_r_G: bytes, index: int): def register_known_whisk_tracker(k_r_G: bytes, index: int):
known_whisk_trackers[k_r_G] = index known_whisk_trackers[k_r_G] = index
def whisk_ks_initial(i: int):
return i
# Must be unique among the set `whisk_ks_initial + whisk_ks_final`
def whisk_ks_final(i: int):
return i + 10000000

View File

@ -21,7 +21,7 @@ def compute_whisk_initial_tracker_cached(i: int) -> WhiskTracker:
if i in whisk_initial_tracker_cache_by_index: if i in whisk_initial_tracker_cache_by_index:
return whisk_initial_tracker_cache_by_index[i] return whisk_initial_tracker_cache_by_index[i]
tracker = compute_whisk_tracker(whisk_ks_initial[i], INITIAL_R) tracker = compute_whisk_tracker(whisk_ks_initial(i), INITIAL_R)
whisk_initial_tracker_cache_by_index[i] = tracker whisk_initial_tracker_cache_by_index[i] = tracker
whisk_initial_tracker_cache_by_k_r_G[tracker.k_r_G] = i whisk_initial_tracker_cache_by_k_r_G[tracker.k_r_G] = i
return tracker return tracker
@ -31,7 +31,7 @@ def compute_whisk_initial_k_commitment_cached(i: int) -> BLSPubkey:
if i in whisk_initial_k_commitment_cache_by_index: if i in whisk_initial_k_commitment_cache_by_index:
return whisk_initial_k_commitment_cache_by_index[i] return whisk_initial_k_commitment_cache_by_index[i]
commitment = compute_whisk_k_commitment(whisk_ks_initial[i]) commitment = compute_whisk_k_commitment(whisk_ks_initial(i))
whisk_initial_k_commitment_cache_by_index[i] = commitment whisk_initial_k_commitment_cache_by_index[i] = commitment
return commitment return commitment

View File

@ -17,7 +17,7 @@ def get_and_populate_pre_shuffle_trackers(spec, state, body):
pre_shuffle_trackers = [] pre_shuffle_trackers = []
for i in shuffle_indices: for i in shuffle_indices:
# Set r to some value > 1 ( = 2+i) # Set r to some value > 1 ( = 2+i)
tracker = compute_whisk_tracker(whisk_ks_initial[i], 2 + i) tracker = compute_whisk_tracker(whisk_ks_initial(i), 2 + i)
state.whisk_candidate_trackers[i] = tracker state.whisk_candidate_trackers[i] = tracker
pre_shuffle_trackers.append(tracker) pre_shuffle_trackers.append(tracker)
return pre_shuffle_trackers return pre_shuffle_trackers

View File

@ -15,7 +15,7 @@ def assign_proposer_at_slot(state, slot: int):
def initialize_whisk_full(spec, state): def initialize_whisk_full(spec, state):
# TODO: De-duplicate code from whisk/fork.md # TODO: De-duplicate code from whisk/fork.md
for index in range(len(state.validators)): for index in range(len(state.validators)):
whisk_k_commitment, whisk_tracker = spec.get_initial_commitments(whisk_ks_initial[index]) whisk_k_commitment, whisk_tracker = spec.get_initial_commitments(whisk_ks_initial(index))
state.whisk_k_commitments[index] = whisk_k_commitment state.whisk_k_commitments[index] = whisk_k_commitment
state.whisk_trackers[index] = whisk_tracker state.whisk_trackers[index] = whisk_tracker
@ -36,7 +36,7 @@ def fill_candidate_trackers(spec, state, tracker: WhiskTracker):
def test_whisk__process_block_single_initial(spec, state): def test_whisk__process_block_single_initial(spec, state):
assert state.slot == 0 assert state.slot == 0
proposer_slot_1 = 0 proposer_slot_1 = 0
tracker_slot_1, k_commitment = compute_whisk_tracker_and_commitment(whisk_ks_initial[proposer_slot_1], 1) tracker_slot_1, k_commitment = compute_whisk_tracker_and_commitment(whisk_ks_initial(proposer_slot_1), 1)
state.whisk_k_commitments[proposer_slot_1] = k_commitment state.whisk_k_commitments[proposer_slot_1] = k_commitment
state.whisk_proposer_trackers[1] = tracker_slot_1 state.whisk_proposer_trackers[1] = tracker_slot_1
fill_candidate_trackers(spec, state, tracker_slot_1) fill_candidate_trackers(spec, state, tracker_slot_1)