-pub struct NodeCfg {
- pub chain_monitor: Arc<chaininterface::ChainWatchInterfaceUtil>,
- pub tx_broadcaster: Arc<test_utils::TestBroadcaster>,
- pub fee_estimator: Arc<test_utils::TestFeeEstimator>,
- pub chan_monitor: test_utils::TestChannelMonitor,
- pub keys_manager: Arc<test_utils::TestKeysInterface>,
- pub logger: Arc<test_utils::TestLogger>,
+pub fn connect_block<'a, 'b, 'c, 'd>(node: &'a Node<'b, 'c, 'd>, block: &Block) {
+ let txdata: Vec<_> = block.txdata.iter().enumerate().collect();
+ let height = node.best_block_info().1 + 1;
+ node.chain_monitor.chain_monitor.block_connected(&block.header, &txdata, height);
+ node.node.block_connected(&block.header, &txdata, height);
+ node.node.test_process_background_events();
+ node.blocks.borrow_mut().push((block.header, height));
+}
+
+pub fn disconnect_blocks<'a, 'b, 'c, 'd>(node: &'a Node<'b, 'c, 'd>, count: u32) {
+ for _ in 0..count {
+ let orig_header = node.blocks.borrow_mut().pop().unwrap();
+ assert!(orig_header.1 > 0); // Cannot disconnect genesis
+ node.chain_monitor.chain_monitor.block_disconnected(&orig_header.0, orig_header.1);
+ node.node.block_disconnected(&orig_header.0);
+ }
+}
+
+pub fn disconnect_all_blocks<'a, 'b, 'c, 'd>(node: &'a Node<'b, 'c, 'd>) {
+ let count = node.blocks.borrow_mut().len() as u32 - 1;
+ disconnect_blocks(node, count);
+}
+
+pub struct TestChanMonCfg {
+ pub tx_broadcaster: test_utils::TestBroadcaster,
+ pub fee_estimator: test_utils::TestFeeEstimator,
+ pub chain_source: test_utils::TestChainSource,
+ pub persister: test_utils::TestPersister,
+ pub logger: test_utils::TestLogger,
+ pub keys_manager: test_utils::TestKeysInterface,
+}
+
+pub struct NodeCfg<'a> {
+ pub chain_source: &'a test_utils::TestChainSource,
+ pub tx_broadcaster: &'a test_utils::TestBroadcaster,
+ pub fee_estimator: &'a test_utils::TestFeeEstimator,
+ pub chain_monitor: test_utils::TestChainMonitor<'a>,
+ pub keys_manager: &'a test_utils::TestKeysInterface,
+ pub logger: &'a test_utils::TestLogger,