@@ -5532,6 +5532,27 @@ fn test_update_add_htlc_bolt2_sender_zero_value_msat() {
55325532 nodes[ 0 ] . logger . assert_log ( "lightning::ln::channelmanager" . to_string ( ) , "Cannot send 0-msat HTLC" . to_string ( ) , 1 ) ;
55335533}
55345534
5535+ #[ test]
5536+ fn test_update_add_htlc_bolt2_receiver_zero_value_msat ( ) {
5537+ //BOLT2 Requirement: MUST offer amount_msat greater than 0.
5538+ let chanmon_cfgs = create_chanmon_cfgs ( 2 ) ;
5539+ let node_cfgs = create_node_cfgs ( 2 , & chanmon_cfgs) ;
5540+ let node_chanmgrs = create_node_chanmgrs ( 2 , & node_cfgs, & [ None , None ] ) ;
5541+ let mut nodes = create_network ( 2 , & node_cfgs, & node_chanmgrs) ;
5542+ let _chan = create_announced_chan_between_nodes_with_value ( & nodes, 0 , 1 , 100000 , 95000000 , InitFeatures :: supported ( ) , InitFeatures :: supported ( ) ) ;
5543+ let route = nodes[ 0 ] . router . get_route ( & nodes[ 1 ] . node . get_our_node_id ( ) , None , & [ ] , 100000 , TEST_FINAL_CLTV ) . unwrap ( ) ;
5544+ let ( _, our_payment_hash) = get_payment_preimage_hash ! ( nodes[ 0 ] ) ;
5545+
5546+ nodes[ 0 ] . node . send_payment ( route, our_payment_hash) ;
5547+ check_added_monitors ! ( nodes[ 0 ] , 1 ) ;
5548+ let mut updates = get_htlc_update_msgs ! ( nodes[ 0 ] , nodes[ 1 ] . node. get_our_node_id( ) ) ;
5549+ updates. update_add_htlcs [ 0 ] . amount_msat = 0 ;
5550+
5551+ nodes[ 1 ] . node . handle_update_add_htlc ( & nodes[ 0 ] . node . get_our_node_id ( ) , & updates. update_add_htlcs [ 0 ] ) ;
5552+ nodes[ 1 ] . logger . assert_log ( "lightning::ln::channelmanager" . to_string ( ) , "Remote side tried to send a 0-msat HTLC" . to_string ( ) , 1 ) ;
5553+ check_closed_broadcast ! ( nodes[ 1 ] , true ) . unwrap ( ) ;
5554+ }
5555+
55355556#[ test]
55365557fn test_update_add_htlc_bolt2_sender_cltv_expiry_too_high ( ) {
55375558 //BOLT 2 Requirement: MUST set cltv_expiry less than 500000000.
0 commit comments