@@ -202,20 +202,26 @@ impl PendingOutboundPayment {
202202 }
203203
204204 fn mark_abandoned ( & mut self , reason : PaymentFailureReason ) {
205- if let PendingOutboundPayment :: Retryable { session_privs, payment_hash, .. } = self {
206- let mut our_session_privs = new_hash_set ( ) ;
207- core:: mem:: swap ( & mut our_session_privs, session_privs) ;
208- * self = PendingOutboundPayment :: Abandoned {
209- session_privs : our_session_privs,
210- payment_hash : * payment_hash,
211- reason : Some ( reason)
212- } ;
213- } else if let PendingOutboundPayment :: InvoiceReceived { payment_hash, .. } = self {
214- * self = PendingOutboundPayment :: Abandoned {
215- session_privs : new_hash_set ( ) ,
216- payment_hash : * payment_hash,
217- reason : Some ( reason)
218- } ;
205+ let session_privs = match self {
206+ PendingOutboundPayment :: Retryable { session_privs, .. } => {
207+ let mut our_session_privs = new_hash_set ( ) ;
208+ core:: mem:: swap ( & mut our_session_privs, session_privs) ;
209+ our_session_privs
210+ } ,
211+ _ => new_hash_set ( ) ,
212+ } ;
213+ match self {
214+ Self :: Retryable { payment_hash, .. } |
215+ Self :: InvoiceReceived { payment_hash, .. } |
216+ Self :: StaticInvoiceReceived { payment_hash, .. } =>
217+ {
218+ * self = Self :: Abandoned {
219+ session_privs,
220+ payment_hash : * payment_hash,
221+ reason : Some ( reason) ,
222+ } ;
223+ } ,
224+ _ => { }
219225 }
220226 }
221227
@@ -2614,4 +2620,44 @@ mod tests {
26142620 reason: Some ( PaymentFailureReason :: PaymentExpired ) ,
26152621 } , None ) ) ;
26162622 }
2623+
2624+ #[ test]
2625+ fn abandon_unreleased_async_payment ( ) {
2626+ let pending_events = Mutex :: new ( VecDeque :: new ( ) ) ;
2627+ let outbound_payments = OutboundPayments :: new ( ) ;
2628+ let payment_id = PaymentId ( [ 0 ; 32 ] ) ;
2629+ let absolute_expiry = 60 ;
2630+
2631+ let mut outbounds = outbound_payments. pending_outbound_payments . lock ( ) . unwrap ( ) ;
2632+ let payment_params = PaymentParameters :: from_node_id ( test_utils:: pubkey ( 42 ) , 0 )
2633+ . with_expiry_time ( absolute_expiry) ;
2634+ let route_params = RouteParameters {
2635+ payment_params,
2636+ final_value_msat : 0 ,
2637+ max_total_routing_fee_msat : None ,
2638+ } ;
2639+ let payment_hash = PaymentHash ( [ 0 ; 32 ] ) ;
2640+ let outbound = PendingOutboundPayment :: StaticInvoiceReceived {
2641+ payment_hash,
2642+ keysend_preimage : PaymentPreimage ( [ 0 ; 32 ] ) ,
2643+ retry_strategy : Retry :: Attempts ( 0 ) ,
2644+ payment_release_secret : [ 0 ; 32 ] ,
2645+ route_params,
2646+ } ;
2647+ outbounds. insert ( payment_id, outbound) ;
2648+ core:: mem:: drop ( outbounds) ;
2649+
2650+ outbound_payments. abandon_payment (
2651+ payment_id, PaymentFailureReason :: UserAbandoned , & pending_events
2652+ ) ;
2653+ let outbounds = outbound_payments. pending_outbound_payments . lock ( ) . unwrap ( ) ;
2654+ assert_eq ! ( outbounds. len( ) , 0 ) ;
2655+ let events = pending_events. lock ( ) . unwrap ( ) ;
2656+ assert_eq ! ( events. len( ) , 1 ) ;
2657+ assert_eq ! ( events[ 0 ] , ( Event :: PaymentFailed {
2658+ payment_hash,
2659+ payment_id,
2660+ reason: Some ( PaymentFailureReason :: UserAbandoned ) ,
2661+ } , None ) ) ;
2662+ }
26172663}
0 commit comments