pytest: optimize test_closing_torture

VALGRIND=1, SLOW_MACHINE=0:
Before: 197.74 seconds
After: 135.43 seconds

Note that we now spend about 13 seconds in teardown, could probably
be optimized.

Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
This commit is contained in:
Rusty Russell 2019-08-22 15:47:22 +09:30
parent 686df235a2
commit 3f1ca18f2f

View File

@ -144,54 +144,67 @@ def test_closing_id(node_factory):
wait_for(lambda: not only_one(l2.rpc.listpeers(l1.info['id'])['peers'])['connected']) wait_for(lambda: not only_one(l2.rpc.listpeers(l1.info['id'])['peers'])['connected'])
@unittest.skipIf(not DEVELOPER, "needs dev-rescan-outputs")
def test_closing_torture(node_factory, executor, bitcoind): def test_closing_torture(node_factory, executor, bitcoind):
l1, l2 = node_factory.get_nodes(2) # We set up N-to-N fully-connected mesh, then try
# closing them all at once.
amount = 10**6 amount = 10**6
# Before the fix was applied, 15 would often pass. num_nodes = 10 # => 55 channels (36 seconds on my laptop)
# However, increasing the number of tries would
# take longer in VALGRIND mode, triggering a CI
# failure since the test does not print any
# output.
# On my laptop, VALGRIND is about 4x slower than native, hence
# the approximations below:
iterations = 50
if VALGRIND: if VALGRIND:
iterations //= 4 num_nodes -= 4 # => 21 (135 seconds)
if SLOW_MACHINE: if SLOW_MACHINE:
iterations //= 2 num_nodes -= 1 # => 45/15 (37/95 seconds)
for i in range(iterations): nodes = node_factory.get_nodes(num_nodes)
# Reduce probability that spurious sendrawtx error will occur
l1.rpc.dev_rescan_outputs()
# Create a channel. # Make sure bitcoind has plenty of utxos
l1.rpc.connect(l2.info['id'], 'localhost', l2.port) bitcoind.generate_block(num_nodes)
l1.fund_channel(l2, amount)
scid = l1.get_channel_scid(l2)
# Get it confirmed. # Give them all plenty of UTXOs, make sure they see them
l1.bitcoin.generate_block(6) for i in range(len(nodes)):
for j in range(i + 1, len(nodes)):
addr = nodes[i].rpc.newaddr()['bech32']
bitcoind.rpc.sendtoaddress(addr, (amount + 1000000) / 10**8)
bitcoind.generate_block(1)
sync_blockheight(bitcoind, nodes)
# Wait for it to go to CHANNELD_NORMAL txs = []
l1.wait_channel_active(scid) for i in range(len(nodes)):
l2.wait_channel_active(scid) for j in range(i + 1, len(nodes)):
nodes[i].rpc.connect(nodes[j].info['id'], 'localhost', nodes[j].port)
txs.append(nodes[i].rpc.fundchannel(nodes[j].info['id'], amount)['txid'])
# Make sure they're all in, then lock them in.
bitcoind.generate_block(1, wait_for_mempool=txs)
# Wait for them all to be CHANNELD_NORMAL
for n in nodes:
wait_for(lambda: all(p['channels'][0]['state'] == 'CHANNELD_NORMAL' for p in n.rpc.listpeers()['peers']))
# Start closers: can take a long time under valgrind! # Start closers: can take a long time under valgrind!
c1 = executor.submit(l1.rpc.close, l2.info['id']) futures = []
c2 = executor.submit(l2.rpc.close, l1.info['id']) for i in range(len(nodes)):
for j in range(i + 1, len(nodes)):
futures.append(executor.submit(nodes[i].rpc.close, nodes[j].info['id']))
futures.append(executor.submit(nodes[j].rpc.close, nodes[i].info['id']))
# Wait for close to finish # Wait for close to finish
c1.result(TIMEOUT) close_txs = set()
c2.result(TIMEOUT) for f in futures:
# If one side completes closing, we'll get an error here 'Peer has no active channel'
try:
close_txs.add(f.result(TIMEOUT)['txid'])
except RpcError as err:
assert err.error['message'] == 'Peer has no active channel'
wait_for(lambda: len(bitcoind.rpc.getrawmempool(False)) == 1) # Should have one close for each open.
assert len(close_txs) == len(txs)
# Get closes confirmed
bitcoind.generate_block(100, wait_for_mempool=list(close_txs))
# Get close confirmed # And make sure they hangup.
l1.bitcoin.generate_block(100) for n in nodes:
wait_for(lambda: len(l1.rpc.listpeers()['peers']) == 0) wait_for(lambda: n.rpc.listpeers()['peers'] == [])
wait_for(lambda: len(l2.rpc.listpeers()['peers']) == 0)
@unittest.skipIf(SLOW_MACHINE and VALGRIND, "slow test") @unittest.skipIf(SLOW_MACHINE and VALGRIND, "slow test")