@@ -126,7 +126,7 @@ impl BackgroundProcessor {
126
126
Descriptor : ' static + SocketDescriptor + Send + Sync ,
127
127
CMH : ' static + Deref + Send + Sync ,
128
128
RMH : ' static + Deref + Send + Sync ,
129
- EH : ' static + EventHandler + Send + Sync ,
129
+ EH : ' static + EventHandler + Send ,
130
130
CMP : ' static + Send + ChannelManagerPersister < Signer , CW , T , K , F , L > ,
131
131
M : ' static + Deref < Target = ChainMonitor < Signer , CF , T , F , L , P > > + Send + Sync ,
132
132
CM : ' static + Deref < Target = ChannelManager < Signer , CW , T , K , F , L > > + Send + Sync ,
@@ -257,10 +257,13 @@ mod tests {
257
257
use lightning:: ln:: features:: InitFeatures ;
258
258
use lightning:: ln:: msgs:: { ChannelMessageHandler , Init } ;
259
259
use lightning:: ln:: peer_handler:: { PeerManager , MessageHandler , SocketDescriptor , IgnoringMessageHandler } ;
260
+ use lightning:: routing:: network_graph:: NetworkGraph ;
260
261
use lightning:: util:: config:: UserConfig ;
261
262
use lightning:: util:: events:: { Event , MessageSendEventsProvider , MessageSendEvent } ;
262
263
use lightning:: util:: ser:: Writeable ;
263
264
use lightning:: util:: test_utils;
265
+ use lightning_invoice:: payment:: InvoicePayer ;
266
+ use lightning_invoice:: utils:: DefaultRouter ;
264
267
use lightning_persister:: FilesystemPersister ;
265
268
use std:: fs;
266
269
use std:: path:: PathBuf ;
@@ -561,4 +564,19 @@ mod tests {
561
564
562
565
assert ! ( bg_processor. stop( ) . is_ok( ) ) ;
563
566
}
567
+
568
+ #[ test]
569
+ fn test_invoice_payer ( ) {
570
+ let nodes = create_nodes ( 2 , "test_invoice_payer" . to_string ( ) ) ;
571
+
572
+ // Initiate the background processors to watch each node.
573
+ let data_dir = nodes[ 0 ] . persister . get_data_dir ( ) ;
574
+ let persister = move |node : & ChannelManager < InMemorySigner , Arc < ChainMonitor > , Arc < test_utils:: TestBroadcaster > , Arc < KeysManager > , Arc < test_utils:: TestFeeEstimator > , Arc < test_utils:: TestLogger > > | FilesystemPersister :: persist_manager ( data_dir. clone ( ) , node) ;
575
+ let network_graph = Arc :: new ( NetworkGraph :: new ( genesis_block ( Network :: Testnet ) . header . block_hash ( ) ) ) ;
576
+ let router = DefaultRouter :: new ( network_graph, Arc :: clone ( & nodes[ 0 ] . logger ) ) ;
577
+ let invoice_payer = Arc :: new ( InvoicePayer :: new ( Arc :: clone ( & nodes[ 0 ] . node ) , router, Arc :: clone ( & nodes[ 0 ] . logger ) , |_: & _ | { } ) . with_retry_attempts ( 2 ) ) ;
578
+ let event_handler = Arc :: clone ( & invoice_payer) ;
579
+ let bg_processor = BackgroundProcessor :: start ( persister, event_handler, nodes[ 0 ] . chain_monitor . clone ( ) , nodes[ 0 ] . node . clone ( ) , nodes[ 0 ] . peer_manager . clone ( ) , nodes[ 0 ] . logger . clone ( ) ) ;
580
+ assert ! ( bg_processor. stop( ) . is_ok( ) ) ;
581
+ }
564
582
}
0 commit comments