mirror of
https://github.com/lightningdevkit/rust-lightning.git
synced 2025-02-24 15:02:20 +01:00
multi: update ChannelManager tx broadcaster from Arc to Deref
This commit is contained in:
parent
f952cc27d6
commit
d768cc234e
11 changed files with 372 additions and 206 deletions
|
@ -75,7 +75,7 @@ impl Writer for VecWriter {
|
|||
|
||||
static mut IN_RESTORE: bool = false;
|
||||
pub struct TestChannelMonitor {
|
||||
pub simple_monitor: Arc<channelmonitor::SimpleManyChannelMonitor<OutPoint, EnforcingChannelKeys>>,
|
||||
pub simple_monitor: Arc<channelmonitor::SimpleManyChannelMonitor<OutPoint, EnforcingChannelKeys, Arc<chaininterface::BroadcasterInterface>>>,
|
||||
pub update_ret: Mutex<Result<(), channelmonitor::ChannelMonitorUpdateErr>>,
|
||||
pub latest_good_update: Mutex<HashMap<OutPoint, Vec<u8>>>,
|
||||
pub latest_update_good: Mutex<HashMap<OutPoint, bool>>,
|
||||
|
@ -230,7 +230,7 @@ pub fn do_test(data: &[u8]) {
|
|||
channel_monitors: &mut monitor_refs,
|
||||
};
|
||||
|
||||
let res = (<(Sha256d, ChannelManager<EnforcingChannelKeys, Arc<TestChannelMonitor>>)>::read(&mut Cursor::new(&$ser.0), read_args).expect("Failed to read manager").1, monitor);
|
||||
let res = (<(Sha256d, ChannelManager<EnforcingChannelKeys, Arc<TestChannelMonitor>, Arc<TestBroadcaster>>)>::read(&mut Cursor::new(&$ser.0), read_args).expect("Failed to read manager").1, monitor);
|
||||
for (_, was_good) in $old_monitors.latest_updates_good_at_last_ser.lock().unwrap().iter() {
|
||||
if !was_good {
|
||||
// If the last time we updated a monitor we didn't successfully update (and we
|
||||
|
|
|
@ -136,9 +136,9 @@ impl<'a> Hash for Peer<'a> {
|
|||
}
|
||||
|
||||
struct MoneyLossDetector<'a> {
|
||||
manager: Arc<ChannelManager<EnforcingChannelKeys, Arc<channelmonitor::SimpleManyChannelMonitor<OutPoint, EnforcingChannelKeys>>>>,
|
||||
monitor: Arc<channelmonitor::SimpleManyChannelMonitor<OutPoint, EnforcingChannelKeys>>,
|
||||
handler: PeerManager<Peer<'a>, Arc<ChannelManager<EnforcingChannelKeys, Arc<channelmonitor::SimpleManyChannelMonitor<OutPoint, EnforcingChannelKeys>>>>>,
|
||||
manager: Arc<ChannelManager<EnforcingChannelKeys, Arc<channelmonitor::SimpleManyChannelMonitor<OutPoint, EnforcingChannelKeys, Arc<TestBroadcaster>>>, Arc<TestBroadcaster>>>,
|
||||
monitor: Arc<channelmonitor::SimpleManyChannelMonitor<OutPoint, EnforcingChannelKeys, Arc<TestBroadcaster>>>,
|
||||
handler: PeerManager<Peer<'a>, Arc<ChannelManager<EnforcingChannelKeys, Arc<channelmonitor::SimpleManyChannelMonitor<OutPoint, EnforcingChannelKeys, Arc<TestBroadcaster>>>, Arc<TestBroadcaster>>>>,
|
||||
|
||||
peers: &'a RefCell<[bool; 256]>,
|
||||
funding_txn: Vec<Transaction>,
|
||||
|
@ -150,9 +150,9 @@ struct MoneyLossDetector<'a> {
|
|||
}
|
||||
impl<'a> MoneyLossDetector<'a> {
|
||||
pub fn new(peers: &'a RefCell<[bool; 256]>,
|
||||
manager: Arc<ChannelManager<EnforcingChannelKeys, Arc<channelmonitor::SimpleManyChannelMonitor<OutPoint, EnforcingChannelKeys>>>>,
|
||||
monitor: Arc<channelmonitor::SimpleManyChannelMonitor<OutPoint, EnforcingChannelKeys>>,
|
||||
handler: PeerManager<Peer<'a>, Arc<ChannelManager<EnforcingChannelKeys, Arc<channelmonitor::SimpleManyChannelMonitor<OutPoint, EnforcingChannelKeys>>>>>) -> Self {
|
||||
manager: Arc<ChannelManager<EnforcingChannelKeys, Arc<channelmonitor::SimpleManyChannelMonitor<OutPoint, EnforcingChannelKeys, Arc<TestBroadcaster>>>, Arc<TestBroadcaster>>>,
|
||||
monitor: Arc<channelmonitor::SimpleManyChannelMonitor<OutPoint, EnforcingChannelKeys, Arc<TestBroadcaster>>>,
|
||||
handler: PeerManager<Peer<'a>, Arc<ChannelManager<EnforcingChannelKeys, Arc<channelmonitor::SimpleManyChannelMonitor<OutPoint, EnforcingChannelKeys, Arc<TestBroadcaster>>>, Arc<TestBroadcaster>>>>) -> Self {
|
||||
MoneyLossDetector {
|
||||
manager,
|
||||
monitor,
|
||||
|
|
|
@ -403,13 +403,14 @@ impl ChainWatchInterfaceUtil {
|
|||
|
||||
#[cfg(test)]
|
||||
mod tests {
|
||||
use ln::functional_test_utils::{create_node_cfgs};
|
||||
use ln::functional_test_utils::{create_chanmon_cfgs, create_node_cfgs};
|
||||
use super::{BlockNotifier, ChainListener};
|
||||
use std::ptr;
|
||||
|
||||
#[test]
|
||||
fn register_listener_test() {
|
||||
let node_cfgs = create_node_cfgs(1);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(1);
|
||||
let node_cfgs = create_node_cfgs(1, &chanmon_cfgs);
|
||||
let block_notifier = BlockNotifier::new(node_cfgs[0].chain_monitor.clone());
|
||||
assert_eq!(block_notifier.listeners.lock().unwrap().len(), 0);
|
||||
let listener = &node_cfgs[0].chan_monitor.simple_monitor as &ChainListener;
|
||||
|
@ -422,7 +423,8 @@ mod tests {
|
|||
|
||||
#[test]
|
||||
fn unregister_single_listener_test() {
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let block_notifier = BlockNotifier::new(node_cfgs[0].chain_monitor.clone());
|
||||
let listener1 = &node_cfgs[0].chan_monitor.simple_monitor as &ChainListener;
|
||||
let listener2 = &node_cfgs[1].chan_monitor.simple_monitor as &ChainListener;
|
||||
|
@ -440,7 +442,8 @@ mod tests {
|
|||
|
||||
#[test]
|
||||
fn unregister_single_listener_ref_test() {
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let block_notifier = BlockNotifier::new(node_cfgs[0].chain_monitor.clone());
|
||||
block_notifier.register_listener(&node_cfgs[0].chan_monitor.simple_monitor as &ChainListener);
|
||||
block_notifier.register_listener(&node_cfgs[1].chan_monitor.simple_monitor as &ChainListener);
|
||||
|
@ -456,7 +459,8 @@ mod tests {
|
|||
|
||||
#[test]
|
||||
fn unregister_multiple_of_the_same_listeners_test() {
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let block_notifier = BlockNotifier::new(node_cfgs[0].chain_monitor.clone());
|
||||
let listener1 = &node_cfgs[0].chan_monitor.simple_monitor as &ChainListener;
|
||||
let listener2 = &node_cfgs[1].chan_monitor.simple_monitor as &ChainListener;
|
||||
|
|
|
@ -19,7 +19,8 @@ use ln::functional_test_utils::*;
|
|||
#[test]
|
||||
fn test_simple_monitor_permanent_update_fail() {
|
||||
// Test that we handle a simple permanent monitor update failure
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let mut nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
create_announced_chan_between_nodes(&nodes, 0, 1, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -51,7 +52,8 @@ fn test_simple_monitor_permanent_update_fail() {
|
|||
fn do_test_simple_monitor_temporary_update_fail(disconnect: bool) {
|
||||
// Test that we can recover from a simple temporary monitor update failure optionally with
|
||||
// a disconnect in between
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let mut nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
create_announced_chan_between_nodes(&nodes, 0, 1, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -152,7 +154,8 @@ fn do_test_monitor_temporary_update_fail(disconnect_count: usize) {
|
|||
// * We then walk through more message exchanges to get the original update_add_htlc
|
||||
// through, swapping message ordering based on disconnect_count & 8 and optionally
|
||||
// disconnect/reconnecting based on disconnect_count.
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let mut nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
create_announced_chan_between_nodes(&nodes, 0, 1, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -480,7 +483,8 @@ fn test_monitor_temporary_update_fail_c() {
|
|||
#[test]
|
||||
fn test_monitor_update_fail_cs() {
|
||||
// Tests handling of a monitor update failure when processing an incoming commitment_signed
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let mut nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
create_announced_chan_between_nodes(&nodes, 0, 1, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -561,7 +565,8 @@ fn test_monitor_update_fail_no_rebroadcast() {
|
|||
// Tests handling of a monitor update failure when no message rebroadcasting on
|
||||
// test_restore_channel_monitor() is required. Backported from
|
||||
// chanmon_fail_consistency fuzz tests.
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let mut nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
create_announced_chan_between_nodes(&nodes, 0, 1, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -605,7 +610,8 @@ fn test_monitor_update_fail_no_rebroadcast() {
|
|||
fn test_monitor_update_raa_while_paused() {
|
||||
// Tests handling of an RAA while monitor updating has already been marked failed.
|
||||
// Backported from chanmon_fail_consistency fuzz tests as this used to be broken.
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let mut nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
create_announced_chan_between_nodes(&nodes, 0, 1, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -674,7 +680,8 @@ fn test_monitor_update_raa_while_paused() {
|
|||
|
||||
fn do_test_monitor_update_fail_raa(test_ignore_second_cs: bool) {
|
||||
// Tests handling of a monitor update failure when processing an incoming RAA
|
||||
let node_cfgs = create_node_cfgs(3);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(3);
|
||||
let node_cfgs = create_node_cfgs(3, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(3, &node_cfgs, &[None, None, None]);
|
||||
let mut nodes = create_network(3, &node_cfgs, &node_chanmgrs);
|
||||
create_announced_chan_between_nodes(&nodes, 0, 1, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -929,7 +936,8 @@ fn test_monitor_update_fail_reestablish() {
|
|||
// Simple test for message retransmission after monitor update failure on
|
||||
// channel_reestablish generating a monitor update (which comes from freeing holding cell
|
||||
// HTLCs).
|
||||
let node_cfgs = create_node_cfgs(3);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(3);
|
||||
let node_cfgs = create_node_cfgs(3, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(3, &node_cfgs, &[None, None, None]);
|
||||
let mut nodes = create_network(3, &node_cfgs, &node_chanmgrs);
|
||||
create_announced_chan_between_nodes(&nodes, 0, 1, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -1009,7 +1017,8 @@ fn raa_no_response_awaiting_raa_state() {
|
|||
// due to a previous monitor update failure, we still set AwaitingRemoteRevoke on the channel
|
||||
// in question (assuming it intends to respond with a CS after monitor updating is restored).
|
||||
// Backported from chanmon_fail_consistency fuzz tests as this used to be broken.
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let mut nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
create_announced_chan_between_nodes(&nodes, 0, 1, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -1124,7 +1133,8 @@ fn claim_while_disconnected_monitor_update_fail() {
|
|||
// Backported from chanmon_fail_consistency fuzz tests as an unmerged version of the handling
|
||||
// code introduced a regression in this test (specifically, this caught a removal of the
|
||||
// channel_reestablish handling ensuring the order was sensical given the messages used).
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let mut nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
create_announced_chan_between_nodes(&nodes, 0, 1, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -1241,7 +1251,8 @@ fn monitor_failed_no_reestablish_response() {
|
|||
// response to a commitment_signed.
|
||||
// Backported from chanmon_fail_consistency fuzz tests as it caught a long-standing
|
||||
// debug_assert!() failure in channel_reestablish handling.
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let mut nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
create_announced_chan_between_nodes(&nodes, 0, 1, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -1309,7 +1320,8 @@ fn first_message_on_recv_ordering() {
|
|||
// have no pending response but will want to send a RAA/CS (with the updates for the second
|
||||
// payment applied).
|
||||
// Backported from chanmon_fail_consistency fuzz tests as it caught a bug here.
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let mut nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
create_announced_chan_between_nodes(&nodes, 0, 1, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -1396,7 +1408,8 @@ fn test_monitor_update_fail_claim() {
|
|||
// update to claim the payment. We then send a payment C->B->A, making the forward of this
|
||||
// payment from B to A fail due to the paused channel. Finally, we restore the channel monitor
|
||||
// updating and claim the payment on B.
|
||||
let node_cfgs = create_node_cfgs(3);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(3);
|
||||
let node_cfgs = create_node_cfgs(3, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(3, &node_cfgs, &[None, None, None]);
|
||||
let mut nodes = create_network(3, &node_cfgs, &node_chanmgrs);
|
||||
let chan_1 = create_announced_chan_between_nodes(&nodes, 0, 1, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -1471,7 +1484,8 @@ fn test_monitor_update_on_pending_forwards() {
|
|||
// We do this with a simple 3-node network, sending a payment from A to C and one from C to A.
|
||||
// The payment from A to C will be failed by C and pending a back-fail to A, while the payment
|
||||
// from C to A will be pending a forward to A.
|
||||
let node_cfgs = create_node_cfgs(3);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(3);
|
||||
let node_cfgs = create_node_cfgs(3, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(3, &node_cfgs, &[None, None, None]);
|
||||
let mut nodes = create_network(3, &node_cfgs, &node_chanmgrs);
|
||||
create_announced_chan_between_nodes(&nodes, 0, 1, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -1538,7 +1552,8 @@ fn monitor_update_claim_fail_no_response() {
|
|||
// to channel being AwaitingRAA).
|
||||
// Backported from chanmon_fail_consistency fuzz tests as an unmerged version of the handling
|
||||
// code was broken.
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let mut nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
create_announced_chan_between_nodes(&nodes, 0, 1, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -1599,7 +1614,8 @@ fn monitor_update_claim_fail_no_response() {
|
|||
fn do_during_funding_monitor_fail(fail_on_generate: bool, restore_between_fails: bool, fail_on_signed: bool, confirm_a_first: bool, restore_b_before_conf: bool) {
|
||||
// Test that if the monitor update generated by funding_transaction_generated fails we continue
|
||||
// the channel setup happily after the update is restored.
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let mut nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
|
||||
|
|
|
@ -289,7 +289,7 @@ const ERR: () = "You need at least 32 bit pointers (well, usize, but we'll assum
|
|||
/// lifetimes). Other times you can afford a reference, which is more efficient, in which case
|
||||
/// SimpleRefChannelManager is the more appropriate type. Defining these type aliases prevents
|
||||
/// issues such as overly long function definitions.
|
||||
pub type SimpleArcChannelManager<M> = Arc<ChannelManager<InMemoryChannelKeys, Arc<M>>>;
|
||||
pub type SimpleArcChannelManager<M, T> = Arc<ChannelManager<InMemoryChannelKeys, Arc<M>, Arc<T>>>;
|
||||
|
||||
/// SimpleRefChannelManager is a type alias for a ChannelManager reference, and is the reference
|
||||
/// counterpart to the SimpleArcChannelManager type alias. Use this type by default when you don't
|
||||
|
@ -297,7 +297,7 @@ pub type SimpleArcChannelManager<M> = Arc<ChannelManager<InMemoryChannelKeys, Ar
|
|||
/// usage of lightning-net-tokio (since tokio::spawn requires parameters with static lifetimes).
|
||||
/// But if this is not necessary, using a reference is more efficient. Defining these type aliases
|
||||
/// helps with issues such as long function definitions.
|
||||
pub type SimpleRefChannelManager<'a, M> = ChannelManager<InMemoryChannelKeys, &'a M>;
|
||||
pub type SimpleRefChannelManager<'a, 'b, M, T> = ChannelManager<InMemoryChannelKeys, &'a M, &'b T>;
|
||||
|
||||
/// Manager which keeps track of a number of channels and sends messages to the appropriate
|
||||
/// channel, also tracking HTLC preimages and forwarding onion packets appropriately.
|
||||
|
@ -335,12 +335,15 @@ pub type SimpleRefChannelManager<'a, M> = ChannelManager<InMemoryChannelKeys, &'
|
|||
/// essentially you should default to using a SimpleRefChannelManager, and use a
|
||||
/// SimpleArcChannelManager when you require a ChannelManager with a static lifetime, such as when
|
||||
/// you're using lightning-net-tokio.
|
||||
pub struct ChannelManager<ChanSigner: ChannelKeys, M: Deref> where M::Target: ManyChannelMonitor<ChanSigner> {
|
||||
pub struct ChannelManager<ChanSigner: ChannelKeys, M: Deref, T: Deref>
|
||||
where M::Target: ManyChannelMonitor<ChanSigner>,
|
||||
T::Target: BroadcasterInterface,
|
||||
{
|
||||
default_configuration: UserConfig,
|
||||
genesis_hash: Sha256dHash,
|
||||
fee_estimator: Arc<FeeEstimator>,
|
||||
monitor: M,
|
||||
tx_broadcaster: Arc<BroadcasterInterface>,
|
||||
tx_broadcaster: T,
|
||||
|
||||
#[cfg(test)]
|
||||
pub(super) latest_block_height: AtomicUsize,
|
||||
|
@ -607,7 +610,10 @@ macro_rules! maybe_break_monitor_err {
|
|||
}
|
||||
}
|
||||
|
||||
impl<ChanSigner: ChannelKeys, M: Deref> ChannelManager<ChanSigner, M> where M::Target: ManyChannelMonitor<ChanSigner> {
|
||||
impl<ChanSigner: ChannelKeys, M: Deref, T: Deref> ChannelManager<ChanSigner, M, T>
|
||||
where M::Target: ManyChannelMonitor<ChanSigner>,
|
||||
T::Target: BroadcasterInterface,
|
||||
{
|
||||
/// Constructs a new ChannelManager to hold several channels and route between them.
|
||||
///
|
||||
/// This is the main "logic hub" for all channel-related actions, and implements
|
||||
|
@ -626,7 +632,7 @@ impl<ChanSigner: ChannelKeys, M: Deref> ChannelManager<ChanSigner, M> where M::T
|
|||
/// the ChannelManager as a listener to the BlockNotifier and call the BlockNotifier's
|
||||
/// `block_(dis)connected` methods, which will notify all registered listeners in one
|
||||
/// go.
|
||||
pub fn new(network: Network, feeest: Arc<FeeEstimator>, monitor: M, tx_broadcaster: Arc<BroadcasterInterface>, logger: Arc<Logger>,keys_manager: Arc<KeysInterface<ChanKeySigner = ChanSigner>>, config: UserConfig, current_blockchain_height: usize) -> Result<ChannelManager<ChanSigner, M>, secp256k1::Error> {
|
||||
pub fn new(network: Network, feeest: Arc<FeeEstimator>, monitor: M, tx_broadcaster: T, logger: Arc<Logger>,keys_manager: Arc<KeysInterface<ChanKeySigner = ChanSigner>>, config: UserConfig, current_blockchain_height: usize) -> Result<ChannelManager<ChanSigner, M, T>, secp256k1::Error> {
|
||||
let secp_ctx = Secp256k1::new();
|
||||
|
||||
let res = ChannelManager {
|
||||
|
@ -2542,7 +2548,10 @@ impl<ChanSigner: ChannelKeys, M: Deref> ChannelManager<ChanSigner, M> where M::T
|
|||
}
|
||||
}
|
||||
|
||||
impl<ChanSigner: ChannelKeys, M: Deref> events::MessageSendEventsProvider for ChannelManager<ChanSigner, M> where M::Target: ManyChannelMonitor<ChanSigner> {
|
||||
impl<ChanSigner: ChannelKeys, M: Deref, T: Deref> events::MessageSendEventsProvider for ChannelManager<ChanSigner, M, T>
|
||||
where M::Target: ManyChannelMonitor<ChanSigner>,
|
||||
T::Target: BroadcasterInterface,
|
||||
{
|
||||
fn get_and_clear_pending_msg_events(&self) -> Vec<events::MessageSendEvent> {
|
||||
// TODO: Event release to users and serialization is currently race-y: it's very easy for a
|
||||
// user to serialize a ChannelManager with pending events in it and lose those events on
|
||||
|
@ -2567,7 +2576,10 @@ impl<ChanSigner: ChannelKeys, M: Deref> events::MessageSendEventsProvider for Ch
|
|||
}
|
||||
}
|
||||
|
||||
impl<ChanSigner: ChannelKeys, M: Deref> events::EventsProvider for ChannelManager<ChanSigner, M> where M::Target: ManyChannelMonitor<ChanSigner> {
|
||||
impl<ChanSigner: ChannelKeys, M: Deref, T: Deref> events::EventsProvider for ChannelManager<ChanSigner, M, T>
|
||||
where M::Target: ManyChannelMonitor<ChanSigner>,
|
||||
T::Target: BroadcasterInterface,
|
||||
{
|
||||
fn get_and_clear_pending_events(&self) -> Vec<events::Event> {
|
||||
// TODO: Event release to users and serialization is currently race-y: it's very easy for a
|
||||
// user to serialize a ChannelManager with pending events in it and lose those events on
|
||||
|
@ -2592,7 +2604,10 @@ impl<ChanSigner: ChannelKeys, M: Deref> events::EventsProvider for ChannelManage
|
|||
}
|
||||
}
|
||||
|
||||
impl<ChanSigner: ChannelKeys, M: Deref + Sync + Send> ChainListener for ChannelManager<ChanSigner, M> where M::Target: ManyChannelMonitor<ChanSigner> {
|
||||
impl<ChanSigner: ChannelKeys, M: Deref + Sync + Send, T: Deref + Sync + Send> ChainListener for ChannelManager<ChanSigner, M, T>
|
||||
where M::Target: ManyChannelMonitor<ChanSigner>,
|
||||
T::Target: BroadcasterInterface,
|
||||
{
|
||||
fn block_connected(&self, header: &BlockHeader, height: u32, txn_matched: &[&Transaction], indexes_of_txn_matched: &[u32]) {
|
||||
let header_hash = header.bitcoin_hash();
|
||||
log_trace!(self, "Block {} at height {} connected with {} txn matched", header_hash, height, txn_matched.len());
|
||||
|
@ -2709,7 +2724,10 @@ impl<ChanSigner: ChannelKeys, M: Deref + Sync + Send> ChainListener for ChannelM
|
|||
}
|
||||
}
|
||||
|
||||
impl<ChanSigner: ChannelKeys, M: Deref + Sync + Send> ChannelMessageHandler for ChannelManager<ChanSigner, M> where M::Target: ManyChannelMonitor<ChanSigner> {
|
||||
impl<ChanSigner: ChannelKeys, M: Deref + Sync + Send, T: Deref + Sync + Send> ChannelMessageHandler for ChannelManager<ChanSigner, M, T>
|
||||
where M::Target: ManyChannelMonitor<ChanSigner>,
|
||||
T::Target: BroadcasterInterface,
|
||||
{
|
||||
fn handle_open_channel(&self, their_node_id: &PublicKey, their_features: InitFeatures, msg: &msgs::OpenChannel) {
|
||||
let _ = self.total_consistency_lock.read().unwrap();
|
||||
let res = self.internal_open_channel(their_node_id, their_features, msg);
|
||||
|
@ -3179,7 +3197,10 @@ impl<R: ::std::io::Read> Readable<R> for HTLCForwardInfo {
|
|||
}
|
||||
}
|
||||
|
||||
impl<ChanSigner: ChannelKeys + Writeable, M: Deref> Writeable for ChannelManager<ChanSigner, M> where M::Target: ManyChannelMonitor<ChanSigner> {
|
||||
impl<ChanSigner: ChannelKeys + Writeable, M: Deref, T: Deref> Writeable for ChannelManager<ChanSigner, M, T>
|
||||
where M::Target: ManyChannelMonitor<ChanSigner>,
|
||||
T::Target: BroadcasterInterface,
|
||||
{
|
||||
fn write<W: Writer>(&self, writer: &mut W) -> Result<(), ::std::io::Error> {
|
||||
let _ = self.total_consistency_lock.write().unwrap();
|
||||
|
||||
|
@ -3250,7 +3271,11 @@ impl<ChanSigner: ChannelKeys + Writeable, M: Deref> Writeable for ChannelManager
|
|||
/// 5) Move the ChannelMonitors into your local ManyChannelMonitor.
|
||||
/// 6) Disconnect/connect blocks on the ChannelManager.
|
||||
/// 7) Register the new ChannelManager with your ChainWatchInterface.
|
||||
pub struct ChannelManagerReadArgs<'a, ChanSigner: 'a + ChannelKeys, M: Deref> where M::Target: ManyChannelMonitor<ChanSigner> {
|
||||
pub struct ChannelManagerReadArgs<'a, ChanSigner: 'a + ChannelKeys, M: Deref, T: Deref>
|
||||
where M::Target: ManyChannelMonitor<ChanSigner>,
|
||||
T::Target: BroadcasterInterface,
|
||||
{
|
||||
|
||||
/// The keys provider which will give us relevant keys. Some keys will be loaded during
|
||||
/// deserialization.
|
||||
pub keys_manager: Arc<KeysInterface<ChanKeySigner = ChanSigner>>,
|
||||
|
@ -3269,7 +3294,7 @@ pub struct ChannelManagerReadArgs<'a, ChanSigner: 'a + ChannelKeys, M: Deref> wh
|
|||
/// The BroadcasterInterface which will be used in the ChannelManager in the future and may be
|
||||
/// used to broadcast the latest local commitment transactions of channels which must be
|
||||
/// force-closed during deserialization.
|
||||
pub tx_broadcaster: Arc<BroadcasterInterface>,
|
||||
pub tx_broadcaster: T,
|
||||
/// The Logger for use in the ChannelManager and which may be used to log information during
|
||||
/// deserialization.
|
||||
pub logger: Arc<Logger>,
|
||||
|
@ -3290,8 +3315,11 @@ pub struct ChannelManagerReadArgs<'a, ChanSigner: 'a + ChannelKeys, M: Deref> wh
|
|||
pub channel_monitors: &'a mut HashMap<OutPoint, &'a mut ChannelMonitor<ChanSigner>>,
|
||||
}
|
||||
|
||||
impl<'a, R : ::std::io::Read, ChanSigner: ChannelKeys + Readable<R>, M: Deref> ReadableArgs<R, ChannelManagerReadArgs<'a, ChanSigner, M>> for (Sha256dHash, ChannelManager<ChanSigner, M>) where M::Target: ManyChannelMonitor<ChanSigner> {
|
||||
fn read(reader: &mut R, args: ChannelManagerReadArgs<'a, ChanSigner, M>) -> Result<Self, DecodeError> {
|
||||
impl<'a, R : ::std::io::Read, ChanSigner: ChannelKeys + Readable<R>, M: Deref, T: Deref> ReadableArgs<R, ChannelManagerReadArgs<'a, ChanSigner, M, T>> for (Sha256dHash, ChannelManager<ChanSigner, M, T>)
|
||||
where M::Target: ManyChannelMonitor<ChanSigner>,
|
||||
T::Target: BroadcasterInterface,
|
||||
{
|
||||
fn read(reader: &mut R, args: ChannelManagerReadArgs<'a, ChanSigner, M, T>) -> Result<Self, DecodeError> {
|
||||
let _ver: u8 = Readable::read(reader)?;
|
||||
let min_ver: u8 = Readable::read(reader)?;
|
||||
if min_ver > SERIALIZATION_VERSION {
|
||||
|
|
|
@ -43,6 +43,7 @@ use util::{byte_utils, events};
|
|||
use std::collections::{HashMap, hash_map, HashSet};
|
||||
use std::sync::{Arc,Mutex};
|
||||
use std::{hash,cmp, mem};
|
||||
use std::ops::Deref;
|
||||
|
||||
/// An error enum representing a failure to persist a channel monitor update.
|
||||
#[derive(Clone)]
|
||||
|
@ -151,19 +152,21 @@ pub trait ManyChannelMonitor<ChanSigner: ChannelKeys>: Send + Sync {
|
|||
///
|
||||
/// If you're using this for local monitoring of your own channels, you probably want to use
|
||||
/// `OutPoint` as the key, which will give you a ManyChannelMonitor implementation.
|
||||
pub struct SimpleManyChannelMonitor<Key, ChanSigner: ChannelKeys> {
|
||||
pub struct SimpleManyChannelMonitor<Key, ChanSigner: ChannelKeys, T: Deref> where T::Target: BroadcasterInterface {
|
||||
#[cfg(test)] // Used in ChannelManager tests to manipulate channels directly
|
||||
pub monitors: Mutex<HashMap<Key, ChannelMonitor<ChanSigner>>>,
|
||||
#[cfg(not(test))]
|
||||
monitors: Mutex<HashMap<Key, ChannelMonitor<ChanSigner>>>,
|
||||
chain_monitor: Arc<ChainWatchInterface>,
|
||||
broadcaster: Arc<BroadcasterInterface>,
|
||||
broadcaster: T,
|
||||
pending_events: Mutex<Vec<events::Event>>,
|
||||
logger: Arc<Logger>,
|
||||
fee_estimator: Arc<FeeEstimator>
|
||||
}
|
||||
|
||||
impl<'a, Key : Send + cmp::Eq + hash::Hash, ChanSigner: ChannelKeys> ChainListener for SimpleManyChannelMonitor<Key, ChanSigner> {
|
||||
impl<'a, Key : Send + cmp::Eq + hash::Hash, ChanSigner: ChannelKeys, T: Deref + Sync + Send> ChainListener for SimpleManyChannelMonitor<Key, ChanSigner, T>
|
||||
where T::Target: BroadcasterInterface
|
||||
{
|
||||
fn block_connected(&self, header: &BlockHeader, height: u32, txn_matched: &[&Transaction], _indexes_of_txn_matched: &[u32]) {
|
||||
let block_hash = header.bitcoin_hash();
|
||||
let mut new_events: Vec<events::Event> = Vec::with_capacity(0);
|
||||
|
@ -197,10 +200,12 @@ impl<'a, Key : Send + cmp::Eq + hash::Hash, ChanSigner: ChannelKeys> ChainListen
|
|||
}
|
||||
}
|
||||
|
||||
impl<Key : Send + cmp::Eq + hash::Hash + 'static, ChanSigner: ChannelKeys> SimpleManyChannelMonitor<Key, ChanSigner> {
|
||||
impl<Key : Send + cmp::Eq + hash::Hash + 'static, ChanSigner: ChannelKeys, T: Deref> SimpleManyChannelMonitor<Key, ChanSigner, T>
|
||||
where T::Target: BroadcasterInterface
|
||||
{
|
||||
/// Creates a new object which can be used to monitor several channels given the chain
|
||||
/// interface with which to register to receive notifications.
|
||||
pub fn new(chain_monitor: Arc<ChainWatchInterface>, broadcaster: Arc<BroadcasterInterface>, logger: Arc<Logger>, feeest: Arc<FeeEstimator>) -> SimpleManyChannelMonitor<Key, ChanSigner> {
|
||||
pub fn new(chain_monitor: Arc<ChainWatchInterface>, broadcaster: T, logger: Arc<Logger>, feeest: Arc<FeeEstimator>) -> SimpleManyChannelMonitor<Key, ChanSigner, T> {
|
||||
let res = SimpleManyChannelMonitor {
|
||||
monitors: Mutex::new(HashMap::new()),
|
||||
chain_monitor,
|
||||
|
@ -250,7 +255,9 @@ impl<Key : Send + cmp::Eq + hash::Hash + 'static, ChanSigner: ChannelKeys> Simpl
|
|||
}
|
||||
}
|
||||
|
||||
impl<ChanSigner: ChannelKeys> ManyChannelMonitor<ChanSigner> for SimpleManyChannelMonitor<OutPoint, ChanSigner> {
|
||||
impl<ChanSigner: ChannelKeys, T: Deref + Sync + Send> ManyChannelMonitor<ChanSigner> for SimpleManyChannelMonitor<OutPoint, ChanSigner, T>
|
||||
where T::Target: BroadcasterInterface
|
||||
{
|
||||
fn add_update_monitor(&self, funding_txo: OutPoint, monitor: ChannelMonitor<ChanSigner>) -> Result<(), ChannelMonitorUpdateErr> {
|
||||
match self.add_update_monitor_by_key(funding_txo, monitor) {
|
||||
Ok(_) => Ok(()),
|
||||
|
@ -267,7 +274,9 @@ impl<ChanSigner: ChannelKeys> ManyChannelMonitor<ChanSigner> for SimpleManyChann
|
|||
}
|
||||
}
|
||||
|
||||
impl<Key : Send + cmp::Eq + hash::Hash, ChanSigner: ChannelKeys> events::EventsProvider for SimpleManyChannelMonitor<Key, ChanSigner> {
|
||||
impl<Key : Send + cmp::Eq + hash::Hash, ChanSigner: ChannelKeys, T: Deref> events::EventsProvider for SimpleManyChannelMonitor<Key, ChanSigner, T>
|
||||
where T::Target: BroadcasterInterface
|
||||
{
|
||||
fn get_and_clear_pending_events(&self) -> Vec<events::Event> {
|
||||
let mut pending_events = self.pending_events.lock().unwrap();
|
||||
let mut ret = Vec::new();
|
||||
|
@ -2387,7 +2396,9 @@ impl<ChanSigner: ChannelKeys> ChannelMonitor<ChanSigner> {
|
|||
/// Eventually this should be pub and, roughly, implement ChainListener, however this requires
|
||||
/// &mut self, as well as returns new spendable outputs and outpoints to watch for spending of
|
||||
/// on-chain.
|
||||
fn block_connected(&mut self, txn_matched: &[&Transaction], height: u32, block_hash: &Sha256dHash, broadcaster: &BroadcasterInterface, fee_estimator: &FeeEstimator)-> (Vec<(Sha256dHash, Vec<TxOut>)>, Vec<SpendableOutputDescriptor>) {
|
||||
fn block_connected<B: Deref>(&mut self, txn_matched: &[&Transaction], height: u32, block_hash: &Sha256dHash, broadcaster: B, fee_estimator: &FeeEstimator)-> (Vec<(Sha256dHash, Vec<TxOut>)>, Vec<SpendableOutputDescriptor>)
|
||||
where B::Target: BroadcasterInterface
|
||||
{
|
||||
for tx in txn_matched {
|
||||
let mut output_val = 0;
|
||||
for out in tx.output.iter() {
|
||||
|
@ -2620,7 +2631,9 @@ impl<ChanSigner: ChannelKeys> ChannelMonitor<ChanSigner> {
|
|||
(watch_outputs, spendable_outputs)
|
||||
}
|
||||
|
||||
fn block_disconnected(&mut self, height: u32, block_hash: &Sha256dHash, broadcaster: &BroadcasterInterface, fee_estimator: &FeeEstimator) {
|
||||
fn block_disconnected<B: Deref>(&mut self, height: u32, block_hash: &Sha256dHash, broadcaster: B, fee_estimator: &FeeEstimator)
|
||||
where B::Target: BroadcasterInterface
|
||||
{
|
||||
log_trace!(self, "Block {} at height {} disconnected", block_hash, height);
|
||||
let mut bump_candidates = HashMap::new();
|
||||
if let Some(events) = self.onchain_events_waiting_threshold_conf.remove(&(height + ANTI_REORG_DELAY - 1)) {
|
||||
|
|
|
@ -60,23 +60,27 @@ pub fn connect_blocks<'a, 'b>(notifier: &'a chaininterface::BlockNotifierRef<'b>
|
|||
header.bitcoin_hash()
|
||||
}
|
||||
|
||||
pub struct NodeCfg {
|
||||
pub struct TestChanMonCfg {
|
||||
pub tx_broadcaster: test_utils::TestBroadcaster,
|
||||
}
|
||||
|
||||
pub struct NodeCfg<'a> {
|
||||
pub chain_monitor: Arc<chaininterface::ChainWatchInterfaceUtil>,
|
||||
pub tx_broadcaster: Arc<test_utils::TestBroadcaster>,
|
||||
pub tx_broadcaster: &'a test_utils::TestBroadcaster,
|
||||
pub fee_estimator: Arc<test_utils::TestFeeEstimator>,
|
||||
pub chan_monitor: test_utils::TestChannelMonitor,
|
||||
pub chan_monitor: test_utils::TestChannelMonitor<'a>,
|
||||
pub keys_manager: Arc<test_utils::TestKeysInterface>,
|
||||
pub logger: Arc<test_utils::TestLogger>,
|
||||
pub node_seed: [u8; 32],
|
||||
}
|
||||
|
||||
pub struct Node<'a, 'b: 'a> {
|
||||
pub block_notifier: chaininterface::BlockNotifierRef<'b>,
|
||||
pub struct Node<'a, 'b: 'a, 'c: 'b> {
|
||||
pub block_notifier: chaininterface::BlockNotifierRef<'a>,
|
||||
pub chain_monitor: Arc<chaininterface::ChainWatchInterfaceUtil>,
|
||||
pub tx_broadcaster: Arc<test_utils::TestBroadcaster>,
|
||||
pub chan_monitor: &'b test_utils::TestChannelMonitor,
|
||||
pub tx_broadcaster: &'c test_utils::TestBroadcaster,
|
||||
pub chan_monitor: &'b test_utils::TestChannelMonitor<'c>,
|
||||
pub keys_manager: Arc<test_utils::TestKeysInterface>,
|
||||
pub node: &'a ChannelManager<EnforcingChannelKeys, &'b TestChannelMonitor>,
|
||||
pub node: &'a ChannelManager<EnforcingChannelKeys, &'b TestChannelMonitor<'c>, &'c test_utils::TestBroadcaster>,
|
||||
pub router: Router,
|
||||
pub node_seed: [u8; 32],
|
||||
pub network_payment_count: Rc<RefCell<u8>>,
|
||||
|
@ -84,7 +88,7 @@ pub struct Node<'a, 'b: 'a> {
|
|||
pub logger: Arc<test_utils::TestLogger>
|
||||
}
|
||||
|
||||
impl<'a, 'b> Drop for Node<'a, 'b> {
|
||||
impl<'a, 'b, 'c> Drop for Node<'a, 'b, 'c> {
|
||||
fn drop(&mut self) {
|
||||
if !::std::thread::panicking() {
|
||||
// Check that we processed all pending events
|
||||
|
@ -116,7 +120,7 @@ impl<'a, 'b> Drop for Node<'a, 'b> {
|
|||
|
||||
let mut w = test_utils::TestVecWriter(Vec::new());
|
||||
self.node.write(&mut w).unwrap();
|
||||
<(Sha256d, ChannelManager<EnforcingChannelKeys, &test_utils::TestChannelMonitor>)>::read(&mut ::std::io::Cursor::new(w.0), ChannelManagerReadArgs {
|
||||
<(Sha256d, ChannelManager<EnforcingChannelKeys, &test_utils::TestChannelMonitor, &test_utils::TestBroadcaster>)>::read(&mut ::std::io::Cursor::new(w.0), ChannelManagerReadArgs {
|
||||
default_config: UserConfig::default(),
|
||||
keys_manager: self.keys_manager.clone(),
|
||||
fee_estimator: Arc::new(test_utils::TestFeeEstimator { sat_per_kw: 253 }),
|
||||
|
@ -141,11 +145,11 @@ impl<'a, 'b> Drop for Node<'a, 'b> {
|
|||
}
|
||||
}
|
||||
|
||||
pub fn create_chan_between_nodes<'a, 'b, 'c>(node_a: &'a Node<'b, 'c>, node_b: &'a Node<'b, 'c>, a_flags: InitFeatures, b_flags: InitFeatures) -> (msgs::ChannelAnnouncement, msgs::ChannelUpdate, msgs::ChannelUpdate, [u8; 32], Transaction) {
|
||||
pub fn create_chan_between_nodes<'a, 'b, 'c, 'd>(node_a: &'a Node<'b, 'c, 'd>, node_b: &'a Node<'b, 'c, 'd>, a_flags: InitFeatures, b_flags: InitFeatures) -> (msgs::ChannelAnnouncement, msgs::ChannelUpdate, msgs::ChannelUpdate, [u8; 32], Transaction) {
|
||||
create_chan_between_nodes_with_value(node_a, node_b, 100000, 10001, a_flags, b_flags)
|
||||
}
|
||||
|
||||
pub fn create_chan_between_nodes_with_value<'a, 'b, 'c>(node_a: &'a Node<'b, 'c>, node_b: &'a Node<'b, 'c>, channel_value: u64, push_msat: u64, a_flags: InitFeatures, b_flags: InitFeatures) -> (msgs::ChannelAnnouncement, msgs::ChannelUpdate, msgs::ChannelUpdate, [u8; 32], Transaction) {
|
||||
pub fn create_chan_between_nodes_with_value<'a, 'b, 'c, 'd>(node_a: &'a Node<'b, 'c, 'd>, node_b: &'a Node<'b, 'c, 'd>, channel_value: u64, push_msat: u64, a_flags: InitFeatures, b_flags: InitFeatures) -> (msgs::ChannelAnnouncement, msgs::ChannelUpdate, msgs::ChannelUpdate, [u8; 32], Transaction) {
|
||||
let (funding_locked, channel_id, tx) = create_chan_between_nodes_with_value_a(node_a, node_b, channel_value, push_msat, a_flags, b_flags);
|
||||
let (announcement, as_update, bs_update) = create_chan_between_nodes_with_value_b(node_a, node_b, &funding_locked);
|
||||
(announcement, as_update, bs_update, channel_id, tx)
|
||||
|
@ -220,7 +224,7 @@ macro_rules! get_feerate {
|
|||
}
|
||||
}
|
||||
|
||||
pub fn create_funding_transaction<'a, 'b>(node: &Node<'a, 'b>, expected_chan_value: u64, expected_user_chan_id: u64) -> ([u8; 32], Transaction, OutPoint) {
|
||||
pub fn create_funding_transaction<'a, 'b, 'c>(node: &Node<'a, 'b, 'c>, expected_chan_value: u64, expected_user_chan_id: u64) -> ([u8; 32], Transaction, OutPoint) {
|
||||
let chan_id = *node.network_chan_count.borrow();
|
||||
|
||||
let events = node.node.get_and_clear_pending_events();
|
||||
|
@ -240,7 +244,7 @@ pub fn create_funding_transaction<'a, 'b>(node: &Node<'a, 'b>, expected_chan_val
|
|||
}
|
||||
}
|
||||
|
||||
pub fn create_chan_between_nodes_with_value_init<'a, 'b>(node_a: &Node<'a, 'b>, node_b: &Node<'a, 'b>, channel_value: u64, push_msat: u64, a_flags: InitFeatures, b_flags: InitFeatures) -> Transaction {
|
||||
pub fn create_chan_between_nodes_with_value_init<'a, 'b, 'c>(node_a: &Node<'a, 'b, 'c>, node_b: &Node<'a, 'b, 'c>, channel_value: u64, push_msat: u64, a_flags: InitFeatures, b_flags: InitFeatures) -> Transaction {
|
||||
node_a.node.create_channel(node_b.node.get_our_node_id(), channel_value, push_msat, 42).unwrap();
|
||||
node_b.node.handle_open_channel(&node_a.node.get_our_node_id(), a_flags, &get_event_msg!(node_a, MessageSendEvent::SendOpenChannel, node_b.node.get_our_node_id()));
|
||||
node_a.node.handle_accept_channel(&node_b.node.get_our_node_id(), b_flags, &get_event_msg!(node_b, MessageSendEvent::SendAcceptChannel, node_a.node.get_our_node_id()));
|
||||
|
@ -284,12 +288,12 @@ pub fn create_chan_between_nodes_with_value_init<'a, 'b>(node_a: &Node<'a, 'b>,
|
|||
tx
|
||||
}
|
||||
|
||||
pub fn create_chan_between_nodes_with_value_confirm_first<'a, 'b, 'c>(node_recv: &'a Node<'a, 'b>, node_conf: &'a Node<'a, 'b>, tx: &Transaction) {
|
||||
pub fn create_chan_between_nodes_with_value_confirm_first<'a, 'b, 'c, 'd>(node_recv: &'a Node<'b, 'c, 'c>, node_conf: &'a Node<'b, 'c, 'd>, tx: &Transaction) {
|
||||
confirm_transaction(&node_conf.block_notifier, &node_conf.chain_monitor, &tx, tx.version);
|
||||
node_recv.node.handle_funding_locked(&node_conf.node.get_our_node_id(), &get_event_msg!(node_conf, MessageSendEvent::SendFundingLocked, node_recv.node.get_our_node_id()));
|
||||
}
|
||||
|
||||
pub fn create_chan_between_nodes_with_value_confirm_second<'a, 'b>(node_recv: &Node<'a, 'b>, node_conf: &Node<'a, 'b>) -> ((msgs::FundingLocked, msgs::AnnouncementSignatures), [u8; 32]) {
|
||||
pub fn create_chan_between_nodes_with_value_confirm_second<'a, 'b, 'c>(node_recv: &Node<'a, 'b, 'c>, node_conf: &Node<'a, 'b, 'c>) -> ((msgs::FundingLocked, msgs::AnnouncementSignatures), [u8; 32]) {
|
||||
let channel_id;
|
||||
let events_6 = node_conf.node.get_and_clear_pending_msg_events();
|
||||
assert_eq!(events_6.len(), 2);
|
||||
|
@ -309,19 +313,19 @@ pub fn create_chan_between_nodes_with_value_confirm_second<'a, 'b>(node_recv: &N
|
|||
}), channel_id)
|
||||
}
|
||||
|
||||
pub fn create_chan_between_nodes_with_value_confirm<'a, 'b, 'c>(node_a: &'a Node<'b, 'c>, node_b: &'a Node<'b, 'c>, tx: &Transaction) -> ((msgs::FundingLocked, msgs::AnnouncementSignatures), [u8; 32]) {
|
||||
pub fn create_chan_between_nodes_with_value_confirm<'a, 'b, 'c, 'd>(node_a: &'a Node<'b, 'c, 'd>, node_b: &'a Node<'b, 'c, 'd>, tx: &Transaction) -> ((msgs::FundingLocked, msgs::AnnouncementSignatures), [u8; 32]) {
|
||||
create_chan_between_nodes_with_value_confirm_first(node_a, node_b, tx);
|
||||
confirm_transaction(&node_a.block_notifier, &node_a.chain_monitor, &tx, tx.version);
|
||||
create_chan_between_nodes_with_value_confirm_second(node_b, node_a)
|
||||
}
|
||||
|
||||
pub fn create_chan_between_nodes_with_value_a<'a, 'b, 'c>(node_a: &'a Node<'b, 'c>, node_b: &'a Node<'b, 'c>, channel_value: u64, push_msat: u64, a_flags: InitFeatures, b_flags: InitFeatures) -> ((msgs::FundingLocked, msgs::AnnouncementSignatures), [u8; 32], Transaction) {
|
||||
pub fn create_chan_between_nodes_with_value_a<'a, 'b, 'c, 'd>(node_a: &'a Node<'b, 'c, 'd>, node_b: &'a Node<'b, 'c, 'd>, channel_value: u64, push_msat: u64, a_flags: InitFeatures, b_flags: InitFeatures) -> ((msgs::FundingLocked, msgs::AnnouncementSignatures), [u8; 32], Transaction) {
|
||||
let tx = create_chan_between_nodes_with_value_init(node_a, node_b, channel_value, push_msat, a_flags, b_flags);
|
||||
let (msgs, chan_id) = create_chan_between_nodes_with_value_confirm(node_a, node_b, &tx);
|
||||
(msgs, chan_id, tx)
|
||||
}
|
||||
|
||||
pub fn create_chan_between_nodes_with_value_b<'a, 'b>(node_a: &Node<'a, 'b>, node_b: &Node<'a, 'b>, as_funding_msgs: &(msgs::FundingLocked, msgs::AnnouncementSignatures)) -> (msgs::ChannelAnnouncement, msgs::ChannelUpdate, msgs::ChannelUpdate) {
|
||||
pub fn create_chan_between_nodes_with_value_b<'a, 'b, 'c>(node_a: &Node<'a, 'b, 'c>, node_b: &Node<'a, 'b, 'c>, as_funding_msgs: &(msgs::FundingLocked, msgs::AnnouncementSignatures)) -> (msgs::ChannelAnnouncement, msgs::ChannelUpdate, msgs::ChannelUpdate) {
|
||||
node_b.node.handle_funding_locked(&node_a.node.get_our_node_id(), &as_funding_msgs.0);
|
||||
let bs_announcement_sigs = get_event_msg!(node_b, MessageSendEvent::SendAnnouncementSignatures, node_a.node.get_our_node_id());
|
||||
node_b.node.handle_announcement_signatures(&node_a.node.get_our_node_id(), &as_funding_msgs.1);
|
||||
|
@ -353,11 +357,11 @@ pub fn create_chan_between_nodes_with_value_b<'a, 'b>(node_a: &Node<'a, 'b>, nod
|
|||
((*announcement).clone(), (*as_update).clone(), (*bs_update).clone())
|
||||
}
|
||||
|
||||
pub fn create_announced_chan_between_nodes<'a, 'b, 'c>(nodes: &'a Vec<Node<'b, 'c>>, a: usize, b: usize, a_flags: InitFeatures, b_flags: InitFeatures) -> (msgs::ChannelUpdate, msgs::ChannelUpdate, [u8; 32], Transaction) {
|
||||
pub fn create_announced_chan_between_nodes<'a, 'b, 'c, 'd>(nodes: &'a Vec<Node<'b, 'c, 'd>>, a: usize, b: usize, a_flags: InitFeatures, b_flags: InitFeatures) -> (msgs::ChannelUpdate, msgs::ChannelUpdate, [u8; 32], Transaction) {
|
||||
create_announced_chan_between_nodes_with_value(nodes, a, b, 100000, 10001, a_flags, b_flags)
|
||||
}
|
||||
|
||||
pub fn create_announced_chan_between_nodes_with_value<'a, 'b, 'c>(nodes: &'a Vec<Node<'b, 'c>>, a: usize, b: usize, channel_value: u64, push_msat: u64, a_flags: InitFeatures, b_flags: InitFeatures) -> (msgs::ChannelUpdate, msgs::ChannelUpdate, [u8; 32], Transaction) {
|
||||
pub fn create_announced_chan_between_nodes_with_value<'a, 'b, 'c, 'd>(nodes: &'a Vec<Node<'b, 'c, 'd>>, a: usize, b: usize, channel_value: u64, push_msat: u64, a_flags: InitFeatures, b_flags: InitFeatures) -> (msgs::ChannelUpdate, msgs::ChannelUpdate, [u8; 32], Transaction) {
|
||||
let chan_announcement = create_chan_between_nodes_with_value(&nodes[a], &nodes[b], channel_value, push_msat, a_flags, b_flags);
|
||||
for node in nodes {
|
||||
assert!(node.router.handle_channel_announcement(&chan_announcement.0).unwrap());
|
||||
|
@ -427,7 +431,7 @@ macro_rules! check_closed_broadcast {
|
|||
}}
|
||||
}
|
||||
|
||||
pub fn close_channel<'a, 'b>(outbound_node: &Node<'a, 'b>, inbound_node: &Node<'a, 'b>, channel_id: &[u8; 32], funding_tx: Transaction, close_inbound_first: bool) -> (msgs::ChannelUpdate, msgs::ChannelUpdate, Transaction) {
|
||||
pub fn close_channel<'a, 'b, 'c>(outbound_node: &Node<'a, 'b, 'c>, inbound_node: &Node<'a, 'b, 'c>, channel_id: &[u8; 32], funding_tx: Transaction, close_inbound_first: bool) -> (msgs::ChannelUpdate, msgs::ChannelUpdate, Transaction) {
|
||||
let (node_a, broadcaster_a, struct_a) = if close_inbound_first { (&inbound_node.node, &inbound_node.tx_broadcaster, inbound_node) } else { (&outbound_node.node, &outbound_node.tx_broadcaster, outbound_node) };
|
||||
let (node_b, broadcaster_b) = if close_inbound_first { (&outbound_node.node, &outbound_node.tx_broadcaster) } else { (&inbound_node.node, &inbound_node.tx_broadcaster) };
|
||||
let (tx_a, tx_b);
|
||||
|
@ -514,7 +518,7 @@ impl SendEvent {
|
|||
}
|
||||
}
|
||||
|
||||
pub fn from_node<'a, 'b>(node: &Node<'a, 'b>) -> SendEvent {
|
||||
pub fn from_node<'a, 'b, 'c>(node: &Node<'a, 'b, 'c>) -> SendEvent {
|
||||
let mut events = node.node.get_and_clear_pending_msg_events();
|
||||
assert_eq!(events.len(), 1);
|
||||
SendEvent::from_event(events.pop().unwrap())
|
||||
|
@ -676,7 +680,7 @@ macro_rules! expect_payment_failed {
|
|||
}
|
||||
}
|
||||
|
||||
pub fn send_along_route_with_hash<'a, 'b>(origin_node: &Node<'a, 'b>, route: Route, expected_route: &[&Node<'a, 'b>], recv_value: u64, our_payment_hash: PaymentHash) {
|
||||
pub fn send_along_route_with_hash<'a, 'b, 'c>(origin_node: &Node<'a, 'b, 'c>, route: Route, expected_route: &[&Node<'a, 'b, 'c>], recv_value: u64, our_payment_hash: PaymentHash) {
|
||||
let mut payment_event = {
|
||||
origin_node.node.send_payment(route, our_payment_hash).unwrap();
|
||||
check_added_monitors!(origin_node, 1);
|
||||
|
@ -718,13 +722,13 @@ pub fn send_along_route_with_hash<'a, 'b>(origin_node: &Node<'a, 'b>, route: Rou
|
|||
}
|
||||
}
|
||||
|
||||
pub fn send_along_route<'a, 'b>(origin_node: &Node<'a, 'b>, route: Route, expected_route: &[&Node<'a, 'b>], recv_value: u64) -> (PaymentPreimage, PaymentHash) {
|
||||
pub fn send_along_route<'a, 'b, 'c>(origin_node: &Node<'a, 'b, 'c>, route: Route, expected_route: &[&Node<'a, 'b, 'c>], recv_value: u64) -> (PaymentPreimage, PaymentHash) {
|
||||
let (our_payment_preimage, our_payment_hash) = get_payment_preimage_hash!(origin_node);
|
||||
send_along_route_with_hash(origin_node, route, expected_route, recv_value, our_payment_hash);
|
||||
(our_payment_preimage, our_payment_hash)
|
||||
}
|
||||
|
||||
pub fn claim_payment_along_route<'a, 'b>(origin_node: &Node<'a, 'b>, expected_route: &[&Node<'a, 'b>], skip_last: bool, our_payment_preimage: PaymentPreimage, expected_amount: u64) {
|
||||
pub fn claim_payment_along_route<'a, 'b, 'c>(origin_node: &Node<'a, 'b, 'c>, expected_route: &[&Node<'a, 'b, 'c>], skip_last: bool, our_payment_preimage: PaymentPreimage, expected_amount: u64) {
|
||||
assert!(expected_route.last().unwrap().node.claim_funds(our_payment_preimage, expected_amount));
|
||||
check_added_monitors!(expected_route.last().unwrap(), 1);
|
||||
|
||||
|
@ -802,13 +806,13 @@ pub fn claim_payment_along_route<'a, 'b>(origin_node: &Node<'a, 'b>, expected_ro
|
|||
}
|
||||
}
|
||||
|
||||
pub fn claim_payment<'a, 'b>(origin_node: &Node<'a, 'b>, expected_route: &[&Node<'a, 'b>], our_payment_preimage: PaymentPreimage, expected_amount: u64) {
|
||||
pub fn claim_payment<'a, 'b, 'c>(origin_node: &Node<'a, 'b, 'c>, expected_route: &[&Node<'a, 'b, 'c>], our_payment_preimage: PaymentPreimage, expected_amount: u64) {
|
||||
claim_payment_along_route(origin_node, expected_route, false, our_payment_preimage, expected_amount);
|
||||
}
|
||||
|
||||
pub const TEST_FINAL_CLTV: u32 = 32;
|
||||
|
||||
pub fn route_payment<'a, 'b>(origin_node: &Node<'a, 'b>, expected_route: &[&Node<'a, 'b>], recv_value: u64) -> (PaymentPreimage, PaymentHash) {
|
||||
pub fn route_payment<'a, 'b, 'c>(origin_node: &Node<'a, 'b, 'c>, expected_route: &[&Node<'a, 'b, 'c>], recv_value: u64) -> (PaymentPreimage, PaymentHash) {
|
||||
let route = origin_node.router.get_route(&expected_route.last().unwrap().node.get_our_node_id(), None, &Vec::new(), recv_value, TEST_FINAL_CLTV).unwrap();
|
||||
assert_eq!(route.hops.len(), expected_route.len());
|
||||
for (node, hop) in expected_route.iter().zip(route.hops.iter()) {
|
||||
|
@ -818,7 +822,7 @@ pub fn route_payment<'a, 'b>(origin_node: &Node<'a, 'b>, expected_route: &[&Node
|
|||
send_along_route(origin_node, route, expected_route, recv_value)
|
||||
}
|
||||
|
||||
pub fn route_over_limit<'a, 'b>(origin_node: &Node<'a, 'b>, expected_route: &[&Node<'a, 'b>], recv_value: u64) {
|
||||
pub fn route_over_limit<'a, 'b, 'c>(origin_node: &Node<'a, 'b, 'c>, expected_route: &[&Node<'a, 'b, 'c>], recv_value: u64) {
|
||||
let route = origin_node.router.get_route(&expected_route.last().unwrap().node.get_our_node_id(), None, &Vec::new(), recv_value, TEST_FINAL_CLTV).unwrap();
|
||||
assert_eq!(route.hops.len(), expected_route.len());
|
||||
for (node, hop) in expected_route.iter().zip(route.hops.iter()) {
|
||||
|
@ -834,12 +838,12 @@ pub fn route_over_limit<'a, 'b>(origin_node: &Node<'a, 'b>, expected_route: &[&N
|
|||
};
|
||||
}
|
||||
|
||||
pub fn send_payment<'a, 'b>(origin: &Node<'a, 'b>, expected_route: &[&Node<'a, 'b>], recv_value: u64, expected_value: u64) {
|
||||
pub fn send_payment<'a, 'b, 'c>(origin: &Node<'a, 'b, 'c>, expected_route: &[&Node<'a, 'b, 'c>], recv_value: u64, expected_value: u64) {
|
||||
let our_payment_preimage = route_payment(&origin, expected_route, recv_value).0;
|
||||
claim_payment(&origin, expected_route, our_payment_preimage, expected_value);
|
||||
}
|
||||
|
||||
pub fn fail_payment_along_route<'a, 'b>(origin_node: &Node<'a, 'b>, expected_route: &[&Node<'a, 'b>], skip_last: bool, our_payment_hash: PaymentHash) {
|
||||
pub fn fail_payment_along_route<'a, 'b, 'c>(origin_node: &Node<'a, 'b, 'c>, expected_route: &[&Node<'a, 'b, 'c>], skip_last: bool, our_payment_hash: PaymentHash) {
|
||||
assert!(expected_route.last().unwrap().node.fail_htlc_backwards(&our_payment_hash));
|
||||
expect_pending_htlcs_forwardable!(expected_route.last().unwrap());
|
||||
check_added_monitors!(expected_route.last().unwrap(), 1);
|
||||
|
@ -908,11 +912,21 @@ pub fn fail_payment_along_route<'a, 'b>(origin_node: &Node<'a, 'b>, expected_rou
|
|||
}
|
||||
}
|
||||
|
||||
pub fn fail_payment<'a, 'b>(origin_node: &Node<'a, 'b>, expected_route: &[&Node<'a, 'b>], our_payment_hash: PaymentHash) {
|
||||
pub fn fail_payment<'a, 'b, 'c>(origin_node: &Node<'a, 'b, 'c>, expected_route: &[&Node<'a, 'b, 'c>], our_payment_hash: PaymentHash) {
|
||||
fail_payment_along_route(origin_node, expected_route, false, our_payment_hash);
|
||||
}
|
||||
|
||||
pub fn create_node_cfgs(node_count: usize) -> Vec<NodeCfg> {
|
||||
pub fn create_chanmon_cfgs(node_count: usize) -> Vec<TestChanMonCfg> {
|
||||
let mut chan_mon_cfgs = Vec::new();
|
||||
for i in 0..node_count {
|
||||
let tx_broadcaster = test_utils::TestBroadcaster{txn_broadcasted: Mutex::new(Vec::new()), broadcasted_txn: Mutex::new(HashSet::new())};
|
||||
chan_mon_cfgs.push(TestChanMonCfg{ tx_broadcaster });
|
||||
}
|
||||
|
||||
chan_mon_cfgs
|
||||
}
|
||||
|
||||
pub fn create_node_cfgs<'a>(node_count: usize, chanmon_cfgs: &'a Vec<TestChanMonCfg>) -> Vec<NodeCfg<'a>> {
|
||||
let mut nodes = Vec::new();
|
||||
let mut rng = thread_rng();
|
||||
|
||||
|
@ -920,31 +934,30 @@ pub fn create_node_cfgs(node_count: usize) -> Vec<NodeCfg> {
|
|||
let logger = Arc::new(test_utils::TestLogger::with_id(format!("node {}", i)));
|
||||
let fee_estimator = Arc::new(test_utils::TestFeeEstimator { sat_per_kw: 253 });
|
||||
let chain_monitor = Arc::new(chaininterface::ChainWatchInterfaceUtil::new(Network::Testnet, logger.clone() as Arc<Logger>));
|
||||
let tx_broadcaster = Arc::new(test_utils::TestBroadcaster{txn_broadcasted: Mutex::new(Vec::new()), broadcasted_txn: Mutex::new(HashSet::new())});
|
||||
let mut seed = [0; 32];
|
||||
rng.fill_bytes(&mut seed);
|
||||
let keys_manager = Arc::new(test_utils::TestKeysInterface::new(&seed, Network::Testnet, logger.clone() as Arc<Logger>));
|
||||
let chan_monitor = test_utils::TestChannelMonitor::new(chain_monitor.clone(), tx_broadcaster.clone(), logger.clone(), fee_estimator.clone());
|
||||
nodes.push(NodeCfg { chain_monitor, logger, tx_broadcaster, fee_estimator, chan_monitor, keys_manager, node_seed: seed });
|
||||
let chan_monitor = test_utils::TestChannelMonitor::new(chain_monitor.clone(), &chanmon_cfgs[i].tx_broadcaster, logger.clone(), fee_estimator.clone());
|
||||
nodes.push(NodeCfg { chain_monitor, logger, tx_broadcaster: &chanmon_cfgs[i].tx_broadcaster, fee_estimator, chan_monitor, keys_manager, node_seed: seed });
|
||||
}
|
||||
|
||||
nodes
|
||||
}
|
||||
|
||||
pub fn create_node_chanmgrs<'a, 'b>(node_count: usize, cfgs: &'a Vec<NodeCfg>, node_config: &[Option<UserConfig>]) -> Vec<ChannelManager<EnforcingChannelKeys, &'a TestChannelMonitor>> {
|
||||
pub fn create_node_chanmgrs<'a, 'b>(node_count: usize, cfgs: &'a Vec<NodeCfg<'b>>, node_config: &[Option<UserConfig>]) -> Vec<ChannelManager<EnforcingChannelKeys, &'a TestChannelMonitor<'b>, &'b test_utils::TestBroadcaster>> {
|
||||
let mut chanmgrs = Vec::new();
|
||||
for i in 0..node_count {
|
||||
let mut default_config = UserConfig::default();
|
||||
default_config.channel_options.announced_channel = true;
|
||||
default_config.peer_channel_config_limits.force_announced_channel_preference = false;
|
||||
let node = ChannelManager::new(Network::Testnet, cfgs[i].fee_estimator.clone(), &cfgs[i].chan_monitor, cfgs[i].tx_broadcaster.clone(), cfgs[i].logger.clone(), cfgs[i].keys_manager.clone(), if node_config[i].is_some() { node_config[i].clone().unwrap() } else { default_config }, 0).unwrap();
|
||||
let node = ChannelManager::new(Network::Testnet, cfgs[i].fee_estimator.clone(), &cfgs[i].chan_monitor, cfgs[i].tx_broadcaster, cfgs[i].logger.clone(), cfgs[i].keys_manager.clone(), if node_config[i].is_some() { node_config[i].clone().unwrap() } else { default_config }, 0).unwrap();
|
||||
chanmgrs.push(node);
|
||||
}
|
||||
|
||||
chanmgrs
|
||||
}
|
||||
|
||||
pub fn create_network<'a, 'b>(node_count: usize, cfgs: &'a Vec<NodeCfg>, chan_mgrs: &'b Vec<ChannelManager<EnforcingChannelKeys, &'a TestChannelMonitor>>) -> Vec<Node<'a, 'b>> {
|
||||
pub fn create_network<'a, 'b: 'a, 'c: 'b>(node_count: usize, cfgs: &'b Vec<NodeCfg<'c>>, chan_mgrs: &'a Vec<ChannelManager<EnforcingChannelKeys, &'b TestChannelMonitor<'c>, &'c test_utils::TestBroadcaster>>) -> Vec<Node<'a, 'b, 'c>> {
|
||||
let secp_ctx = Secp256k1::new();
|
||||
let mut nodes = Vec::new();
|
||||
let chan_count = Rc::new(RefCell::new(0));
|
||||
|
@ -956,7 +969,7 @@ pub fn create_network<'a, 'b>(node_count: usize, cfgs: &'a Vec<NodeCfg>, chan_mg
|
|||
block_notifier.register_listener(&chan_mgrs[i] as &chaininterface::ChainListener);
|
||||
let router = Router::new(PublicKey::from_secret_key(&secp_ctx, &cfgs[i].keys_manager.get_node_secret()), cfgs[i].chain_monitor.clone(), cfgs[i].logger.clone() as Arc<Logger>);
|
||||
nodes.push(Node{ chain_monitor: cfgs[i].chain_monitor.clone(), block_notifier,
|
||||
tx_broadcaster: cfgs[i].tx_broadcaster.clone(), chan_monitor: &cfgs[i].chan_monitor,
|
||||
tx_broadcaster: cfgs[i].tx_broadcaster, chan_monitor: &cfgs[i].chan_monitor,
|
||||
keys_manager: cfgs[i].keys_manager.clone(), node: &chan_mgrs[i], router,
|
||||
node_seed: cfgs[i].node_seed, network_chan_count: chan_count.clone(),
|
||||
network_payment_count: payment_count.clone(), logger: cfgs[i].logger.clone(),
|
||||
|
@ -982,7 +995,7 @@ pub enum HTLCType { NONE, TIMEOUT, SUCCESS }
|
|||
///
|
||||
/// All broadcast transactions must be accounted for in one of the above three types of we'll
|
||||
/// also fail.
|
||||
pub fn test_txn_broadcast<'a, 'b>(node: &Node<'a, 'b>, chan: &(msgs::ChannelUpdate, msgs::ChannelUpdate, [u8; 32], Transaction), commitment_tx: Option<Transaction>, has_htlc_tx: HTLCType) -> Vec<Transaction> {
|
||||
pub fn test_txn_broadcast<'a, 'b, 'c>(node: &Node<'a, 'b, 'c>, chan: &(msgs::ChannelUpdate, msgs::ChannelUpdate, [u8; 32], Transaction), commitment_tx: Option<Transaction>, has_htlc_tx: HTLCType) -> Vec<Transaction> {
|
||||
let mut node_txn = node.tx_broadcaster.txn_broadcasted.lock().unwrap();
|
||||
assert!(node_txn.len() >= if commitment_tx.is_some() { 0 } else { 1 } + if has_htlc_tx == HTLCType::NONE { 0 } else { 1 });
|
||||
|
||||
|
@ -1027,7 +1040,7 @@ pub fn test_txn_broadcast<'a, 'b>(node: &Node<'a, 'b>, chan: &(msgs::ChannelUpda
|
|||
|
||||
/// Tests that the given node has broadcast a claim transaction against the provided revoked
|
||||
/// HTLC transaction.
|
||||
pub fn test_revoked_htlc_claim_txn_broadcast<'a, 'b>(node: &Node<'a, 'b>, revoked_tx: Transaction, commitment_revoked_tx: Transaction) {
|
||||
pub fn test_revoked_htlc_claim_txn_broadcast<'a, 'b, 'c>(node: &Node<'a, 'b, 'c>, revoked_tx: Transaction, commitment_revoked_tx: Transaction) {
|
||||
let mut node_txn = node.tx_broadcaster.txn_broadcasted.lock().unwrap();
|
||||
// We should issue a 2nd transaction if one htlc is dropped from initial claiming tx
|
||||
// but sometimes not as feerate is too-low
|
||||
|
@ -1045,7 +1058,7 @@ pub fn test_revoked_htlc_claim_txn_broadcast<'a, 'b>(node: &Node<'a, 'b>, revoke
|
|||
assert!(node_txn.is_empty());
|
||||
}
|
||||
|
||||
pub fn check_preimage_claim<'a, 'b>(node: &Node<'a, 'b>, prev_txn: &Vec<Transaction>) -> Vec<Transaction> {
|
||||
pub fn check_preimage_claim<'a, 'b, 'c>(node: &Node<'a, 'b, 'c>, prev_txn: &Vec<Transaction>) -> Vec<Transaction> {
|
||||
let mut node_txn = node.tx_broadcaster.txn_broadcasted.lock().unwrap();
|
||||
|
||||
assert!(node_txn.len() >= 1);
|
||||
|
@ -1069,7 +1082,7 @@ pub fn check_preimage_claim<'a, 'b>(node: &Node<'a, 'b>, prev_txn: &Vec<Transact
|
|||
res
|
||||
}
|
||||
|
||||
pub fn get_announce_close_broadcast_events<'a, 'b>(nodes: &Vec<Node<'a, 'b>>, a: usize, b: usize) {
|
||||
pub fn get_announce_close_broadcast_events<'a, 'b, 'c>(nodes: &Vec<Node<'a, 'b, 'c>>, a: usize, b: usize) {
|
||||
let events_1 = nodes[a].node.get_and_clear_pending_msg_events();
|
||||
assert_eq!(events_1.len(), 1);
|
||||
let as_update = match events_1[0] {
|
||||
|
@ -1176,7 +1189,7 @@ macro_rules! handle_chan_reestablish_msgs {
|
|||
|
||||
/// pending_htlc_adds includes both the holding cell and in-flight update_add_htlcs, whereas
|
||||
/// for claims/fails they are separated out.
|
||||
pub fn reconnect_nodes<'a, 'b>(node_a: &Node<'a, 'b>, node_b: &Node<'a, 'b>, send_funding_locked: (bool, bool), pending_htlc_adds: (i64, i64), pending_htlc_claims: (usize, usize), pending_cell_htlc_claims: (usize, usize), pending_cell_htlc_fails: (usize, usize), pending_raa: (bool, bool)) {
|
||||
pub fn reconnect_nodes<'a, 'b, 'c>(node_a: &Node<'a, 'b, 'c>, node_b: &Node<'a, 'b, 'c>, send_funding_locked: (bool, bool), pending_htlc_adds: (i64, i64), pending_htlc_claims: (usize, usize), pending_cell_htlc_claims: (usize, usize), pending_cell_htlc_fails: (usize, usize), pending_raa: (bool, bool)) {
|
||||
node_a.node.peer_connected(&node_b.node.get_our_node_id(), &msgs::Init { features: InitFeatures::empty() });
|
||||
let reestablish_1 = get_chan_reestablish_msgs!(node_a, node_b);
|
||||
node_b.node.peer_connected(&node_a.node.get_our_node_id(), &msgs::Init { features: InitFeatures::empty() });
|
||||
|
|
|
@ -53,7 +53,8 @@ use ln::functional_test_utils::*;
|
|||
#[test]
|
||||
fn test_insane_channel_opens() {
|
||||
// Stand up a network of 2 nodes
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
|
||||
|
@ -110,7 +111,8 @@ fn test_insane_channel_opens() {
|
|||
|
||||
#[test]
|
||||
fn test_async_inbound_update_fee() {
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let mut nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
let chan = create_announced_chan_between_nodes(&nodes, 0, 1, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -222,7 +224,8 @@ fn test_async_inbound_update_fee() {
|
|||
fn test_update_fee_unordered_raa() {
|
||||
// Just the intro to the previous test followed by an out-of-order RAA (which caused a
|
||||
// crash in an earlier version of the update_fee patch)
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let mut nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
let chan = create_announced_chan_between_nodes(&nodes, 0, 1, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -274,7 +277,8 @@ fn test_update_fee_unordered_raa() {
|
|||
|
||||
#[test]
|
||||
fn test_multi_flight_update_fee() {
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
let chan = create_announced_chan_between_nodes(&nodes, 0, 1, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -390,7 +394,8 @@ fn test_1_conf_open() {
|
|||
bob_config.own_channel_config.minimum_depth = 1;
|
||||
bob_config.channel_options.announced_channel = true;
|
||||
bob_config.peer_channel_config_limits.force_announced_channel_preference = false;
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[Some(alice_config), Some(bob_config)]);
|
||||
let nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
|
||||
|
@ -419,7 +424,8 @@ fn do_test_sanity_on_in_flight_opens(steps: u8) {
|
|||
// serialization round-trips and simply do steps towards opening a channel and then drop the
|
||||
// Node objects.
|
||||
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
|
||||
|
@ -513,7 +519,8 @@ fn test_sanity_on_in_flight_opens() {
|
|||
|
||||
#[test]
|
||||
fn test_update_fee_vanilla() {
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
let chan = create_announced_chan_between_nodes(&nodes, 0, 1, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -553,7 +560,8 @@ fn test_update_fee_vanilla() {
|
|||
|
||||
#[test]
|
||||
fn test_update_fee_that_funder_cannot_afford() {
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
let channel_value = 1888;
|
||||
|
@ -604,7 +612,8 @@ fn test_update_fee_that_funder_cannot_afford() {
|
|||
|
||||
#[test]
|
||||
fn test_update_fee_with_fundee_update_add_htlc() {
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let mut nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
let chan = create_announced_chan_between_nodes(&nodes, 0, 1, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -700,7 +709,8 @@ fn test_update_fee_with_fundee_update_add_htlc() {
|
|||
|
||||
#[test]
|
||||
fn test_update_fee() {
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
let chan = create_announced_chan_between_nodes(&nodes, 0, 1, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -803,7 +813,8 @@ fn test_update_fee() {
|
|||
#[test]
|
||||
fn pre_funding_lock_shutdown_test() {
|
||||
// Test sending a shutdown prior to funding_locked after funding generation
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
let tx = create_chan_between_nodes_with_value_init(&nodes[0], &nodes[1], 8000000, 0, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -831,7 +842,8 @@ fn pre_funding_lock_shutdown_test() {
|
|||
#[test]
|
||||
fn updates_shutdown_wait() {
|
||||
// Test sending a shutdown with outstanding updates pending
|
||||
let node_cfgs = create_node_cfgs(3);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(3);
|
||||
let node_cfgs = create_node_cfgs(3, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(3, &node_cfgs, &[None, None, None]);
|
||||
let mut nodes = create_network(3, &node_cfgs, &node_chanmgrs);
|
||||
let chan_1 = create_announced_chan_between_nodes(&nodes, 0, 1, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -905,7 +917,8 @@ fn updates_shutdown_wait() {
|
|||
#[test]
|
||||
fn htlc_fail_async_shutdown() {
|
||||
// Test HTLCs fail if shutdown starts even if messages are delivered out-of-order
|
||||
let node_cfgs = create_node_cfgs(3);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(3);
|
||||
let node_cfgs = create_node_cfgs(3, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(3, &node_cfgs, &[None, None, None]);
|
||||
let mut nodes = create_network(3, &node_cfgs, &node_chanmgrs);
|
||||
let chan_1 = create_announced_chan_between_nodes(&nodes, 0, 1, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -988,7 +1001,8 @@ fn htlc_fail_async_shutdown() {
|
|||
fn do_test_shutdown_rebroadcast(recv_count: u8) {
|
||||
// Test that shutdown/closing_signed is re-sent on reconnect with a variable number of
|
||||
// messages delivered prior to disconnect
|
||||
let node_cfgs = create_node_cfgs(3);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(3);
|
||||
let node_cfgs = create_node_cfgs(3, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(3, &node_cfgs, &[None, None, None]);
|
||||
let nodes = create_network(3, &node_cfgs, &node_chanmgrs);
|
||||
let chan_1 = create_announced_chan_between_nodes(&nodes, 0, 1, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -1149,7 +1163,8 @@ fn test_shutdown_rebroadcast() {
|
|||
fn fake_network_test() {
|
||||
// Simple test which builds a network of ChannelManagers, connects them to each other, and
|
||||
// tests that payments get routed and transactions broadcast in semi-reasonable ways.
|
||||
let node_cfgs = create_node_cfgs(4);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(4);
|
||||
let node_cfgs = create_node_cfgs(4, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(4, &node_cfgs, &[None, None, None, None]);
|
||||
let nodes = create_network(4, &node_cfgs, &node_chanmgrs);
|
||||
|
||||
|
@ -1280,7 +1295,8 @@ fn holding_cell_htlc_counting() {
|
|||
// Tests that HTLCs in the holding cell count towards the pending HTLC limits on outbound HTLCs
|
||||
// to ensure we don't end up with HTLCs sitting around in our holding cell for several
|
||||
// commitment dance rounds.
|
||||
let node_cfgs = create_node_cfgs(3);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(3);
|
||||
let node_cfgs = create_node_cfgs(3, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(3, &node_cfgs, &[None, None, None]);
|
||||
let mut nodes = create_network(3, &node_cfgs, &node_chanmgrs);
|
||||
create_announced_chan_between_nodes(&nodes, 0, 1, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -1409,7 +1425,8 @@ fn holding_cell_htlc_counting() {
|
|||
fn duplicate_htlc_test() {
|
||||
// Test that we accept duplicate payment_hash HTLCs across the network and that
|
||||
// claiming/failing them are all separate and don't affect each other
|
||||
let node_cfgs = create_node_cfgs(6);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(6);
|
||||
let node_cfgs = create_node_cfgs(6, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(6, &node_cfgs, &[None, None, None, None, None, None]);
|
||||
let mut nodes = create_network(6, &node_cfgs, &node_chanmgrs);
|
||||
|
||||
|
@ -1438,7 +1455,8 @@ fn test_duplicate_htlc_different_direction_onchain() {
|
|||
// Test that ChannelMonitor doesn't generate 2 preimage txn
|
||||
// when we have 2 HTLCs with same preimage that go across a node
|
||||
// in opposite directions.
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
|
||||
|
@ -1505,7 +1523,8 @@ fn test_duplicate_htlc_different_direction_onchain() {
|
|||
|
||||
fn do_channel_reserve_test(test_recv: bool) {
|
||||
|
||||
let node_cfgs = create_node_cfgs(3);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(3);
|
||||
let node_cfgs = create_node_cfgs(3, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(3, &node_cfgs, &[None, None, None]);
|
||||
let mut nodes = create_network(3, &node_cfgs, &node_chanmgrs);
|
||||
let chan_1 = create_announced_chan_between_nodes_with_value(&nodes, 0, 1, 1900, 1001, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -1791,7 +1810,8 @@ fn channel_reserve_in_flight_removes() {
|
|||
// removed it fully. B now has the push_msat plus the first two HTLCs in value.
|
||||
// * Now B happily sends another HTLC, potentially violating its reserve value from A's point
|
||||
// of view (if A counts the AwaitingRemovedRemoteRevoke HTLC).
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let mut nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
let chan_1 = create_announced_chan_between_nodes(&nodes, 0, 1, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -1920,7 +1940,8 @@ fn channel_reserve_in_flight_removes() {
|
|||
fn channel_monitor_network_test() {
|
||||
// Simple test which builds a network of ChannelManagers, connects them to each other, and
|
||||
// tests that ChannelMonitor is able to recover from various states.
|
||||
let node_cfgs = create_node_cfgs(5);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(5);
|
||||
let node_cfgs = create_node_cfgs(5, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(5, &node_cfgs, &[None, None, None, None, None]);
|
||||
let nodes = create_network(5, &node_cfgs, &node_chanmgrs);
|
||||
|
||||
|
@ -2070,7 +2091,8 @@ fn test_justice_tx() {
|
|||
bob_config.peer_channel_config_limits.force_announced_channel_preference = false;
|
||||
bob_config.own_channel_config.our_to_self_delay = 6 * 24 * 3;
|
||||
let user_cfgs = [Some(alice_config), Some(bob_config)];
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &user_cfgs);
|
||||
let nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
// Create some new channels:
|
||||
|
@ -2161,7 +2183,8 @@ fn test_justice_tx() {
|
|||
fn revoked_output_claim() {
|
||||
// Simple test to ensure a node will claim a revoked output when a stale remote commitment
|
||||
// transaction is broadcast by its counterparty
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
let chan_1 = create_announced_chan_between_nodes(&nodes, 0, 1, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -2190,7 +2213,8 @@ fn revoked_output_claim() {
|
|||
#[test]
|
||||
fn claim_htlc_outputs_shared_tx() {
|
||||
// Node revoked old state, htlcs haven't time out yet, claim them in shared justice tx
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
|
||||
|
@ -2265,7 +2289,8 @@ fn claim_htlc_outputs_shared_tx() {
|
|||
#[test]
|
||||
fn claim_htlc_outputs_single_tx() {
|
||||
// Node revoked old state, htlcs have timed out, claim each of them in separated justice tx
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
|
||||
|
@ -2378,7 +2403,8 @@ fn test_htlc_on_chain_success() {
|
|||
// the HTLC outputs via the preimage it learned (which, once confirmed should generate a
|
||||
// PaymentSent event).
|
||||
|
||||
let node_cfgs = create_node_cfgs(3);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(3);
|
||||
let node_cfgs = create_node_cfgs(3, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(3, &node_cfgs, &[None, None, None]);
|
||||
let nodes = create_network(3, &node_cfgs, &node_chanmgrs);
|
||||
|
||||
|
@ -2547,7 +2573,8 @@ fn test_htlc_on_chain_timeout() {
|
|||
// \ \
|
||||
// B's HTLC timeout tx B's timeout tx
|
||||
|
||||
let node_cfgs = create_node_cfgs(3);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(3);
|
||||
let node_cfgs = create_node_cfgs(3, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(3, &node_cfgs, &[None, None, None]);
|
||||
let nodes = create_network(3, &node_cfgs, &node_chanmgrs);
|
||||
|
||||
|
@ -2657,7 +2684,8 @@ fn test_simple_commitment_revoked_fail_backward() {
|
|||
// Test that in case of a revoked commitment tx, we detect the resolution of output by justice tx
|
||||
// and fail backward accordingly.
|
||||
|
||||
let node_cfgs = create_node_cfgs(3);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(3);
|
||||
let node_cfgs = create_node_cfgs(3, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(3, &node_cfgs, &[None, None, None]);
|
||||
let nodes = create_network(3, &node_cfgs, &node_chanmgrs);
|
||||
|
||||
|
@ -2727,7 +2755,8 @@ fn do_test_commitment_revoked_fail_backward_exhaustive(deliver_bs_raa: bool, use
|
|||
// * Once they remove it, we will send a (the first) commitment_signed without the HTLC,
|
||||
// and once they revoke the previous commitment transaction (allowing us to send a new
|
||||
// commitment_signed) we will be free to fail/fulfill the HTLC backwards.
|
||||
let node_cfgs = create_node_cfgs(3);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(3);
|
||||
let node_cfgs = create_node_cfgs(3, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(3, &node_cfgs, &[None, None, None]);
|
||||
let mut nodes = create_network(3, &node_cfgs, &node_chanmgrs);
|
||||
|
||||
|
@ -2940,7 +2969,8 @@ fn test_commitment_revoked_fail_backward_exhaustive_b() {
|
|||
fn test_htlc_ignore_latest_remote_commitment() {
|
||||
// Test that HTLC transactions spending the latest remote commitment transaction are simply
|
||||
// ignored if we cannot claim them. This originally tickled an invalid unwrap().
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
create_announced_chan_between_nodes(&nodes, 0, 1, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -2964,7 +2994,8 @@ fn test_htlc_ignore_latest_remote_commitment() {
|
|||
#[test]
|
||||
fn test_force_close_fail_back() {
|
||||
// Check which HTLCs are failed-backwards on channel force-closure
|
||||
let node_cfgs = create_node_cfgs(3);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(3);
|
||||
let node_cfgs = create_node_cfgs(3, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(3, &node_cfgs, &[None, None, None]);
|
||||
let mut nodes = create_network(3, &node_cfgs, &node_chanmgrs);
|
||||
create_announced_chan_between_nodes(&nodes, 0, 1, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -3040,7 +3071,8 @@ fn test_force_close_fail_back() {
|
|||
#[test]
|
||||
fn test_unconf_chan() {
|
||||
// After creating a chan between nodes, we disconnect all blocks previously seen to force a channel close on nodes[0] side
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
create_announced_chan_between_nodes(&nodes, 0, 1, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -3071,7 +3103,8 @@ fn test_unconf_chan() {
|
|||
#[test]
|
||||
fn test_simple_peer_disconnect() {
|
||||
// Test that we can reconnect when there are no lost messages
|
||||
let node_cfgs = create_node_cfgs(3);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(3);
|
||||
let node_cfgs = create_node_cfgs(3, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(3, &node_cfgs, &[None, None, None]);
|
||||
let nodes = create_network(3, &node_cfgs, &node_chanmgrs);
|
||||
create_announced_chan_between_nodes(&nodes, 0, 1, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -3126,7 +3159,8 @@ fn test_simple_peer_disconnect() {
|
|||
|
||||
fn do_test_drop_messages_peer_disconnect(messages_delivered: u8) {
|
||||
// Test that we can reconnect when in-flight HTLC updates get dropped
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let mut nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
if messages_delivered == 0 {
|
||||
|
@ -3334,7 +3368,8 @@ fn test_drop_messages_peer_disconnect_b() {
|
|||
#[test]
|
||||
fn test_funding_peer_disconnect() {
|
||||
// Test that we can lock in our funding tx while disconnected
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
let tx = create_chan_between_nodes_with_value_init(&nodes[0], &nodes[1], 100000, 10001, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -3418,7 +3453,8 @@ fn test_funding_peer_disconnect() {
|
|||
fn test_drop_messages_peer_disconnect_dual_htlc() {
|
||||
// Test that we can handle reconnecting when both sides of a channel have pending
|
||||
// commitment_updates when we disconnect.
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let mut nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
create_announced_chan_between_nodes(&nodes, 0, 1, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -3559,7 +3595,8 @@ fn test_drop_messages_peer_disconnect_dual_htlc() {
|
|||
fn test_invalid_channel_announcement() {
|
||||
//Test BOLT 7 channel_announcement msg requirement for final node, gather data to build customed channel_announcement msgs
|
||||
let secp_ctx = Secp256k1::new();
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
|
||||
|
@ -3633,10 +3670,11 @@ fn test_invalid_channel_announcement() {
|
|||
|
||||
#[test]
|
||||
fn test_no_txn_manager_serialize_deserialize() {
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let new_chan_monitor: test_utils::TestChannelMonitor;
|
||||
let nodes_0_deserialized: ChannelManager<EnforcingChannelKeys, &test_utils::TestChannelMonitor>;
|
||||
let nodes_0_deserialized: ChannelManager<EnforcingChannelKeys, &test_utils::TestChannelMonitor, &test_utils::TestBroadcaster>;
|
||||
let mut nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
|
||||
let tx = create_chan_between_nodes_with_value_init(&nodes[0], &nodes[1], 100000, 10001, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -3659,7 +3697,7 @@ fn test_no_txn_manager_serialize_deserialize() {
|
|||
let (_, nodes_0_deserialized_tmp) = {
|
||||
let mut channel_monitors = HashMap::new();
|
||||
channel_monitors.insert(chan_0_monitor.get_funding_txo().unwrap(), &mut chan_0_monitor);
|
||||
<(Sha256dHash, ChannelManager<EnforcingChannelKeys, &test_utils::TestChannelMonitor>)>::read(&mut nodes_0_read, ChannelManagerReadArgs {
|
||||
<(Sha256dHash, ChannelManager<EnforcingChannelKeys, &test_utils::TestChannelMonitor, &test_utils::TestBroadcaster>)>::read(&mut nodes_0_read, ChannelManagerReadArgs {
|
||||
default_config: config,
|
||||
keys_manager,
|
||||
fee_estimator: Arc::new(test_utils::TestFeeEstimator { sat_per_kw: 253 }),
|
||||
|
@ -3701,10 +3739,11 @@ fn test_no_txn_manager_serialize_deserialize() {
|
|||
|
||||
#[test]
|
||||
fn test_simple_manager_serialize_deserialize() {
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let new_chan_monitor: test_utils::TestChannelMonitor;
|
||||
let nodes_0_deserialized: ChannelManager<EnforcingChannelKeys, &test_utils::TestChannelMonitor>;
|
||||
let nodes_0_deserialized: ChannelManager<EnforcingChannelKeys, &test_utils::TestChannelMonitor, &test_utils::TestBroadcaster>;
|
||||
let mut nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
create_announced_chan_between_nodes(&nodes, 0, 1, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
||||
|
@ -3728,7 +3767,7 @@ fn test_simple_manager_serialize_deserialize() {
|
|||
let (_, nodes_0_deserialized_tmp) = {
|
||||
let mut channel_monitors = HashMap::new();
|
||||
channel_monitors.insert(chan_0_monitor.get_funding_txo().unwrap(), &mut chan_0_monitor);
|
||||
<(Sha256dHash, ChannelManager<EnforcingChannelKeys, &test_utils::TestChannelMonitor>)>::read(&mut nodes_0_read, ChannelManagerReadArgs {
|
||||
<(Sha256dHash, ChannelManager<EnforcingChannelKeys, &test_utils::TestChannelMonitor, &test_utils::TestBroadcaster>)>::read(&mut nodes_0_read, ChannelManagerReadArgs {
|
||||
default_config: UserConfig::default(),
|
||||
keys_manager,
|
||||
fee_estimator: Arc::new(test_utils::TestFeeEstimator { sat_per_kw: 253 }),
|
||||
|
@ -3754,10 +3793,11 @@ fn test_simple_manager_serialize_deserialize() {
|
|||
#[test]
|
||||
fn test_manager_serialize_deserialize_inconsistent_monitor() {
|
||||
// Test deserializing a ChannelManager with an out-of-date ChannelMonitor
|
||||
let node_cfgs = create_node_cfgs(4);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(4);
|
||||
let node_cfgs = create_node_cfgs(4, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(4, &node_cfgs, &[None, None, None, None]);
|
||||
let new_chan_monitor: test_utils::TestChannelMonitor;
|
||||
let nodes_0_deserialized: ChannelManager<EnforcingChannelKeys, &test_utils::TestChannelMonitor>;
|
||||
let nodes_0_deserialized: ChannelManager<EnforcingChannelKeys, &test_utils::TestChannelMonitor, &test_utils::TestBroadcaster>;
|
||||
let mut nodes = create_network(4, &node_cfgs, &node_chanmgrs);
|
||||
create_announced_chan_between_nodes(&nodes, 0, 1, InitFeatures::supported(), InitFeatures::supported());
|
||||
create_announced_chan_between_nodes(&nodes, 2, 0, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -3794,7 +3834,7 @@ fn test_manager_serialize_deserialize_inconsistent_monitor() {
|
|||
|
||||
let mut nodes_0_read = &nodes_0_serialized[..];
|
||||
let keys_manager = Arc::new(test_utils::TestKeysInterface::new(&nodes[0].node_seed, Network::Testnet, Arc::new(test_utils::TestLogger::new())));
|
||||
let (_, nodes_0_deserialized_tmp) = <(Sha256dHash, ChannelManager<EnforcingChannelKeys, &test_utils::TestChannelMonitor>)>::read(&mut nodes_0_read, ChannelManagerReadArgs {
|
||||
let (_, nodes_0_deserialized_tmp) = <(Sha256dHash, ChannelManager<EnforcingChannelKeys, &test_utils::TestChannelMonitor, &test_utils::TestBroadcaster>)>::read(&mut nodes_0_read, ChannelManagerReadArgs {
|
||||
default_config: UserConfig::default(),
|
||||
keys_manager,
|
||||
fee_estimator: Arc::new(test_utils::TestFeeEstimator { sat_per_kw: 253 }),
|
||||
|
@ -3956,7 +3996,8 @@ macro_rules! check_spendable_outputs {
|
|||
#[test]
|
||||
fn test_claim_sizeable_push_msat() {
|
||||
// Incidentally test SpendableOutput event generation due to detection of to_local output on commitment tx
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
|
||||
|
@ -3979,7 +4020,8 @@ fn test_claim_sizeable_push_msat() {
|
|||
fn test_claim_on_remote_sizeable_push_msat() {
|
||||
// Same test as previous, just test on remote commitment tx, as per_commitment_point registration changes following you're funder/fundee and
|
||||
// to_remote output is encumbered by a P2WPKH
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
|
||||
|
@ -4006,7 +4048,8 @@ fn test_claim_on_remote_revoked_sizeable_push_msat() {
|
|||
// Same test as previous, just test on remote revoked commitment tx, as per_commitment_point registration changes following you're funder/fundee and
|
||||
// to_remote output is encumbered by a P2WPKH
|
||||
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
|
||||
|
@ -4032,7 +4075,8 @@ fn test_claim_on_remote_revoked_sizeable_push_msat() {
|
|||
|
||||
#[test]
|
||||
fn test_static_spendable_outputs_preimage_tx() {
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
|
||||
|
@ -4077,7 +4121,8 @@ eprintln!("{:?}", node_txn[1]);
|
|||
|
||||
#[test]
|
||||
fn test_static_spendable_outputs_justice_tx_revoked_commitment_tx() {
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
|
||||
|
@ -4108,7 +4153,8 @@ fn test_static_spendable_outputs_justice_tx_revoked_commitment_tx() {
|
|||
|
||||
#[test]
|
||||
fn test_static_spendable_outputs_justice_tx_revoked_htlc_timeout_tx() {
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
|
||||
|
@ -4154,7 +4200,8 @@ fn test_static_spendable_outputs_justice_tx_revoked_htlc_timeout_tx() {
|
|||
|
||||
#[test]
|
||||
fn test_static_spendable_outputs_justice_tx_revoked_htlc_success_tx() {
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
|
||||
|
@ -4209,7 +4256,8 @@ fn test_onchain_to_onchain_claim() {
|
|||
// Finally, check that B will claim the HTLC output if A's latest commitment transaction
|
||||
// gets broadcast.
|
||||
|
||||
let node_cfgs = create_node_cfgs(3);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(3);
|
||||
let node_cfgs = create_node_cfgs(3, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(3, &node_cfgs, &[None, None, None]);
|
||||
let nodes = create_network(3, &node_cfgs, &node_chanmgrs);
|
||||
|
||||
|
@ -4301,7 +4349,8 @@ fn test_onchain_to_onchain_claim() {
|
|||
fn test_duplicate_payment_hash_one_failure_one_success() {
|
||||
// Topology : A --> B --> C
|
||||
// We route 2 payments with same hash between B and C, one will be timeout, the other successfully claim
|
||||
let node_cfgs = create_node_cfgs(3);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(3);
|
||||
let node_cfgs = create_node_cfgs(3, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(3, &node_cfgs, &[None, None, None]);
|
||||
let mut nodes = create_network(3, &node_cfgs, &node_chanmgrs);
|
||||
|
||||
|
@ -4420,7 +4469,8 @@ fn test_duplicate_payment_hash_one_failure_one_success() {
|
|||
|
||||
#[test]
|
||||
fn test_dynamic_spendable_outputs_local_htlc_success_tx() {
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
|
||||
|
@ -4471,7 +4521,8 @@ fn do_test_fail_backwards_unrevoked_remote_announce(deliver_last_raa: bool, anno
|
|||
// - C - D -
|
||||
// B / \ F
|
||||
// And test where C fails back to A/B when D announces its latest commitment transaction
|
||||
let node_cfgs = create_node_cfgs(6);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(6);
|
||||
let node_cfgs = create_node_cfgs(6, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(6, &node_cfgs, &[None, None, None, None, None, None]);
|
||||
let nodes = create_network(6, &node_cfgs, &node_chanmgrs);
|
||||
|
||||
|
@ -4712,7 +4763,8 @@ fn test_fail_backwards_previous_remote_announce() {
|
|||
|
||||
#[test]
|
||||
fn test_dynamic_spendable_outputs_local_htlc_timeout_tx() {
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
|
||||
|
@ -4749,7 +4801,8 @@ fn test_dynamic_spendable_outputs_local_htlc_timeout_tx() {
|
|||
|
||||
#[test]
|
||||
fn test_static_output_closing_tx() {
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
|
||||
|
@ -4771,7 +4824,8 @@ fn test_static_output_closing_tx() {
|
|||
}
|
||||
|
||||
fn do_htlc_claim_local_commitment_only(use_dust: bool) {
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
let chan = create_announced_chan_between_nodes(&nodes, 0, 1, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -4810,7 +4864,8 @@ fn do_htlc_claim_local_commitment_only(use_dust: bool) {
|
|||
}
|
||||
|
||||
fn do_htlc_claim_current_remote_commitment_only(use_dust: bool) {
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let mut nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
let chan = create_announced_chan_between_nodes(&nodes, 0, 1, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -4837,7 +4892,8 @@ fn do_htlc_claim_current_remote_commitment_only(use_dust: bool) {
|
|||
}
|
||||
|
||||
fn do_htlc_claim_previous_remote_commitment_only(use_dust: bool, check_revoke_no_close: bool) {
|
||||
let node_cfgs = create_node_cfgs(3);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(3);
|
||||
let node_cfgs = create_node_cfgs(3, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(3, &node_cfgs, &[None, None, None]);
|
||||
let nodes = create_network(3, &node_cfgs, &node_chanmgrs);
|
||||
let chan = create_announced_chan_between_nodes(&nodes, 0, 1, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -5136,7 +5192,8 @@ fn test_onion_failure() {
|
|||
const NODE: u16 = 0x2000;
|
||||
const UPDATE: u16 = 0x1000;
|
||||
|
||||
let node_cfgs = create_node_cfgs(3);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(3);
|
||||
let node_cfgs = create_node_cfgs(3, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(3, &node_cfgs, &[None, None, None]);
|
||||
let mut nodes = create_network(3, &node_cfgs, &node_chanmgrs);
|
||||
for node in nodes.iter() {
|
||||
|
@ -5364,7 +5421,8 @@ fn test_onion_failure() {
|
|||
#[test]
|
||||
#[should_panic]
|
||||
fn bolt2_open_channel_sending_node_checks_part1() { //This test needs to be on its own as we are catching a panic
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
//Force duplicate channel ids
|
||||
|
@ -5385,7 +5443,8 @@ fn bolt2_open_channel_sending_node_checks_part1() { //This test needs to be on i
|
|||
|
||||
#[test]
|
||||
fn bolt2_open_channel_sending_node_checks_part2() {
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
|
||||
|
@ -5435,7 +5494,8 @@ fn bolt2_open_channel_sending_node_checks_part2() {
|
|||
fn test_update_add_htlc_bolt2_sender_value_below_minimum_msat() {
|
||||
//BOLT2 Requirement: MUST offer amount_msat greater than 0.
|
||||
//BOLT2 Requirement: MUST NOT offer amount_msat below the receiving node's htlc_minimum_msat (same validation check catches both of these)
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let mut nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
let _chan = create_announced_chan_between_nodes_with_value(&nodes, 0, 1, 100000, 95000000, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -5459,7 +5519,8 @@ fn test_update_add_htlc_bolt2_sender_value_below_minimum_msat() {
|
|||
fn test_update_add_htlc_bolt2_sender_cltv_expiry_too_high() {
|
||||
//BOLT 2 Requirement: MUST set cltv_expiry less than 500000000.
|
||||
//It is enforced when constructing a route.
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let mut nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
let _chan = create_announced_chan_between_nodes_with_value(&nodes, 0, 1, 100000, 0, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -5480,7 +5541,8 @@ fn test_update_add_htlc_bolt2_sender_exceed_max_htlc_num_and_htlc_id_increment()
|
|||
//BOLT 2 Requirement: if result would be offering more than the remote's max_accepted_htlcs HTLCs, in the remote commitment transaction: MUST NOT add an HTLC.
|
||||
//BOLT 2 Requirement: for the first HTLC it offers MUST set id to 0.
|
||||
//BOLT 2 Requirement: MUST increase the value of id by 1 for each successive offer.
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let mut nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
let chan = create_announced_chan_between_nodes_with_value(&nodes, 0, 1, 1000000, 0, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -5525,7 +5587,8 @@ fn test_update_add_htlc_bolt2_sender_exceed_max_htlc_num_and_htlc_id_increment()
|
|||
#[test]
|
||||
fn test_update_add_htlc_bolt2_sender_exceed_max_htlc_value_in_flight() {
|
||||
//BOLT 2 Requirement: if the sum of total offered HTLCs would exceed the remote's max_htlc_value_in_flight_msat: MUST NOT add an HTLC.
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let mut nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
let channel_value = 100000;
|
||||
|
@ -5553,7 +5616,8 @@ fn test_update_add_htlc_bolt2_sender_exceed_max_htlc_value_in_flight() {
|
|||
#[test]
|
||||
fn test_update_add_htlc_bolt2_receiver_check_amount_received_more_than_min() {
|
||||
//BOLT2 Requirement: receiving an amount_msat equal to 0, OR less than its own htlc_minimum_msat -> SHOULD fail the channel.
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let mut nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
let chan = create_announced_chan_between_nodes_with_value(&nodes, 0, 1, 100000, 95000000, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -5578,7 +5642,8 @@ fn test_update_add_htlc_bolt2_receiver_check_amount_received_more_than_min() {
|
|||
#[test]
|
||||
fn test_update_add_htlc_bolt2_receiver_sender_can_afford_amount_sent() {
|
||||
//BOLT2 Requirement: receiving an amount_msat that the sending node cannot afford at the current feerate_per_kw (while maintaining its channel reserve): SHOULD fail the channel
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let mut nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
let chan = create_announced_chan_between_nodes_with_value(&nodes, 0, 1, 100000, 95000000, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -5603,7 +5668,8 @@ fn test_update_add_htlc_bolt2_receiver_sender_can_afford_amount_sent() {
|
|||
fn test_update_add_htlc_bolt2_receiver_check_max_htlc_limit() {
|
||||
//BOLT 2 Requirement: if a sending node adds more than its max_accepted_htlcs HTLCs to its local commitment transaction: SHOULD fail the channel
|
||||
//BOLT 2 Requirement: MUST allow multiple HTLCs with the same payment_hash.
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let mut nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
let chan = create_announced_chan_between_nodes_with_value(&nodes, 0, 1, 100000, 95000000, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -5646,7 +5712,8 @@ fn test_update_add_htlc_bolt2_receiver_check_max_htlc_limit() {
|
|||
#[test]
|
||||
fn test_update_add_htlc_bolt2_receiver_check_max_in_flight_msat() {
|
||||
//OR adds more than its max_htlc_value_in_flight_msat worth of offered HTLCs to its local commitment transaction: SHOULD fail the channel
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let mut nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
let chan = create_announced_chan_between_nodes_with_value(&nodes, 0, 1, 1000000, 1000000, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -5666,7 +5733,8 @@ fn test_update_add_htlc_bolt2_receiver_check_max_in_flight_msat() {
|
|||
#[test]
|
||||
fn test_update_add_htlc_bolt2_receiver_check_cltv_expiry() {
|
||||
//BOLT2 Requirement: if sending node sets cltv_expiry to greater or equal to 500000000: SHOULD fail the channel.
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let mut nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
create_announced_chan_between_nodes_with_value(&nodes, 0, 1, 100000, 95000000, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -5688,7 +5756,8 @@ fn test_update_add_htlc_bolt2_receiver_check_repeated_id_ignore() {
|
|||
//BOLT 2 requirement: if the sender did not previously acknowledge the commitment of that HTLC: MUST ignore a repeated id value after a reconnection.
|
||||
// We test this by first testing that that repeated HTLCs pass commitment signature checks
|
||||
// after disconnect and that non-sequential htlc_ids result in a channel failure.
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let mut nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
create_announced_chan_between_nodes(&nodes, 0, 1, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -5731,7 +5800,8 @@ fn test_update_add_htlc_bolt2_receiver_check_repeated_id_ignore() {
|
|||
fn test_update_fulfill_htlc_bolt2_update_fulfill_htlc_before_commitment() {
|
||||
//BOLT 2 Requirement: until the corresponding HTLC is irrevocably committed in both sides' commitment transactions: MUST NOT send an update_fulfill_htlc, update_fail_htlc, or update_fail_malformed_htlc.
|
||||
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let mut nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
let chan = create_announced_chan_between_nodes(&nodes, 0, 1, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -5760,7 +5830,8 @@ fn test_update_fulfill_htlc_bolt2_update_fulfill_htlc_before_commitment() {
|
|||
fn test_update_fulfill_htlc_bolt2_update_fail_htlc_before_commitment() {
|
||||
//BOLT 2 Requirement: until the corresponding HTLC is irrevocably committed in both sides' commitment transactions: MUST NOT send an update_fulfill_htlc, update_fail_htlc, or update_fail_malformed_htlc.
|
||||
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let mut nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
let chan = create_announced_chan_between_nodes(&nodes, 0, 1, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -5789,7 +5860,8 @@ fn test_update_fulfill_htlc_bolt2_update_fail_htlc_before_commitment() {
|
|||
fn test_update_fulfill_htlc_bolt2_update_fail_malformed_htlc_before_commitment() {
|
||||
//BOLT 2 Requirement: until the corresponding HTLC is irrevocably committed in both sides' commitment transactions: MUST NOT send an update_fulfill_htlc, update_fail_htlc, or update_fail_malformed_htlc.
|
||||
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let mut nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
let chan = create_announced_chan_between_nodes(&nodes, 0, 1, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -5819,7 +5891,8 @@ fn test_update_fulfill_htlc_bolt2_update_fail_malformed_htlc_before_commitment()
|
|||
fn test_update_fulfill_htlc_bolt2_incorrect_htlc_id() {
|
||||
//BOLT 2 Requirement: A receiving node: if the id does not correspond to an HTLC in its current commitment transaction MUST fail the channel.
|
||||
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
create_announced_chan_between_nodes(&nodes, 0, 1, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -5858,7 +5931,8 @@ fn test_update_fulfill_htlc_bolt2_incorrect_htlc_id() {
|
|||
fn test_update_fulfill_htlc_bolt2_wrong_preimage() {
|
||||
//BOLT 2 Requirement: A receiving node: if the payment_preimage value in update_fulfill_htlc doesn't SHA256 hash to the corresponding HTLC payment_hash MUST fail the channel.
|
||||
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
create_announced_chan_between_nodes(&nodes, 0, 1, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -5898,7 +5972,8 @@ fn test_update_fulfill_htlc_bolt2_wrong_preimage() {
|
|||
fn test_update_fulfill_htlc_bolt2_missing_badonion_bit_for_malformed_htlc_message() {
|
||||
//BOLT 2 Requirement: A receiving node: if the BADONION bit in failure_code is not set for update_fail_malformed_htlc MUST fail the channel.
|
||||
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let mut nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
create_announced_chan_between_nodes_with_value(&nodes, 0, 1, 1000000, 1000000, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -5942,7 +6017,8 @@ fn test_update_fulfill_htlc_bolt2_after_malformed_htlc_message_must_forward_upda
|
|||
//BOLT 2 Requirement: a receiving node which has an outgoing HTLC canceled by update_fail_malformed_htlc:
|
||||
// * MUST return an error in the update_fail_htlc sent to the link which originally sent the HTLC, using the failure_code given and setting the data to sha256_of_onion.
|
||||
|
||||
let node_cfgs = create_node_cfgs(3);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(3);
|
||||
let node_cfgs = create_node_cfgs(3, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(3, &node_cfgs, &[None, None, None]);
|
||||
let mut nodes = create_network(3, &node_cfgs, &node_chanmgrs);
|
||||
create_announced_chan_between_nodes_with_value(&nodes, 0, 1, 1000000, 1000000, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -6019,7 +6095,8 @@ fn do_test_failure_delay_dust_htlc_local_commitment(announce_latest: bool) {
|
|||
// We can have at most two valid local commitment tx, so both cases must be covered, and both txs must be checked to get them all as
|
||||
// HTLC could have been removed from lastest local commitment tx but still valid until we get remote RAA
|
||||
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
let chan =create_announced_chan_between_nodes(&nodes, 0, 1, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -6111,7 +6188,8 @@ fn test_no_failure_dust_htlc_local_commitment() {
|
|||
// Transaction filters for failing back dust htlc based on local commitment txn infos has been
|
||||
// prone to error, we test here that a dummy transaction don't fail them.
|
||||
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
let chan = create_announced_chan_between_nodes(&nodes, 0, 1, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -6167,7 +6245,8 @@ fn do_test_sweep_outbound_htlc_failure_update(revoked: bool, local: bool) {
|
|||
// Broadcast of local commitment tx, trigger failure-update of dust-HTLCs
|
||||
// Broadcast of HTLC-timeout tx on local commitment tx, trigger failure-update of non-dust HTLCs
|
||||
|
||||
let node_cfgs = create_node_cfgs(3);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(3);
|
||||
let node_cfgs = create_node_cfgs(3, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(3, &node_cfgs, &[None, None, None]);
|
||||
let nodes = create_network(3, &node_cfgs, &node_chanmgrs);
|
||||
let chan = create_announced_chan_between_nodes(&nodes, 0, 1, InitFeatures::supported(), InitFeatures::supported());
|
||||
|
@ -6300,7 +6379,8 @@ fn test_upfront_shutdown_script() {
|
|||
config.peer_channel_config_limits.force_announced_channel_preference = false;
|
||||
config.channel_options.commit_upfront_shutdown_pubkey = false;
|
||||
let user_cfgs = [None, Some(config), None];
|
||||
let node_cfgs = create_node_cfgs(3);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(3);
|
||||
let node_cfgs = create_node_cfgs(3, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(3, &node_cfgs, &user_cfgs);
|
||||
let nodes = create_network(3, &node_cfgs, &node_chanmgrs);
|
||||
|
||||
|
@ -6397,7 +6477,8 @@ fn test_user_configurable_csv_delay() {
|
|||
let mut high_their_to_self_config = UserConfig::default();
|
||||
high_their_to_self_config.peer_channel_config_limits.their_to_self_delay = 100;
|
||||
let user_cfgs = [Some(high_their_to_self_config.clone()), None];
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &user_cfgs);
|
||||
let nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
|
||||
|
@ -6454,9 +6535,11 @@ fn test_data_loss_protect() {
|
|||
// * we don't broadcast our Local Commitment Tx in case of fallen behind
|
||||
// * we close channel in case of detecting other being fallen behind
|
||||
// * we are able to claim our own outputs thanks to remote my_current_per_commitment_point
|
||||
let tx_broadcaster;
|
||||
let monitor;
|
||||
let node_state_0;
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let mut nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
|
||||
|
@ -6477,18 +6560,18 @@ fn test_data_loss_protect() {
|
|||
let logger: Arc<Logger> = Arc::new(test_utils::TestLogger::with_id(format!("node {}", 0)));
|
||||
let mut chan_monitor = <(Sha256dHash, ChannelMonitor<EnforcingChannelKeys>)>::read(&mut ::std::io::Cursor::new(previous_chan_monitor_state.0), Arc::clone(&logger)).unwrap().1;
|
||||
let chain_monitor = Arc::new(ChainWatchInterfaceUtil::new(Network::Testnet, Arc::clone(&logger)));
|
||||
let tx_broadcaster = Arc::new(test_utils::TestBroadcaster{txn_broadcasted: Mutex::new(Vec::new()), broadcasted_txn: Mutex::new(HashSet::new())});
|
||||
tx_broadcaster = test_utils::TestBroadcaster{txn_broadcasted: Mutex::new(Vec::new()), broadcasted_txn: Mutex::new(HashSet::new())};
|
||||
let feeest = Arc::new(test_utils::TestFeeEstimator { sat_per_kw: 253 });
|
||||
monitor = test_utils::TestChannelMonitor::new(chain_monitor.clone(), tx_broadcaster.clone(), logger.clone(), feeest.clone());
|
||||
monitor = test_utils::TestChannelMonitor::new(chain_monitor.clone(), &tx_broadcaster, logger.clone(), feeest.clone());
|
||||
node_state_0 = {
|
||||
let mut channel_monitors = HashMap::new();
|
||||
channel_monitors.insert(OutPoint { txid: chan.3.txid(), index: 0 }, &mut chan_monitor);
|
||||
<(Sha256dHash, ChannelManager<EnforcingChannelKeys, &test_utils::TestChannelMonitor>)>::read(&mut ::std::io::Cursor::new(previous_node_state), ChannelManagerReadArgs {
|
||||
<(Sha256dHash, ChannelManager<EnforcingChannelKeys, &test_utils::TestChannelMonitor, &test_utils::TestBroadcaster>)>::read(&mut ::std::io::Cursor::new(previous_node_state), ChannelManagerReadArgs {
|
||||
keys_manager: Arc::new(test_utils::TestKeysInterface::new(&nodes[0].node_seed, Network::Testnet, Arc::clone(&logger))),
|
||||
fee_estimator: feeest.clone(),
|
||||
monitor: &monitor,
|
||||
logger: Arc::clone(&logger),
|
||||
tx_broadcaster,
|
||||
tx_broadcaster: &tx_broadcaster,
|
||||
default_config: UserConfig::default(),
|
||||
channel_monitors: &mut channel_monitors,
|
||||
}).unwrap().1
|
||||
|
@ -6573,7 +6656,8 @@ fn test_check_htlc_underpaying() {
|
|||
// sending a probe payment (i.e less than expected value0
|
||||
// to B, B should refuse payment.
|
||||
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
|
||||
|
@ -6621,7 +6705,8 @@ fn test_announce_disable_channels() {
|
|||
// Create 2 channels between A and B. Disconnect B. Call timer_chan_freshness_every_min and check for generated
|
||||
// ChannelUpdate. Reconnect B, reestablish and check there is non-generated ChannelUpdate.
|
||||
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
|
||||
|
@ -6682,7 +6767,8 @@ fn test_bump_penalty_txn_on_revoked_commitment() {
|
|||
// In case of penalty txn with too low feerates for getting into mempools, RBF-bump them to be sure
|
||||
// we're able to claim outputs on revoked commitment transaction before timelocks expiration
|
||||
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
|
||||
|
@ -6783,7 +6869,8 @@ fn test_bump_penalty_txn_on_revoked_htlcs() {
|
|||
// In case of penalty txn with too low feerates for getting into mempools, RBF-bump them to sure
|
||||
// we're able to claim outputs on revoked HTLC transactions before timelocks expiration
|
||||
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
|
||||
|
@ -6938,7 +7025,8 @@ fn test_bump_penalty_txn_on_remote_commitment() {
|
|||
// Provide preimage for one
|
||||
// Check aggregation
|
||||
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
|
||||
|
@ -7045,7 +7133,8 @@ fn test_set_outpoints_partial_claiming() {
|
|||
// - remote party claim tx, new bump tx
|
||||
// - disconnect remote claiming tx, new bump
|
||||
// - disconnect tx, see no tx anymore
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
|
||||
|
@ -7144,7 +7233,8 @@ fn test_counterparty_raa_skip_no_crash() {
|
|||
// check simply that the channel is closed in response to such an RAA, but don't check whether
|
||||
// we decide to punish our counterparty for revoking their funds (as we don't currently
|
||||
// implement that).
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
let channel_id = create_announced_chan_between_nodes(&nodes, 0, 1, InitFeatures::supported(), InitFeatures::supported()).2;
|
||||
|
@ -7165,7 +7255,8 @@ fn test_bump_txn_sanitize_tracking_maps() {
|
|||
// Sanitizing pendning_claim_request and claimable_outpoints used to be buggy,
|
||||
// verify we clean then right after expiration of ANTI_REORG_DELAY.
|
||||
|
||||
let node_cfgs = create_node_cfgs(2);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(2);
|
||||
let node_cfgs = create_node_cfgs(2, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(2, &node_cfgs, &[None, None]);
|
||||
let nodes = create_network(2, &node_cfgs, &node_chanmgrs);
|
||||
|
||||
|
|
|
@ -162,7 +162,7 @@ fn _check_usize_is_32_or_64() {
|
|||
/// lifetimes). Other times you can afford a reference, which is more efficient, in which case
|
||||
/// SimpleRefPeerManager is the more appropriate type. Defining these type aliases prevents
|
||||
/// issues such as overly long function definitions.
|
||||
pub type SimpleArcPeerManager<SD, M> = Arc<PeerManager<SD, SimpleArcChannelManager<M>>>;
|
||||
pub type SimpleArcPeerManager<SD, M, T> = Arc<PeerManager<SD, SimpleArcChannelManager<M, T>>>;
|
||||
|
||||
/// SimpleRefPeerManager is a type alias for a PeerManager reference, and is the reference
|
||||
/// counterpart to the SimpleArcPeerManager type alias. Use this type by default when you don't
|
||||
|
@ -170,7 +170,7 @@ pub type SimpleArcPeerManager<SD, M> = Arc<PeerManager<SD, SimpleArcChannelManag
|
|||
/// usage of lightning-net-tokio (since tokio::spawn requires parameters with static lifetimes).
|
||||
/// But if this is not necessary, using a reference is more efficient. Defining these type aliases
|
||||
/// helps with issues such as long function definitions.
|
||||
pub type SimpleRefPeerManager<'a, SD, M> = PeerManager<SD, SimpleRefChannelManager<'a, M>>;
|
||||
pub type SimpleRefPeerManager<'a, 'b, SD, M, T> = PeerManager<SD, SimpleRefChannelManager<'a, 'b, M, T>>;
|
||||
|
||||
/// A PeerManager manages a set of peers, described by their SocketDescriptor and marshalls socket
|
||||
/// events into messages which it passes on to its MessageHandlers.
|
||||
|
|
|
@ -28,7 +28,8 @@ fn do_test_onchain_htlc_reorg(local_commitment: bool, claim: bool) {
|
|||
//
|
||||
// We then either allow these transactions to confirm (if !claim) or we wait until one block
|
||||
// before they otherwise would and reorg them out, confirming an HTLC-Success tx instead.
|
||||
let node_cfgs = create_node_cfgs(3);
|
||||
let chanmon_cfgs = create_chanmon_cfgs(3);
|
||||
let node_cfgs = create_node_cfgs(3, &chanmon_cfgs);
|
||||
let node_chanmgrs = create_node_chanmgrs(3, &node_cfgs, &[None, None, None]);
|
||||
let nodes = create_network(3, &node_cfgs, &node_chanmgrs);
|
||||
|
||||
|
|
|
@ -45,13 +45,13 @@ impl chaininterface::FeeEstimator for TestFeeEstimator {
|
|||
}
|
||||
}
|
||||
|
||||
pub struct TestChannelMonitor {
|
||||
pub struct TestChannelMonitor<'a> {
|
||||
pub added_monitors: Mutex<Vec<(OutPoint, channelmonitor::ChannelMonitor<EnforcingChannelKeys>)>>,
|
||||
pub simple_monitor: channelmonitor::SimpleManyChannelMonitor<OutPoint, EnforcingChannelKeys>,
|
||||
pub simple_monitor: channelmonitor::SimpleManyChannelMonitor<OutPoint, EnforcingChannelKeys, &'a chaininterface::BroadcasterInterface>,
|
||||
pub update_ret: Mutex<Result<(), channelmonitor::ChannelMonitorUpdateErr>>,
|
||||
}
|
||||
impl TestChannelMonitor {
|
||||
pub fn new(chain_monitor: Arc<chaininterface::ChainWatchInterface>, broadcaster: Arc<chaininterface::BroadcasterInterface>, logger: Arc<Logger>, fee_estimator: Arc<chaininterface::FeeEstimator>) -> Self {
|
||||
impl<'a> TestChannelMonitor<'a> {
|
||||
pub fn new(chain_monitor: Arc<chaininterface::ChainWatchInterface>, broadcaster: &'a chaininterface::BroadcasterInterface, logger: Arc<Logger>, fee_estimator: Arc<chaininterface::FeeEstimator>) -> Self {
|
||||
Self {
|
||||
added_monitors: Mutex::new(Vec::new()),
|
||||
simple_monitor: channelmonitor::SimpleManyChannelMonitor::new(chain_monitor, broadcaster, logger, fee_estimator),
|
||||
|
@ -59,7 +59,7 @@ impl TestChannelMonitor {
|
|||
}
|
||||
}
|
||||
}
|
||||
impl channelmonitor::ManyChannelMonitor<EnforcingChannelKeys> for TestChannelMonitor {
|
||||
impl<'a> channelmonitor::ManyChannelMonitor<EnforcingChannelKeys> for TestChannelMonitor<'a> {
|
||||
fn add_update_monitor(&self, funding_txo: OutPoint, monitor: channelmonitor::ChannelMonitor<EnforcingChannelKeys>) -> Result<(), channelmonitor::ChannelMonitorUpdateErr> {
|
||||
// At every point where we get a monitor update, we should be able to send a useful monitor
|
||||
// to a watchtower and disk...
|
||||
|
|
Loading…
Add table
Reference in a new issue