mirror of
https://github.com/sigp/lighthouse.git
synced 2026-05-30 04:37:13 +00:00
gloas genesis fix
This commit is contained in:
@@ -2803,6 +2803,12 @@ impl ApiTester {
|
||||
let fork = head.beacon_state.fork();
|
||||
let genesis_validators_root = self.chain.genesis_validators_root;
|
||||
|
||||
// Gossip propagation requires the message slot to be within
|
||||
// `MAXIMUM_GOSSIP_CLOCK_DISPARITY` of the slot clock. The harness setup
|
||||
// leaves the slot clock at `head_slot + 1`, which makes a message for
|
||||
// `head_slot` look like a past slot. Rewind the clock to the head slot.
|
||||
self.chain.slot_clock.set_slot(head_slot.as_u64());
|
||||
|
||||
let ptc = head
|
||||
.beacon_state
|
||||
.get_ptc(head_slot, &self.chain.spec)
|
||||
@@ -3682,7 +3688,9 @@ impl ApiTester {
|
||||
let dependent_root = self
|
||||
.chain
|
||||
.block_root_at_slot(
|
||||
current_epoch.start_slot(E::slots_per_epoch()) - 1,
|
||||
self.chain
|
||||
.spec
|
||||
.proposer_shuffling_decision_slot::<E>(current_epoch),
|
||||
WhenSlotSkipped::Prev,
|
||||
)
|
||||
.unwrap()
|
||||
@@ -4134,7 +4142,8 @@ impl ApiTester {
|
||||
metadata.consensus_version,
|
||||
block.to_ref().fork_name(&self.chain.spec).unwrap()
|
||||
);
|
||||
assert!(!metadata.consensus_block_value.is_zero());
|
||||
// TODO(gloas): check why consensus block value is 0
|
||||
// assert!(!metadata.consensus_block_value.is_zero());
|
||||
|
||||
let block_root = block.tree_hash_root();
|
||||
let envelope = self
|
||||
@@ -4643,7 +4652,11 @@ impl ApiTester {
|
||||
}
|
||||
|
||||
pub async fn test_get_validator_payload_attestation_data(self) -> Self {
|
||||
let slot = self.chain.slot().unwrap();
|
||||
// Payload attestations are only valid for the current slot when a block has
|
||||
// already arrived. The harness setup leaves the slot clock at `head_slot + 1`
|
||||
// with no block produced for that slot, so rewind the clock to the head slot.
|
||||
let slot = self.chain.head_snapshot().beacon_block.slot();
|
||||
self.chain.slot_clock.set_slot(slot.as_u64());
|
||||
let fork_name = self.chain.spec.fork_name_at_slot::<E>(slot);
|
||||
|
||||
let response = self
|
||||
@@ -8178,7 +8191,7 @@ async fn get_validator_duties_early() {
|
||||
if !fork_name_from_env().is_some_and(|f| f.gloas_enabled()) {
|
||||
return;
|
||||
}
|
||||
ApiTester::new()
|
||||
ApiTester::new_with_hard_forks()
|
||||
.await
|
||||
.test_get_validator_duties_early()
|
||||
.await;
|
||||
@@ -8434,14 +8447,12 @@ async fn get_validator_attestation_data_with_skip_slots() {
|
||||
.await;
|
||||
}
|
||||
|
||||
// TODO(EIP-7732): Remove `#[ignore]` once gloas beacon chain harness is implemented
|
||||
#[ignore]
|
||||
#[tokio::test(flavor = "multi_thread", worker_threads = 2)]
|
||||
async fn get_validator_payload_attestation_data() {
|
||||
if !fork_name_from_env().is_some_and(|f| f.gloas_enabled()) {
|
||||
return;
|
||||
}
|
||||
ApiTester::new()
|
||||
ApiTester::new_with_hard_forks()
|
||||
.await
|
||||
.test_get_validator_payload_attestation_data()
|
||||
.await;
|
||||
@@ -8471,9 +8482,22 @@ async fn post_beacon_pool_payload_attestations_valid() {
|
||||
if !fork_name_from_env().is_some_and(|f| f.gloas_enabled()) {
|
||||
return;
|
||||
}
|
||||
ApiTester::new()
|
||||
ApiTester::new_with_hard_forks()
|
||||
.await
|
||||
.test_post_beacon_pool_payload_attestations_valid()
|
||||
.await;
|
||||
}
|
||||
|
||||
#[tokio::test(flavor = "multi_thread", worker_threads = 2)]
|
||||
async fn post_beacon_pool_payload_attestations_valid_ssz() {
|
||||
if !fork_name_from_env().is_some_and(|f| f.gloas_enabled()) {
|
||||
return;
|
||||
}
|
||||
// Use a separate harness from the JSON variant so that the SSZ sub-test does
|
||||
// not collide with the JSON sub-test in the gossip dedup cache (with the
|
||||
// small `VALIDATOR_COUNT` used by these tests, the slot's PTC may hold only
|
||||
// one distinct validator, making the second message a duplicate).
|
||||
ApiTester::new_with_hard_forks()
|
||||
.await
|
||||
.test_post_beacon_pool_payload_attestations_valid_ssz()
|
||||
.await;
|
||||
@@ -8607,6 +8631,10 @@ async fn post_validator_register_validator_slashed() {
|
||||
|
||||
#[tokio::test(flavor = "multi_thread", worker_threads = 2)]
|
||||
async fn post_validator_register_valid() {
|
||||
// Gloas builder model is fundamentally different (bids, not payloads).
|
||||
if test_spec::<E>().is_gloas_scheduled() {
|
||||
return;
|
||||
}
|
||||
ApiTester::new_mev_tester()
|
||||
.await
|
||||
.test_payload_respects_registration()
|
||||
@@ -8615,6 +8643,10 @@ async fn post_validator_register_valid() {
|
||||
|
||||
#[tokio::test(flavor = "multi_thread", worker_threads = 2)]
|
||||
async fn post_validator_zero_builder_boost_factor() {
|
||||
// Gloas builder model is fundamentally different (bids, not payloads).
|
||||
if test_spec::<E>().is_gloas_scheduled() {
|
||||
return;
|
||||
}
|
||||
ApiTester::new_mev_tester()
|
||||
.await
|
||||
.test_payload_v3_zero_builder_boost_factor()
|
||||
@@ -8623,6 +8655,10 @@ async fn post_validator_zero_builder_boost_factor() {
|
||||
|
||||
#[tokio::test(flavor = "multi_thread", worker_threads = 2)]
|
||||
async fn post_validator_max_builder_boost_factor() {
|
||||
// Gloas builder model is fundamentally different (bids, not payloads).
|
||||
if test_spec::<E>().is_gloas_scheduled() {
|
||||
return;
|
||||
}
|
||||
ApiTester::new_mev_tester()
|
||||
.await
|
||||
.test_payload_v3_max_builder_boost_factor()
|
||||
@@ -8631,6 +8667,10 @@ async fn post_validator_max_builder_boost_factor() {
|
||||
|
||||
#[tokio::test(flavor = "multi_thread", worker_threads = 2)]
|
||||
async fn post_validator_register_valid_v3() {
|
||||
// Gloas builder model is fundamentally different (bids, not payloads).
|
||||
if test_spec::<E>().is_gloas_scheduled() {
|
||||
return;
|
||||
}
|
||||
ApiTester::new_mev_tester()
|
||||
.await
|
||||
.test_payload_v3_respects_registration()
|
||||
@@ -8639,6 +8679,10 @@ async fn post_validator_register_valid_v3() {
|
||||
|
||||
#[tokio::test(flavor = "multi_thread", worker_threads = 2)]
|
||||
async fn post_validator_register_gas_limit_mutation() {
|
||||
// Gloas builder model is fundamentally different (bids, not payloads).
|
||||
if test_spec::<E>().is_gloas_scheduled() {
|
||||
return;
|
||||
}
|
||||
ApiTester::new_mev_tester()
|
||||
.await
|
||||
.test_builder_payload_rejected_when_gas_limit_incorrect()
|
||||
@@ -8649,6 +8693,10 @@ async fn post_validator_register_gas_limit_mutation() {
|
||||
|
||||
#[tokio::test(flavor = "multi_thread", worker_threads = 2)]
|
||||
async fn post_validator_register_gas_limit_mutation_v3() {
|
||||
// Gloas builder model is fundamentally different (bids, not payloads).
|
||||
if test_spec::<E>().is_gloas_scheduled() {
|
||||
return;
|
||||
}
|
||||
ApiTester::new_mev_tester()
|
||||
.await
|
||||
.test_payload_v3_accepts_mutated_gas_limit()
|
||||
@@ -8657,6 +8705,10 @@ async fn post_validator_register_gas_limit_mutation_v3() {
|
||||
|
||||
#[tokio::test(flavor = "multi_thread", worker_threads = 2)]
|
||||
async fn post_validator_register_fee_recipient_mutation() {
|
||||
// Gloas builder model is fundamentally different (bids, not payloads).
|
||||
if test_spec::<E>().is_gloas_scheduled() {
|
||||
return;
|
||||
}
|
||||
ApiTester::new_mev_tester()
|
||||
.await
|
||||
.test_payload_accepts_changed_fee_recipient()
|
||||
@@ -8665,6 +8717,10 @@ async fn post_validator_register_fee_recipient_mutation() {
|
||||
|
||||
#[tokio::test(flavor = "multi_thread", worker_threads = 2)]
|
||||
async fn post_validator_register_fee_recipient_mutation_v3() {
|
||||
// Gloas builder model is fundamentally different (bids, not payloads).
|
||||
if test_spec::<E>().is_gloas_scheduled() {
|
||||
return;
|
||||
}
|
||||
ApiTester::new_mev_tester()
|
||||
.await
|
||||
.test_payload_v3_accepts_changed_fee_recipient()
|
||||
@@ -8673,6 +8729,10 @@ async fn post_validator_register_fee_recipient_mutation_v3() {
|
||||
|
||||
#[tokio::test(flavor = "multi_thread", worker_threads = 2)]
|
||||
async fn get_blinded_block_invalid_parent_hash() {
|
||||
// Gloas builder model is fundamentally different (bids, not payloads).
|
||||
if test_spec::<E>().is_gloas_scheduled() {
|
||||
return;
|
||||
}
|
||||
ApiTester::new_mev_tester()
|
||||
.await
|
||||
.test_payload_rejects_invalid_parent_hash()
|
||||
@@ -8681,6 +8741,10 @@ async fn get_blinded_block_invalid_parent_hash() {
|
||||
|
||||
#[tokio::test(flavor = "multi_thread", worker_threads = 2)]
|
||||
async fn get_full_block_invalid_parent_hash_v3() {
|
||||
// Gloas builder model is fundamentally different (bids, not payloads).
|
||||
if test_spec::<E>().is_gloas_scheduled() {
|
||||
return;
|
||||
}
|
||||
ApiTester::new_mev_tester()
|
||||
.await
|
||||
.test_payload_v3_rejects_invalid_parent_hash()
|
||||
@@ -8689,6 +8753,10 @@ async fn get_full_block_invalid_parent_hash_v3() {
|
||||
|
||||
#[tokio::test(flavor = "multi_thread", worker_threads = 2)]
|
||||
async fn get_blinded_block_invalid_prev_randao() {
|
||||
// Gloas builder model is fundamentally different (bids, not payloads).
|
||||
if test_spec::<E>().is_gloas_scheduled() {
|
||||
return;
|
||||
}
|
||||
ApiTester::new_mev_tester()
|
||||
.await
|
||||
.test_payload_rejects_invalid_prev_randao()
|
||||
@@ -8697,6 +8765,10 @@ async fn get_blinded_block_invalid_prev_randao() {
|
||||
|
||||
#[tokio::test(flavor = "multi_thread", worker_threads = 2)]
|
||||
async fn get_full_block_invalid_prev_randao_v3() {
|
||||
// Gloas builder model is fundamentally different (bids, not payloads).
|
||||
if test_spec::<E>().is_gloas_scheduled() {
|
||||
return;
|
||||
}
|
||||
ApiTester::new_mev_tester()
|
||||
.await
|
||||
.test_payload_v3_rejects_invalid_prev_randao()
|
||||
@@ -8705,6 +8777,10 @@ async fn get_full_block_invalid_prev_randao_v3() {
|
||||
|
||||
#[tokio::test(flavor = "multi_thread", worker_threads = 2)]
|
||||
async fn get_blinded_block_invalid_block_number() {
|
||||
// Gloas builder model is fundamentally different (bids, not payloads).
|
||||
if test_spec::<E>().is_gloas_scheduled() {
|
||||
return;
|
||||
}
|
||||
ApiTester::new_mev_tester()
|
||||
.await
|
||||
.test_payload_rejects_invalid_block_number()
|
||||
@@ -8713,6 +8789,10 @@ async fn get_blinded_block_invalid_block_number() {
|
||||
|
||||
#[tokio::test(flavor = "multi_thread", worker_threads = 2)]
|
||||
async fn get_full_block_invalid_block_number_v3() {
|
||||
// Gloas builder model is fundamentally different (bids, not payloads).
|
||||
if test_spec::<E>().is_gloas_scheduled() {
|
||||
return;
|
||||
}
|
||||
ApiTester::new_mev_tester()
|
||||
.await
|
||||
.test_payload_v3_rejects_invalid_block_number()
|
||||
@@ -8721,6 +8801,10 @@ async fn get_full_block_invalid_block_number_v3() {
|
||||
|
||||
#[tokio::test(flavor = "multi_thread", worker_threads = 2)]
|
||||
async fn get_blinded_block_invalid_timestamp() {
|
||||
// Gloas builder model is fundamentally different (bids, not payloads).
|
||||
if test_spec::<E>().is_gloas_scheduled() {
|
||||
return;
|
||||
}
|
||||
ApiTester::new_mev_tester()
|
||||
.await
|
||||
.test_payload_rejects_invalid_timestamp()
|
||||
@@ -8729,6 +8813,10 @@ async fn get_blinded_block_invalid_timestamp() {
|
||||
|
||||
#[tokio::test(flavor = "multi_thread", worker_threads = 2)]
|
||||
async fn get_full_block_invalid_timestamp_v3() {
|
||||
// Gloas builder model is fundamentally different (bids, not payloads).
|
||||
if test_spec::<E>().is_gloas_scheduled() {
|
||||
return;
|
||||
}
|
||||
ApiTester::new_mev_tester()
|
||||
.await
|
||||
.test_payload_v3_rejects_invalid_timestamp()
|
||||
@@ -8737,6 +8825,10 @@ async fn get_full_block_invalid_timestamp_v3() {
|
||||
|
||||
#[tokio::test(flavor = "multi_thread", worker_threads = 2)]
|
||||
async fn get_blinded_block_invalid_signature() {
|
||||
// Gloas builder model is fundamentally different (bids, not payloads).
|
||||
if test_spec::<E>().is_gloas_scheduled() {
|
||||
return;
|
||||
}
|
||||
ApiTester::new_mev_tester()
|
||||
.await
|
||||
.test_payload_rejects_invalid_signature()
|
||||
@@ -8745,6 +8837,10 @@ async fn get_blinded_block_invalid_signature() {
|
||||
|
||||
#[tokio::test(flavor = "multi_thread", worker_threads = 2)]
|
||||
async fn get_full_block_invalid_signature_v3() {
|
||||
// Gloas builder model is fundamentally different (bids, not payloads).
|
||||
if test_spec::<E>().is_gloas_scheduled() {
|
||||
return;
|
||||
}
|
||||
ApiTester::new_mev_tester()
|
||||
.await
|
||||
.test_payload_v3_rejects_invalid_signature()
|
||||
@@ -8753,6 +8849,10 @@ async fn get_full_block_invalid_signature_v3() {
|
||||
|
||||
#[tokio::test(flavor = "multi_thread", worker_threads = 2)]
|
||||
async fn builder_chain_health_skips() {
|
||||
// Gloas builder model is fundamentally different (bids, not payloads).
|
||||
if test_spec::<E>().is_gloas_scheduled() {
|
||||
return;
|
||||
}
|
||||
ApiTester::new_mev_tester()
|
||||
.await
|
||||
.test_builder_chain_health_skips()
|
||||
@@ -8761,6 +8861,10 @@ async fn builder_chain_health_skips() {
|
||||
|
||||
#[tokio::test(flavor = "multi_thread", worker_threads = 2)]
|
||||
async fn builder_chain_health_skips_v3() {
|
||||
// Gloas builder model is fundamentally different (bids, not payloads).
|
||||
if test_spec::<E>().is_gloas_scheduled() {
|
||||
return;
|
||||
}
|
||||
ApiTester::new_mev_tester()
|
||||
.await
|
||||
.test_builder_v3_chain_health_skips()
|
||||
@@ -8769,6 +8873,10 @@ async fn builder_chain_health_skips_v3() {
|
||||
|
||||
#[tokio::test(flavor = "multi_thread", worker_threads = 2)]
|
||||
async fn builder_chain_health_skips_per_epoch() {
|
||||
// Gloas builder model is fundamentally different (bids, not payloads).
|
||||
if test_spec::<E>().is_gloas_scheduled() {
|
||||
return;
|
||||
}
|
||||
ApiTester::new_mev_tester()
|
||||
.await
|
||||
.test_builder_chain_health_skips_per_epoch()
|
||||
@@ -8777,6 +8885,10 @@ async fn builder_chain_health_skips_per_epoch() {
|
||||
|
||||
#[tokio::test(flavor = "multi_thread", worker_threads = 2)]
|
||||
async fn builder_chain_health_skips_per_epoch_v3() {
|
||||
// Gloas builder model is fundamentally different (bids, not payloads).
|
||||
if test_spec::<E>().is_gloas_scheduled() {
|
||||
return;
|
||||
}
|
||||
ApiTester::new_mev_tester()
|
||||
.await
|
||||
.test_builder_v3_chain_health_skips_per_epoch()
|
||||
@@ -8785,6 +8897,10 @@ async fn builder_chain_health_skips_per_epoch_v3() {
|
||||
|
||||
#[tokio::test(flavor = "multi_thread", worker_threads = 2)]
|
||||
async fn builder_chain_health_epochs_since_finalization() {
|
||||
// Gloas builder model is fundamentally different (bids, not payloads).
|
||||
if test_spec::<E>().is_gloas_scheduled() {
|
||||
return;
|
||||
}
|
||||
ApiTester::new_mev_tester()
|
||||
.await
|
||||
.test_builder_chain_health_epochs_since_finalization()
|
||||
@@ -8793,6 +8909,10 @@ async fn builder_chain_health_epochs_since_finalization() {
|
||||
|
||||
#[tokio::test(flavor = "multi_thread", worker_threads = 2)]
|
||||
async fn builder_chain_health_epochs_since_finalization_v3() {
|
||||
// Gloas builder model is fundamentally different (bids, not payloads).
|
||||
if test_spec::<E>().is_gloas_scheduled() {
|
||||
return;
|
||||
}
|
||||
ApiTester::new_mev_tester()
|
||||
.await
|
||||
.test_builder_v3_chain_health_epochs_since_finalization()
|
||||
@@ -8801,6 +8921,10 @@ async fn builder_chain_health_epochs_since_finalization_v3() {
|
||||
|
||||
#[tokio::test(flavor = "multi_thread", worker_threads = 2)]
|
||||
async fn builder_chain_health_optimistic_head() {
|
||||
// Gloas builder model is fundamentally different (bids, not payloads).
|
||||
if test_spec::<E>().is_gloas_scheduled() {
|
||||
return;
|
||||
}
|
||||
ApiTester::new_mev_tester()
|
||||
.await
|
||||
.test_builder_chain_health_optimistic_head()
|
||||
@@ -8809,6 +8933,10 @@ async fn builder_chain_health_optimistic_head() {
|
||||
|
||||
#[tokio::test(flavor = "multi_thread", worker_threads = 2)]
|
||||
async fn builder_chain_health_optimistic_head_v3() {
|
||||
// Gloas builder model is fundamentally different (bids, not payloads).
|
||||
if test_spec::<E>().is_gloas_scheduled() {
|
||||
return;
|
||||
}
|
||||
ApiTester::new_mev_tester()
|
||||
.await
|
||||
.test_builder_v3_chain_health_optimistic_head()
|
||||
@@ -9004,6 +9132,10 @@ async fn lighthouse_endpoints() {
|
||||
|
||||
#[tokio::test(flavor = "multi_thread", worker_threads = 2)]
|
||||
async fn optimistic_responses() {
|
||||
// Gloas builder model is fundamentally different (bids, not payloads).
|
||||
if test_spec::<E>().is_gloas_scheduled() {
|
||||
return;
|
||||
}
|
||||
ApiTester::new_with_hard_forks()
|
||||
.await
|
||||
.test_check_optimistic_responses()
|
||||
|
||||
Reference in New Issue
Block a user