Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add test to beacon node fallback feature #6568

Open
wants to merge 116 commits into
base: unstable
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 84 commits
Commits
Show all changes
116 commits
Select commit Hold shift + click to select a range
71ee4cf
Rework Validator Client fallback mechanism
macladson Jun 13, 2023
52f2be5
Add CI workflow for fallback simulator
macladson Jun 13, 2023
ce4df50
Tie-break with sync distance for non-synced nodes
macladson Jun 13, 2023
6262013
Fix simulator
macladson Jun 13, 2023
f5154be
Cleanup unused code
macladson Jun 14, 2023
d659671
More improvements
macladson Jun 14, 2023
dbce701
Add IsOptimistic enum for readability
macladson Jun 15, 2023
774eb91
Use configurable sync distance tiers
macladson Jun 16, 2023
d839620
Fix tests
macladson Jun 19, 2023
5153aff
Combine status and health and improve logging
macladson Jun 21, 2023
61bc700
Fix nodes not being marked as available
macladson Jun 22, 2023
1295685
Fix simulator
macladson Jul 21, 2023
59c6b09
Fix tests again
macladson Jul 24, 2023
6fc12e6
Increase fallback simulator tolerance
macladson Jul 24, 2023
c9bb547
Add http api endpoint
macladson Aug 1, 2023
b25a135
Fix todos and tests
macladson Aug 1, 2023
23f68ad
Update simulator
macladson Aug 2, 2023
235c452
Merge branch 'unstable' into vc-fallback
macladson Nov 2, 2023
1d70441
Add suggestions
macladson Nov 3, 2023
4ddfc7d
Add id to ui endpoint
macladson Nov 3, 2023
21c34c2
Remove unnecessary clones
macladson Nov 3, 2023
ba92f5d
Formatting
macladson Nov 3, 2023
f87ab63
Merge branch 'unstable' into vc-fallback
macladson Dec 1, 2023
88ebe36
Merge branch 'unstable' into vc-fallback
macladson Dec 13, 2023
6117cef
Fix flag tests
macladson Dec 13, 2023
6dc44b2
Merge branch 'unstable' into vc-fallback
macladson Jan 5, 2024
e555dc9
Merge branch 'unstable' into vc-fallback
macladson Jan 16, 2024
ba32239
Fix conflicts
macladson Jan 16, 2024
5672afe
Merge branch 'unstable' into vc-fallback
macladson Jan 31, 2024
1802080
Remove unnecessary pubs
macladson Feb 1, 2024
a5e9348
Simplify `compute_distance_tier` and reduce notifier awaits
macladson Feb 1, 2024
e368397
Use the more descriptive `user_index` instead of `id`
macladson Feb 5, 2024
ee75a72
Combine sync distance tolerance flags into one
macladson Feb 6, 2024
1d9dc26
Merge branch 'unstable' into vc-fallback
macladson Apr 15, 2024
9897626
Merge branch 'unstable' into vc-fallback
macladson Apr 26, 2024
4c5dd67
wip
macladson Apr 26, 2024
85443e8
Use new simulator from unstable
macladson Apr 26, 2024
037448b
Fix cli text
macladson Apr 26, 2024
b72d219
Remove leftover files
macladson Apr 26, 2024
7e3866a
Remove old commented code
macladson Apr 26, 2024
7f574b3
Merge branch 'unstable' into vc-fallback
macladson Jun 5, 2024
e348231
Update cli text
macladson Jun 5, 2024
5c8dc21
Silence candidate errors when pre-genesis
macladson Jun 6, 2024
3d5e277
Merge branch 'unstable' into vc-fallback
macladson Jun 27, 2024
a431d94
Merge branch 'unstable' into vc-fallback
macladson Jul 8, 2024
c373891
Retry on failure
macladson Jul 16, 2024
95466f0
Merge branch 'unstable' into vc-fallback
macladson Jul 16, 2024
517fae9
Merge branch 'unstable' into vc-fallback
macladson Jul 23, 2024
453e003
Remove disable_run_on_all
macladson Jul 24, 2024
500dbe5
Remove unused error variant
macladson Jul 24, 2024
a63ec8f
Fix out of date comment
macladson Jul 24, 2024
8aa97a8
Merge branch 'unstable' into vc-fallback
macladson Jul 25, 2024
1653484
Remove unnecessary as_u64
macladson Jul 25, 2024
9c206d5
Remove more out of date comments
macladson Jul 25, 2024
526a894
Use tokio RwLock and remove parking_lot
macladson Aug 19, 2024
1fdb4ec
Merge branch 'unstable' into vc-fallback
macladson Aug 19, 2024
2de68ed
Formatting
macladson Aug 19, 2024
4bf2f59
Ensure nodes are still added to total when not available
macladson Aug 22, 2024
4c55b03
Allow VC to detect when BN comes online
macladson Aug 22, 2024
5cc2c13
Fix ui endpoint
macladson Aug 22, 2024
b5445a0
Don't have block_service as an Option
macladson Aug 23, 2024
2675f0d
Merge branch 'unstable' into vc-fallback
macladson Aug 23, 2024
7eab573
Clean up lifetimes and futures
michaelsproul Sep 2, 2024
fff8637
Revert "Don't have block_service as an Option"
macladson Sep 11, 2024
5a55bd6
Merge branch 'unstable' into vc-fallback
macladson Sep 11, 2024
4052827
Merge branch 'unstable' into vc-fallback
jimmygchen Sep 30, 2024
c0afb96
Initial validator test setup.
jimmygchen Oct 1, 2024
464a110
Jimmy's guidance
chong-he Oct 24, 2024
0bf34c4
vc fallback
chong-he Oct 24, 2024
245a1bc
Fix fallback test.
jimmygchen Oct 24, 2024
c0b7a4b
blinded
chong-he Oct 24, 2024
433f753
Merge remote-tracking branch 'Jimmy/vc-fallback-test' into vc-fallbac…
chong-he Oct 29, 2024
00adb54
Store blocks and add test
chong-he Nov 5, 2024
e59fd3a
Changed to signed
chong-he Nov 5, 2024
8d2c669
Minor revisision
chong-he Nov 5, 2024
dcfe832
Add update_all_candidate
chong-he Nov 5, 2024
2ace7c7
first_beacon_node
chong-he Nov 5, 2024
e87f9b9
sync status
chong-he Nov 6, 2024
9b81cc0
Complete `update_all_candidates` test.
jimmygchen Nov 6, 2024
6f23a55
Merge branch 'unstable' into vc-fallback-test
jimmygchen Nov 6, 2024
ed63f70
Fix clippy
chong-he Nov 6, 2024
77c59db
temporarily disable storing blocks test
chong-he Nov 6, 2024
dc97d8a
commented
chong-he Nov 6, 2024
24c243a
ssz
chong-he Nov 6, 2024
93c7b02
Update validator_client/src/beacon_node_fallback.rs
chong-he Nov 7, 2024
636345a
Simplify
chong-he Nov 8, 2024
6d60826
Add first_success test
chong-he Nov 20, 2024
79acbf7
Merge remote-tracking branch 'origin/unstable' into vc-fallback-test
chong-he Nov 21, 2024
3c536dc
Fix
chong-he Nov 21, 2024
8a0d98b
Try to fix
chong-he Nov 22, 2024
3fe3e64
Try to fix
chong-he Nov 22, 2024
cccdc50
small change
chong-he Nov 22, 2024
06af376
Fix test compile
chong-he Nov 26, 2024
20d0f6f
Fix test compile
chong-he Nov 26, 2024
820d056
Move around files
chong-he Dec 8, 2024
e0c74f0
Merge branch 'unstable' into vc-fallback-test
chong-he Dec 8, 2024
eb92dd5
Fix compilation issue and clean up.
jimmygchen Dec 10, 2024
aa67fad
Remove unnecessary changes.
jimmygchen Dec 10, 2024
77702fa
Merge branch 'unstable' into vc-fallback-test
jimmygchen Dec 10, 2024
a59a59a
Remove unused dependency
chong-he Dec 10, 2024
807c6d2
Merge branch 'vc-fallback-test' of https://github.com/chong-he/lighth…
chong-he Dec 10, 2024
e30b2f0
Merge branch 'unstable' into vc-fallback-test
chong-he Dec 19, 2024
1f6a7d1
test rig cargo.toml
chong-he Dec 19, 2024
3d69f09
sort validator_test_rig dependency
chong-he Dec 19, 2024
49ea48a
main Cargo.toml
chong-he Dec 19, 2024
7c27440
Update Cargo.toml
chong-he Dec 19, 2024
61fbe20
Remove unused dependency
chong-he Dec 19, 2024
8376b9b
Minor rearrange
chong-he Dec 24, 2024
46d15b9
Add mock1 and mock2 expect assert
chong-he Dec 24, 2024
a406704
remove debug
chong-he Dec 24, 2024
7fbcf3a
Remove unused deps
chong-he Jan 3, 2025
53a9100
Cargo.lock
chong-he Jan 3, 2025
82e6d5a
Remove deps and simplify
chong-he Jan 3, 2025
2d0952f
Remove deps
chong-he Jan 6, 2025
99ffa61
Merge branch 'unstable' into vc-fallback-test
chong-he Jan 6, 2025
a23adf3
minor grammar
chong-he Jan 6, 2025
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
86 changes: 84 additions & 2 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 2 additions & 0 deletions Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -138,6 +138,7 @@ log = "0.4"
lru = "0.12"
maplit = "1"
milhouse = "0.3"
mockito = "1.5.0"
num_cpus = "1"
parking_lot = "0.12"
paste = "1"
Expand Down Expand Up @@ -224,6 +225,7 @@ malloc_utils = { path = "common/malloc_utils" }
merkle_proof = { path = "consensus/merkle_proof" }
monitoring_api = { path = "common/monitoring_api" }
network = { path = "beacon_node/network" }
node_test_rig = { path = "testing/node_test_rig"}
operation_pool = { path = "beacon_node/operation_pool" }
pretty_reqwest_error = { path = "common/pretty_reqwest_error" }
proto_array = { path = "consensus/proto_array" }
Expand Down
1 change: 0 additions & 1 deletion lighthouse/tests/validator_client.rs
Original file line number Diff line number Diff line change
Expand Up @@ -506,7 +506,6 @@ fn monitoring_endpoint() {
assert_eq!(api_conf.update_period_secs, Some(30));
});
}

