Add skip-slots command (#1095)
This commit is contained in:
parent
90453181f8
commit
ebbc4e3630
@ -10,6 +10,7 @@ mod interop_genesis;
|
|||||||
mod new_testnet;
|
mod new_testnet;
|
||||||
mod parse_hex;
|
mod parse_hex;
|
||||||
mod refund_deposit_contract;
|
mod refund_deposit_contract;
|
||||||
|
mod skip_slots;
|
||||||
mod transition_blocks;
|
mod transition_blocks;
|
||||||
|
|
||||||
use clap::{App, Arg, ArgMatches, SubCommand};
|
use clap::{App, Arg, ArgMatches, SubCommand};
|
||||||
@ -77,6 +78,32 @@ fn main() {
|
|||||||
.help("Output file for generated state."),
|
.help("Output file for generated state."),
|
||||||
),
|
),
|
||||||
)
|
)
|
||||||
|
.subcommand(
|
||||||
|
SubCommand::with_name("skip-slots")
|
||||||
|
.about("Performs a state transition from some state across some number of skip slots")
|
||||||
|
.arg(
|
||||||
|
Arg::with_name("pre-state")
|
||||||
|
.value_name("BEACON_STATE")
|
||||||
|
.takes_value(true)
|
||||||
|
.required(true)
|
||||||
|
.help("Path to a SSZ file of the pre-state."),
|
||||||
|
)
|
||||||
|
.arg(
|
||||||
|
Arg::with_name("slots")
|
||||||
|
.value_name("SLOT_COUNT")
|
||||||
|
.takes_value(true)
|
||||||
|
.required(true)
|
||||||
|
.help("Number of slots to skip before outputting a state.."),
|
||||||
|
)
|
||||||
|
.arg(
|
||||||
|
Arg::with_name("output")
|
||||||
|
.value_name("SSZ_FILE")
|
||||||
|
.takes_value(true)
|
||||||
|
.required(true)
|
||||||
|
.default_value("./output.ssz")
|
||||||
|
.help("Path to output a SSZ file."),
|
||||||
|
),
|
||||||
|
)
|
||||||
.subcommand(
|
.subcommand(
|
||||||
SubCommand::with_name("transition-blocks")
|
SubCommand::with_name("transition-blocks")
|
||||||
.about("Performs a state transition given a pre-state and block")
|
.about("Performs a state transition given a pre-state and block")
|
||||||
@ -488,6 +515,9 @@ fn run<T: EthSpec>(env_builder: EnvironmentBuilder<T>, matches: &ArgMatches) ->
|
|||||||
}
|
}
|
||||||
("transition-blocks", Some(matches)) => run_transition_blocks::<T>(matches)
|
("transition-blocks", Some(matches)) => run_transition_blocks::<T>(matches)
|
||||||
.map_err(|e| format!("Failed to transition blocks: {}", e)),
|
.map_err(|e| format!("Failed to transition blocks: {}", e)),
|
||||||
|
("skip-slots", Some(matches)) => {
|
||||||
|
skip_slots::run::<T>(matches).map_err(|e| format!("Failed to skip slots: {}", e))
|
||||||
|
}
|
||||||
("pretty-hex", Some(matches)) => {
|
("pretty-hex", Some(matches)) => {
|
||||||
run_parse_hex::<T>(matches).map_err(|e| format!("Failed to pretty print hex: {}", e))
|
run_parse_hex::<T>(matches).map_err(|e| format!("Failed to pretty print hex: {}", e))
|
||||||
}
|
}
|
||||||
|
55
lcli/src/skip_slots.rs
Normal file
55
lcli/src/skip_slots.rs
Normal file
@ -0,0 +1,55 @@
|
|||||||
|
use crate::transition_blocks::load_from_ssz;
|
||||||
|
use clap::ArgMatches;
|
||||||
|
use ssz::Encode;
|
||||||
|
use state_processing::per_slot_processing;
|
||||||
|
use std::fs::File;
|
||||||
|
use std::io::prelude::*;
|
||||||
|
use std::path::PathBuf;
|
||||||
|
use types::{BeaconState, EthSpec};
|
||||||
|
|
||||||
|
pub fn run<T: EthSpec>(matches: &ArgMatches) -> Result<(), String> {
|
||||||
|
let pre_state_path = matches
|
||||||
|
.value_of("pre-state")
|
||||||
|
.ok_or_else(|| "No pre-state file supplied".to_string())?
|
||||||
|
.parse::<PathBuf>()
|
||||||
|
.map_err(|e| format!("Failed to parse pre-state path: {}", e))?;
|
||||||
|
|
||||||
|
let slots = matches
|
||||||
|
.value_of("slots")
|
||||||
|
.ok_or_else(|| "No slots supplied".to_string())?
|
||||||
|
.parse::<usize>()
|
||||||
|
.map_err(|e| format!("Failed to parse slots: {}", e))?;
|
||||||
|
|
||||||
|
let output_path = matches
|
||||||
|
.value_of("output")
|
||||||
|
.ok_or_else(|| "No output file supplied".to_string())?
|
||||||
|
.parse::<PathBuf>()
|
||||||
|
.map_err(|e| format!("Failed to parse output path: {}", e))?;
|
||||||
|
|
||||||
|
info!("Using minimal spec");
|
||||||
|
info!("Pre-state path: {:?}", pre_state_path);
|
||||||
|
info!("Slots: {:?}", slots);
|
||||||
|
|
||||||
|
let mut state: BeaconState<T> = load_from_ssz(pre_state_path)?;
|
||||||
|
|
||||||
|
let spec = &T::default_spec();
|
||||||
|
|
||||||
|
state
|
||||||
|
.build_all_caches(spec)
|
||||||
|
.map_err(|e| format!("Unable to build caches: {:?}", e))?;
|
||||||
|
|
||||||
|
// Transition the parent state to the block slot.
|
||||||
|
for i in 0..slots {
|
||||||
|
per_slot_processing(&mut state, None, spec)
|
||||||
|
.map_err(|e| format!("Failed to advance slot on iteration {}: {:?}", i, e))?;
|
||||||
|
}
|
||||||
|
|
||||||
|
let mut output_file =
|
||||||
|
File::create(output_path).map_err(|e| format!("Unable to create output file: {:?}", e))?;
|
||||||
|
|
||||||
|
output_file
|
||||||
|
.write_all(&state.as_ssz_bytes())
|
||||||
|
.map_err(|e| format!("Unable to write to output file: {:?}", e))?;
|
||||||
|
|
||||||
|
Ok(())
|
||||||
|
}
|
@ -76,7 +76,7 @@ fn do_transition<T: EthSpec>(
|
|||||||
Ok(pre_state)
|
Ok(pre_state)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn load_from_ssz<T: Decode>(path: PathBuf) -> Result<T, String> {
|
pub fn load_from_ssz<T: Decode>(path: PathBuf) -> Result<T, String> {
|
||||||
let mut file =
|
let mut file =
|
||||||
File::open(path.clone()).map_err(|e| format!("Unable to open file {:?}: {:?}", path, e))?;
|
File::open(path.clone()).map_err(|e| format!("Unable to open file {:?}: {:?}", path, e))?;
|
||||||
let mut bytes = vec![];
|
let mut bytes = vec![];
|
||||||
|
Loading…
Reference in New Issue
Block a user