mirror of
https://github.com/sigp/lighthouse.git
synced 2026-03-15 19:02:42 +00:00
* Use `E` for `EthSpec` globally * Fix tests * Merge branch 'unstable' into e-ethspec * Merge branch 'unstable' into e-ethspec # Conflicts: # beacon_node/execution_layer/src/engine_api.rs # beacon_node/execution_layer/src/engine_api/http.rs # beacon_node/execution_layer/src/engine_api/json_structures.rs # beacon_node/execution_layer/src/test_utils/handle_rpc.rs # beacon_node/store/src/partial_beacon_state.rs # consensus/types/src/beacon_block.rs # consensus/types/src/beacon_block_body.rs # consensus/types/src/beacon_state.rs # consensus/types/src/config_and_preset.rs # consensus/types/src/execution_payload.rs # consensus/types/src/execution_payload_header.rs # consensus/types/src/light_client_optimistic_update.rs # consensus/types/src/payload.rs # lcli/src/parse_ssz.rs
77 lines
2.6 KiB
Rust
77 lines
2.6 KiB
Rust
use crate::transition_blocks::load_from_ssz_with;
|
|
use clap::ArgMatches;
|
|
use clap_utils::{parse_optional, parse_required};
|
|
use environment::Environment;
|
|
use eth2::{types::StateId, BeaconNodeHttpClient, SensitiveUrl, Timeouts};
|
|
use eth2_network_config::Eth2NetworkConfig;
|
|
use std::path::PathBuf;
|
|
use std::time::{Duration, Instant};
|
|
use types::{BeaconState, EthSpec};
|
|
|
|
const HTTP_TIMEOUT: Duration = Duration::from_secs(10);
|
|
|
|
pub fn run<E: EthSpec>(
|
|
env: Environment<E>,
|
|
network_config: Eth2NetworkConfig,
|
|
matches: &ArgMatches,
|
|
) -> Result<(), String> {
|
|
let executor = env.core_context().executor;
|
|
|
|
let spec = &network_config.chain_spec::<E>()?;
|
|
|
|
let state_path: Option<PathBuf> = parse_optional(matches, "state-path")?;
|
|
let beacon_url: Option<SensitiveUrl> = parse_optional(matches, "beacon-url")?;
|
|
let runs: usize = parse_required(matches, "runs")?;
|
|
|
|
info!(
|
|
"Using {} network ({} spec)",
|
|
spec.config_name.as_deref().unwrap_or("unknown"),
|
|
E::spec_name()
|
|
);
|
|
info!("Doing {} runs", runs);
|
|
|
|
let state = match (state_path, beacon_url) {
|
|
(Some(state_path), None) => {
|
|
info!("State path: {:?}", state_path);
|
|
load_from_ssz_with(&state_path, spec, BeaconState::from_ssz_bytes)?
|
|
}
|
|
(None, Some(beacon_url)) => {
|
|
let state_id: StateId = parse_required(matches, "state-id")?;
|
|
let client = BeaconNodeHttpClient::new(beacon_url, Timeouts::set_all(HTTP_TIMEOUT));
|
|
executor
|
|
.handle()
|
|
.ok_or("shutdown in progress")?
|
|
.block_on(async move {
|
|
client
|
|
.get_debug_beacon_states::<E>(state_id)
|
|
.await
|
|
.map_err(|e| format!("Failed to download state: {:?}", e))
|
|
})
|
|
.map_err(|e| format!("Failed to complete task: {:?}", e))?
|
|
.ok_or_else(|| format!("Unable to locate state at {:?}", state_id))?
|
|
.data
|
|
}
|
|
_ => return Err("must supply either --state-path or --beacon-url".into()),
|
|
};
|
|
|
|
/*
|
|
* Perform the core "runs".
|
|
*/
|
|
let mut state_root = None;
|
|
for i in 0..runs {
|
|
let mut state = state.clone();
|
|
let timer = Instant::now();
|
|
state_root = Some(
|
|
state
|
|
.update_tree_hash_cache()
|
|
.map_err(|e| format!("error computing state root: {e:?}"))?,
|
|
);
|
|
info!("Run {}: {:?}", i, timer.elapsed());
|
|
}
|
|
|
|
if let Some(state_root) = state_root {
|
|
info!("State root is {:?}", state_root);
|
|
}
|
|
Ok(())
|
|
}
|