mirror of
https://github.com/sigp/lighthouse.git
synced 2026-03-14 18:32:42 +00:00
* persist light client updates * update beacon chain to serve light client updates * resolve todos * cache best update * extend cache parts * is better light client update * resolve merge conflict * initial api changes * add lc update db column * fmt * added tests * add sim * Merge branch 'unstable' of https://github.com/sigp/lighthouse into persist-light-client-updates * fix some weird issues with the simulator * tests * Merge branch 'unstable' of https://github.com/sigp/lighthouse into persist-light-client-updates * test changes * merge conflict * testing * started work on ef tests and some code clean up * update tests * linting * noop pre altair, were still failing on electra though * allow for zeroed light client header * Merge branch 'unstable' of https://github.com/sigp/lighthouse into persist-light-client-updates * merge unstable * remove unwraps * remove unwraps * Update light_client_update.rs * merge unstable * move functionality to helper methods * refactor is best update fn * refactor is best update fn * improve organization of light client server cache logic * fork diget calc, and only spawn as many blcoks as we need for the lc update test * fetch lc update from the cache if it exists * fmt * Fix beacon_chain tests * Add debug code to update ranking_order ef test * Fix compare code * merge conflicts * fix test * Merge branch 'persist-light-client-updates' of https://github.com/eserilev/lighthouse into persist-light-client-updates * Use blinded blocks for light client proofs * fix ef test * merge conflicts * fix lc update check * Lint * resolve merge conflict * Merge branch 'persist-light-client-updates' of https://github.com/eserilev/lighthouse into persist-light-client-updates * revert basic sim * small fix * revert sim * Review PR * resolve merge conflicts * Merge branch 'unstable' into persist-light-client-updates
122 lines
3.4 KiB
Rust
122 lines
3.4 KiB
Rust
use super::*;
|
|
use rayon::prelude::*;
|
|
use std::fmt::Debug;
|
|
use std::path::{Path, PathBuf};
|
|
use types::ForkName;
|
|
|
|
mod bls_aggregate_sigs;
|
|
mod bls_aggregate_verify;
|
|
mod bls_batch_verify;
|
|
mod bls_eth_aggregate_pubkeys;
|
|
mod bls_eth_fast_aggregate_verify;
|
|
mod bls_fast_aggregate_verify;
|
|
mod bls_sign_msg;
|
|
mod bls_verify_msg;
|
|
mod common;
|
|
mod epoch_processing;
|
|
mod fork;
|
|
mod fork_choice;
|
|
mod genesis_initialization;
|
|
mod genesis_validity;
|
|
mod kzg_blob_to_kzg_commitment;
|
|
mod kzg_compute_blob_kzg_proof;
|
|
mod kzg_compute_kzg_proof;
|
|
mod kzg_verify_blob_kzg_proof;
|
|
mod kzg_verify_blob_kzg_proof_batch;
|
|
mod kzg_verify_kzg_proof;
|
|
mod light_client_verify_is_better_update;
|
|
mod merkle_proof_validity;
|
|
mod operations;
|
|
mod rewards;
|
|
mod sanity_blocks;
|
|
mod sanity_slots;
|
|
mod shuffling;
|
|
mod ssz_generic;
|
|
mod ssz_static;
|
|
mod transition;
|
|
|
|
pub use self::fork_choice::*;
|
|
pub use bls_aggregate_sigs::*;
|
|
pub use bls_aggregate_verify::*;
|
|
pub use bls_batch_verify::*;
|
|
pub use bls_eth_aggregate_pubkeys::*;
|
|
pub use bls_eth_fast_aggregate_verify::*;
|
|
pub use bls_fast_aggregate_verify::*;
|
|
pub use bls_sign_msg::*;
|
|
pub use bls_verify_msg::*;
|
|
pub use common::SszStaticType;
|
|
pub use epoch_processing::*;
|
|
pub use fork::ForkTest;
|
|
pub use genesis_initialization::*;
|
|
pub use genesis_validity::*;
|
|
pub use kzg_blob_to_kzg_commitment::*;
|
|
pub use kzg_compute_blob_kzg_proof::*;
|
|
pub use kzg_compute_kzg_proof::*;
|
|
pub use kzg_verify_blob_kzg_proof::*;
|
|
pub use kzg_verify_blob_kzg_proof_batch::*;
|
|
pub use kzg_verify_kzg_proof::*;
|
|
pub use light_client_verify_is_better_update::*;
|
|
pub use merkle_proof_validity::*;
|
|
pub use operations::*;
|
|
pub use rewards::RewardsTest;
|
|
pub use sanity_blocks::*;
|
|
pub use sanity_slots::*;
|
|
pub use shuffling::*;
|
|
pub use ssz_generic::*;
|
|
pub use ssz_static::*;
|
|
pub use transition::TransitionTest;
|
|
|
|
pub trait LoadCase: Sized {
|
|
/// Load the test case from a test case directory.
|
|
fn load_from_dir(_path: &Path, _fork_name: ForkName) -> Result<Self, Error>;
|
|
}
|
|
|
|
pub trait Case: Debug + Sync {
|
|
/// An optional field for implementing a custom description.
|
|
///
|
|
/// Defaults to "no description".
|
|
fn description(&self) -> String {
|
|
"no description".to_string()
|
|
}
|
|
|
|
/// Whether or not this test exists for the given `fork_name`.
|
|
///
|
|
/// Returns `true` by default.
|
|
fn is_enabled_for_fork(_fork_name: ForkName) -> bool {
|
|
true
|
|
}
|
|
|
|
/// Execute a test and return the result.
|
|
///
|
|
/// `case_index` reports the index of the case in the set of test cases. It is not strictly
|
|
/// necessary, but it's useful when troubleshooting specific failing tests.
|
|
fn result(&self, case_index: usize, fork_name: ForkName) -> Result<(), Error>;
|
|
}
|
|
|
|
#[derive(Debug)]
|
|
pub struct Cases<T> {
|
|
pub test_cases: Vec<(PathBuf, T)>,
|
|
}
|
|
|
|
impl<T: Case> Cases<T> {
|
|
pub fn test_results(&self, fork_name: ForkName, use_rayon: bool) -> Vec<CaseResult> {
|
|
if use_rayon {
|
|
self.test_cases
|
|
.into_par_iter()
|
|
.enumerate()
|
|
.map(|(i, (ref path, ref tc))| {
|
|
CaseResult::new(i, path, tc, tc.result(i, fork_name))
|
|
})
|
|
.collect()
|
|
} else {
|
|
self.test_cases
|
|
.iter()
|
|
.enumerate()
|
|
.map(|(i, (ref path, ref tc))| {
|
|
CaseResult::new(i, path, tc, tc.result(i, fork_name))
|
|
})
|
|
.collect()
|
|
}
|
|
}
|
|
}
|