Skip to content

Commit

Permalink
pytest: simplify test_openchannel_hook_chaining now order is determin…
Browse files Browse the repository at this point in the history
…istic.
  • Loading branch information
m-schmoock authored and rustyrussell committed Nov 9, 2020
1 parent b8c7cea commit fe6b1e0
Showing 1 changed file with 3 additions and 12 deletions.
15 changes: 3 additions & 12 deletions tests/test_plugin.py
Original file line number Diff line number Diff line change
Expand Up @@ -612,18 +612,9 @@ def test_openchannel_hook_chaining(node_factory, bitcoind):
with pytest.raises(RpcError, match=r'They sent error channel'):
l1.rpc.fundchannel(l2.info['id'], 100005)

# Note: hook chain order is currently undefined, because hooks are registerd
# as a result of the getmanifest call, which may take some random time.
# We need to workaround that fact, so test can be stable
correct_order = l2.daemon.is_in_log(hook_msg + "reject for a reason")
if correct_order:
assert l2.daemon.wait_for_log(hook_msg + "reject for a reason")
# the other plugin must not be called
assert not l2.daemon.is_in_log("reject on principle")
else:
assert l2.daemon.wait_for_log(hook_msg + "reject on principle")
# the other plugin must not be called
assert not l2.daemon.is_in_log("reject for a reason")
assert l2.daemon.wait_for_log(hook_msg + "reject for a reason")
# the third plugin must now not be called anymore
assert not l2.daemon.is_in_log("reject on principle")

# 100000sat is good for hook_accepter, so it should fail 'on principle'
# at third hook openchannel_reject.py
Expand Down

0 comments on commit fe6b1e0

Please sign in to comment.