mirror of
https://github.com/ElementsProject/lightning.git
synced 2025-01-17 19:03:42 +01:00
test_lightningd.py: test updating feerates.
Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
This commit is contained in:
parent
1a38c98a7e
commit
6c79550c22
@ -2233,5 +2233,86 @@ class LightningDTests(BaseLightningDTests):
|
||||
l2.daemon.wait_for_log('Received node_announcement for node {}'.format(l1.info['id']))
|
||||
assert [c['active'] for c in l1.rpc.getchannels()['channels']] == [True, True]
|
||||
|
||||
@unittest.skipIf(not DEVELOPER, "needs DEVELOPER=1")
|
||||
def test_update_fee(self):
|
||||
l1, l2 = self.connect()
|
||||
chanid = self.fund_channel(l1, l2, 10**6)
|
||||
|
||||
# Make l1 send out feechange.
|
||||
l1.rpc.dev_setfees('14000')
|
||||
l2.daemon.wait_for_log('peer updated fee to 14000')
|
||||
|
||||
# Now make sure an HTLC works.
|
||||
# (First wait for route propagation.)
|
||||
bitcoind.rpc.generate(6)
|
||||
l1.daemon.wait_for_logs(['Received channel_update for channel {}\(0\)'
|
||||
.format(chanid),
|
||||
'Received channel_update for channel {}\(1\)'
|
||||
.format(chanid)])
|
||||
|
||||
# Make payments.
|
||||
self.pay(l1,l2,200000000)
|
||||
self.pay(l2,l1,100000000)
|
||||
|
||||
# Now shutdown cleanly.
|
||||
l1.rpc.close(l2.info['id']);
|
||||
l1.daemon.wait_for_log('-> CLOSINGD_COMPLETE')
|
||||
l2.daemon.wait_for_log('-> CLOSINGD_COMPLETE')
|
||||
|
||||
# And should put closing into mempool.
|
||||
l1.daemon.wait_for_log('sendrawtx exit 0')
|
||||
l2.daemon.wait_for_log('sendrawtx exit 0')
|
||||
|
||||
bitcoind.rpc.generate(1)
|
||||
l1.daemon.wait_for_log('-> ONCHAIND_MUTUAL')
|
||||
l2.daemon.wait_for_log('-> ONCHAIND_MUTUAL')
|
||||
|
||||
bitcoind.rpc.generate(99)
|
||||
l1.daemon.wait_for_log('onchaind complete, forgetting peer')
|
||||
l2.daemon.wait_for_log('onchaind complete, forgetting peer')
|
||||
|
||||
@unittest.skipIf(not DEVELOPER, "needs DEVELOPER=1")
|
||||
def test_update_fee_reconnect(self):
|
||||
# Disconnect after first commitsig.
|
||||
disconnects = ['+WIRE_COMMITMENT_SIGNED']
|
||||
l1 = self.node_factory.get_node(disconnect=disconnects)
|
||||
l2 = self.node_factory.get_node()
|
||||
l1.rpc.connect(l2.info['id'], 'localhost:{}'.format(l2.info['port']))
|
||||
|
||||
self.fund_channel(l1, l2, 10**6)
|
||||
|
||||
# Make l1 send out feechange; triggers disconnect/reconnect.
|
||||
l1.rpc.dev_setfees('14000')
|
||||
l1.daemon.wait_for_log('Setting REMOTE feerate to 14000')
|
||||
l2.daemon.wait_for_log('Setting LOCAL feerate to 14000')
|
||||
l1.daemon.wait_for_log('dev_disconnect: \+WIRE_COMMITMENT_SIGNED')
|
||||
|
||||
# Wait for reconnect....
|
||||
l1.daemon.wait_for_log('Applying feerate 14000 to LOCAL')
|
||||
|
||||
self.pay(l1,l2,200000000)
|
||||
self.pay(l2,l1,100000000)
|
||||
|
||||
# They should both have gotten commits with correct feerate.
|
||||
assert l1.daemon.is_in_log('got commitsig [0-9]*: feerate 14000')
|
||||
assert l2.daemon.is_in_log('got commitsig [0-9]*: feerate 14000')
|
||||
|
||||
# Now shutdown cleanly.
|
||||
l1.rpc.close(l2.info['id']);
|
||||
l1.daemon.wait_for_log('-> CLOSINGD_COMPLETE')
|
||||
l2.daemon.wait_for_log('-> CLOSINGD_COMPLETE')
|
||||
|
||||
# And should put closing into mempool.
|
||||
l1.daemon.wait_for_log('sendrawtx exit 0')
|
||||
l2.daemon.wait_for_log('sendrawtx exit 0')
|
||||
|
||||
bitcoind.rpc.generate(1)
|
||||
l1.daemon.wait_for_log('-> ONCHAIND_MUTUAL')
|
||||
l2.daemon.wait_for_log('-> ONCHAIND_MUTUAL')
|
||||
|
||||
bitcoind.rpc.generate(99)
|
||||
l1.daemon.wait_for_log('onchaind complete, forgetting peer')
|
||||
l2.daemon.wait_for_log('onchaind complete, forgetting peer')
|
||||
|
||||
if __name__ == '__main__':
|
||||
unittest.main(verbosity=2)
|
||||
|
Loading…
Reference in New Issue
Block a user