use std::sync::Arc; use config::{networks, Config}; use consensus::{rpc::mock_rpc::MockRpc, ConsensusClient}; async fn setup() -> ConsensusClient<MockRpc> { let base_config = networks::goerli(); let config = Config { consensus_rpc: String::new(), execution_rpc: String::new(), chain: base_config.chain, forks: base_config.forks, max_checkpoint_age: 123123123, ..Default::default() }; let checkpoint = hex::decode("1e591af1e90f2db918b2a132991c7c2ee9a4ab26da496bd6e71e4f0bd65ea870").unwrap(); ConsensusClient::new("testdata/", &checkpoint, Arc::new(config)).unwrap() } #[tokio::test] async fn test_sync() { let mut client = setup().await; client.sync().await.unwrap(); let head = client.get_header(); assert_eq!(head.slot, 3818196); let finalized_head = client.get_finalized_header(); assert_eq!(finalized_head.slot, 3818112); } #[tokio::test] async fn test_get_payload() { let mut client = setup().await; client.sync().await.unwrap(); let payload = client.get_execution_payload(&None).await.unwrap(); assert_eq!(payload.block_number, 7530932); }