fix tests for mainnet preset
This commit is contained in:
parent
f14900fc45
commit
42d91d5482
|
@ -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)
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
|
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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)
|
||||||
|
|
Loading…
Reference in New Issue