#[test]
fn no_broadcast_flag() {
CommandLineTest::new().run().with_config(|config| {
Expand Down
5 changes: 5 additions & 0 deletions validator_client/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,11 @@ path = "src/lib.rs"

[dev-dependencies]
tokio = { workspace = true }
eth2_config = { workspace = true }
node_test_rig = { workspace = true }
mockito = { workspace = true }
regex = { workspace = true }
env_logger = { workspace = true }

[dependencies]
tree_hash = { workspace = true }
Expand Down
155 changes: 153 additions & 2 deletions validator_client/src/beacon_node_fallback.rs
Original file line number Diff line number Diff line change
Expand Up @@ -737,13 +737,21 @@ impl ApiTopic {

#[cfg(test)]
mod tests {
use super::*;
use crate::beacon_node_health::BeaconNodeHealthTier;
use crate::SensitiveUrl;
use eth2::Timeouts;
use logging::test_logger;
use std::str::FromStr;
use strum::VariantNames;
use types::{MainnetEthSpec, Slot};
use types::EmptyBlock;

use slot_clock::TestingSlotClock;
use types::{BeaconBlockDeneb, BlindedBeaconBlock, MainnetEthSpec, Slot};

use super::*;
use crate::block_service::{BlockService, BlockServiceBuilder, UnsignedBlock};
use crate::testing::mock_beacon_node::MockBeaconNode;
use crate::testing::validator_test_rig::ValidatorTestRig;

type E = MainnetEthSpec;

Expand Down Expand Up @@ -867,4 +875,147 @@ mod tests {

assert_eq!(candidates, expected_candidates);
}

#[tokio::test]
async fn update_all_candidates_should_update_sync_status() {
let spec = Arc::new(MainnetEthSpec::default_spec());
let mut mock_beacon_node_one = MockBeaconNode::<E>::new().await;
let mut mock_beacon_node_two = MockBeaconNode::<E>::new().await;
let mut mock_beacon_node_three = MockBeaconNode::<E>::new().await;

let beacon_node_one =
CandidateBeaconNode::<E>::new(mock_beacon_node_one.beacon_api_client.clone(), 0);
let beacon_node_two =
CandidateBeaconNode::<E>::new(mock_beacon_node_two.beacon_api_client.clone(), 1);
let beacon_node_three =
CandidateBeaconNode::<E>::new(mock_beacon_node_three.beacon_api_client.clone(), 2);

let mut beacon_node_fallback: BeaconNodeFallback<TestingSlotClock, E> =
BeaconNodeFallback::new(
// Put this out of order to be sorted later
vec![
beacon_node_two.clone(),
beacon_node_three.clone(),
beacon_node_one.clone(),
],
Config::default(),
vec![], // to broadcast blocks to both bns
chong-he marked this conversation as resolved.
Show resolved Hide resolved
spec.clone(),
test_logger(),
);

beacon_node_fallback.set_slot_clock(TestingSlotClock::new(
Slot::new(1),
Duration::from_secs(0),
Duration::from_secs(12),
));

mock_beacon_node_one.mock_config_spec(&spec);
mock_beacon_node_two.mock_config_spec(&spec);
mock_beacon_node_three.mock_config_spec(&spec);

// BeaconNodeHealthTier 1
mock_beacon_node_one.mock_get_node_syncing(eth2::types::SyncingData {
is_syncing: false,
is_optimistic: false,
el_offline: false,
head_slot: Slot::new(1),
sync_distance: Slot::new(0),
});
// BeaconNodeHealthTier 3
mock_beacon_node_two.mock_get_node_syncing(eth2::types::SyncingData {
is_syncing: false,
is_optimistic: false,
el_offline: true,
head_slot: Slot::new(1),
sync_distance: Slot::new(0),
});
// BeaconNodeHealthTier 5
mock_beacon_node_three.mock_get_node_syncing(eth2::types::SyncingData {
is_syncing: false,
is_optimistic: true,
el_offline: false,
head_slot: Slot::new(1),
sync_distance: Slot::new(0),
});

beacon_node_fallback.update_all_candidates().await;

let candidates = beacon_node_fallback.candidates.read().await;
assert_eq!(
vec![beacon_node_one, beacon_node_two, beacon_node_three],
*candidates
);
}

#[tokio::test]
async fn broadcast_should_send_to_all_bns() {
let test_rig = ValidatorTestRig::new().await;
let mut mock_beacon_node_one = MockBeaconNode::<E>::new().await;
let mut mock_beacon_node_two = MockBeaconNode::<E>::new().await;

let beacon_node_one =
CandidateBeaconNode::new(mock_beacon_node_one.beacon_api_client.clone(), 0);
let beacon_node_two =
CandidateBeaconNode::new(mock_beacon_node_two.beacon_api_client.clone(), 1);

let mut beacon_node_fallback = BeaconNodeFallback::new(
vec![beacon_node_one, beacon_node_two],
Config::default(),
vec![ApiTopic::Blocks], // to broadcast blocks to both bns
test_rig.spec.clone(),
test_rig.logger.clone(),
);

beacon_node_fallback.set_slot_clock(TestingSlotClock::new(
Slot::new(1),
Duration::from_secs(0),
Duration::from_secs(12),
));

mock_beacon_node_one.mock_config_spec(&test_rig.spec);
mock_beacon_node_two.mock_config_spec(&test_rig.spec);

let mock1 = mock_beacon_node_one.mock_post_beacon_blinded_blocks_v2(Duration::from_secs(0));
let mock2 = mock_beacon_node_two.mock_post_beacon_blinded_blocks_v2(Duration::from_secs(0));

let beacon_node_fallback = Arc::new(beacon_node_fallback);
let block_service: BlockService<TestingSlotClock, MainnetEthSpec> =
BlockServiceBuilder::new()
.slot_clock(test_rig.slot_clock)
.validator_store(test_rig.validator_store.clone())
.beacon_nodes(beacon_node_fallback.clone())
.runtime_context(test_rig.runtime_context)
.build()
.unwrap();

beacon_node_fallback.update_all_candidates().await;

let validators = test_rig.validator_store.initialized_validators();
let first_validator_pubkey = {
let validators = validators.read();
if let Some(first_validator) = validators.validator_definitions().first() {
first_validator.voting_public_key.clone()
} else {
panic!("No validators found");
}
};
let unsigned_block = UnsignedBlock::Blinded(BlindedBeaconBlock::Deneb(
BeaconBlockDeneb::empty(&test_rig.spec),
));

let result = block_service
.publish_block_for_testing(Slot::new(1), &first_validator_pubkey.into(), unsigned_block)
.await;
assert!(result.is_ok());

mock1.expect(1).assert();
mock2.expect(1).assert();

let received_blocks_one = mock_beacon_node_one.received_blocks.lock().unwrap();
let received_blocks_two = mock_beacon_node_two.received_blocks.lock().unwrap();

assert_eq!(received_blocks_one.len(), 1);
assert_eq!(received_blocks_two.len(), 1);
}
}
Loading
Loading