mirror of
https://github.com/sigp/lighthouse.git
synced 2026-03-17 20:02:43 +00:00
* Update to spec v0.9.0 * Update to v0.9.1 * Bump spec tags for v0.9.1 * Formatting, fix CI failures * Resolve accidental KeyPair merge conflict * Document new BeaconState functions * Add `validator` changes from `validator-to-rest` * Add initial (failing) REST api tests * Fix signature parsing * Add more tests * Refactor http router * Add working tests for publish beacon block * Add validator duties tests * Move account_manager under `lighthouse` binary * Unify logfile handling in `environment` crate. * Fix incorrect cache drops in `advance_caches` * Update fork choice for v0.9.1 * Add `deposit_contract` crate * Add progress on validator onboarding * Add unfinished attesation code * Update account manager CLI * Write eth1 data file as hex string * Integrate ValidatorDirectory with validator_client * Move ValidatorDirectory into validator_client * Clean up some FIXMEs * Add beacon_chain_sim * Fix a few docs/logs * Expand `beacon_chain_sim` * Fix spec for `beacon_chain_sim * More testing for api * Start work on attestation endpoint * Reject empty attestations * Allow attestations to genesis block * Add working tests for `rest_api` validator endpoint * Remove grpc from beacon_node * Start heavy refactor of validator client - Block production is working * Prune old validator client files * Start works on attestation service * Add attestation service to validator client * Use full pubkey for validator directories * Add validator duties post endpoint * Use par_iter for keypair generation * Use bulk duties request in validator client * Add version http endpoint tests * Add interop keys and startup wait * Ensure a prompt exit * Add duties pruning * Fix compile error in beacon node tests * Add github workflow * Modify rust.yaml * Modify gitlab actions * Add to CI file * Add sudo to CI npm install * Move cargo fmt to own job in tests * Fix cargo fmt in CI * Add rustup update before cargo fmt * Change name of CI job * Make other CI jobs require cargo fmt * Add CI badge * Remove gitlab and travis files * Add different http timeout for debug * Update docker file, use makefile in CI * Use make in the dockerfile, skip the test * Use the makefile for debug GI test * Update book * Tidy grpc and misc things * Apply discv5 fixes * Address other minor issues * Fix warnings * Attempt fix for addr parsing * Tidy validator config, CLIs * Tidy comments * Tidy signing, reduce ForkService duplication * Fail if skipping too many slots * Set default recent genesis time to 0 * Add custom http timeout to validator * Fix compile bug in node_test_rig * Remove old bootstrap flag from val CLI * Update docs * Tidy val client * Change val client log levels * Add comments, more validity checks * Fix compile error, add comments * Undo changes to eth2-libp2p/src * Reduce duplication of keypair generation * Add more logging for validator duties * Fix beacon_chain_sim, nitpicks * Fix compile error, minor nits * Address Michael's comments
132 lines
3.9 KiB
Rust
132 lines
3.9 KiB
Rust
use node_test_rig::{
|
|
environment::{Environment, EnvironmentBuilder, RuntimeContext},
|
|
testing_client_config, ClientConfig, ClientGenesis, LocalBeaconNode, LocalValidatorClient,
|
|
ProductionClient, ValidatorConfig,
|
|
};
|
|
use std::time::{SystemTime, UNIX_EPOCH};
|
|
use types::EthSpec;
|
|
|
|
pub type BeaconNode<E> = LocalBeaconNode<ProductionClient<E>>;
|
|
|
|
fn main() {
|
|
let nodes = 4;
|
|
let validators_per_node = 64 / nodes;
|
|
|
|
match simulation(nodes, validators_per_node) {
|
|
Ok(()) => println!("Simulation exited successfully"),
|
|
Err(e) => println!("Simulation exited with error: {}", e),
|
|
}
|
|
}
|
|
|
|
fn simulation(num_nodes: usize, validators_per_node: usize) -> Result<(), String> {
|
|
if num_nodes < 1 {
|
|
return Err("Must have at least one node".into());
|
|
}
|
|
|
|
let mut env = EnvironmentBuilder::minimal()
|
|
.async_logger("debug")?
|
|
.multi_threaded_tokio_runtime()?
|
|
.build()?;
|
|
|
|
let mut base_config = testing_client_config();
|
|
|
|
let now = SystemTime::now()
|
|
.duration_since(UNIX_EPOCH)
|
|
.expect("should get system time")
|
|
.as_secs();
|
|
base_config.genesis = ClientGenesis::Interop {
|
|
genesis_time: now,
|
|
validator_count: num_nodes * validators_per_node,
|
|
};
|
|
|
|
let boot_node =
|
|
BeaconNode::production(env.service_context("boot_node".into()), base_config.clone());
|
|
|
|
let mut nodes = (1..num_nodes)
|
|
.map(|i| {
|
|
let context = env.service_context(format!("node_{}", i));
|
|
new_with_bootnode_via_enr(context, &boot_node, base_config.clone())
|
|
})
|
|
.collect::<Vec<_>>();
|
|
|
|
let _validators = nodes
|
|
.iter()
|
|
.enumerate()
|
|
.map(|(i, node)| {
|
|
let mut context = env.service_context(format!("validator_{}", i));
|
|
|
|
// Pull the spec from the beacon node's beacon chain, in case there were some changes
|
|
// to the spec after the node booted.
|
|
context.eth2_config.spec = node
|
|
.client
|
|
.beacon_chain()
|
|
.expect("should have beacon chain")
|
|
.spec
|
|
.clone();
|
|
|
|
let context = env.service_context(format!("validator_{}", i));
|
|
|
|
let indices =
|
|
(i * validators_per_node..(i + 1) * validators_per_node).collect::<Vec<_>>();
|
|
new_validator_client(
|
|
&mut env,
|
|
context,
|
|
node,
|
|
ValidatorConfig::default(),
|
|
&indices,
|
|
)
|
|
})
|
|
.collect::<Vec<_>>();
|
|
|
|
nodes.insert(0, boot_node);
|
|
|
|
env.block_until_ctrl_c()?;
|
|
|
|
Ok(())
|
|
}
|
|
|
|
// TODO: this function does not result in nodes connecting to each other. This is a bug due to
|
|
// using a 0 port for discovery. Age is fixing it.
|
|
fn new_with_bootnode_via_enr<E: EthSpec>(
|
|
context: RuntimeContext<E>,
|
|
boot_node: &BeaconNode<E>,
|
|
base_config: ClientConfig,
|
|
) -> BeaconNode<E> {
|
|
let mut config = base_config;
|
|
config.network.boot_nodes.push(
|
|
boot_node
|
|
.client
|
|
.enr()
|
|
.expect("bootnode must have a network"),
|
|
);
|
|
|
|
BeaconNode::production(context, config)
|
|
}
|
|
|
|
// Note: this function will block until the validator can connect to the beaco node. It is
|
|
// recommended to ensure that the beacon node is running first.
|
|
fn new_validator_client<E: EthSpec>(
|
|
env: &mut Environment<E>,
|
|
context: RuntimeContext<E>,
|
|
beacon_node: &BeaconNode<E>,
|
|
base_config: ValidatorConfig,
|
|
keypair_indices: &[usize],
|
|
) -> LocalValidatorClient<E> {
|
|
let mut config = base_config;
|
|
|
|
let socket_addr = beacon_node
|
|
.client
|
|
.http_listen_addr()
|
|
.expect("Must have http started");
|
|
|
|
config.http_server = format!("http://{}:{}", socket_addr.ip(), socket_addr.port());
|
|
|
|
env.runtime()
|
|
.block_on(LocalValidatorClient::production_with_insecure_keypairs(
|
|
context,
|
|
config,
|
|
keypair_indices,
|
|
))
|
|
.expect("should start validator")
|
|
}
|