From ebd7334c84c13178637ddc12f97119c8df7846e6 Mon Sep 17 00:00:00 2001 From: Rusty Russell Date: Thu, 16 Nov 2023 09:53:33 +1030 Subject: [PATCH] topology: don't show private nodes in listchannels. This alters a few remaining tests, as well. Signed-off-by: Rusty Russell Changelog-Deprecated: JSON-RPC: `listchannels` listing private channels: use listpeerchannels --- plugins/topology.c | 2 +- tests/test_gossip.py | 70 +++++++++++++++++++++----------------------- 2 files changed, 35 insertions(+), 37 deletions(-) diff --git a/plugins/topology.c b/plugins/topology.c index 094fa9a259ea..aafca3d831e2 100644 --- a/plugins/topology.c +++ b/plugins/topology.c @@ -359,7 +359,7 @@ static struct command_result *listpeerchannels_done(struct command *cmd, struct node_map *connected; struct gossmap_chan *c; struct json_stream *js; - struct gossmap *gossmap = get_gossmap(false); + struct gossmap *gossmap = get_gossmap(true); connected = local_connected(opts, buf, result); diff --git a/tests/test_gossip.py b/tests/test_gossip.py index 56a4ca847032..677ec4825ecd 100644 --- a/tests/test_gossip.py +++ b/tests/test_gossip.py @@ -394,23 +394,32 @@ def test_gossip_jsonrpc(node_factory): # Shouldn't send announce signatures until 6 deep. assert not l1.daemon.is_in_log('peer_out WIRE_ANNOUNCEMENT_SIGNATURES') - # Channels should be activated locally - wait_for(lambda: len(l1.rpc.listchannels()['channels']) == 2) - wait_for(lambda: len(l2.rpc.listchannels()['channels']) == 2) - # Make sure we can route through the channel, will raise on failure l1.rpc.getroute(l2.info['id'], 100, 1) - # Outgoing should be active, but not public. - channels1 = l1.rpc.listchannels()['channels'] - channels2 = l2.rpc.listchannels()['channels'] + # Channels not should be activated locally + assert l1.rpc.listchannels() == {'channels': []} + assert l2.rpc.listchannels() == {'channels': []} + + # Outgoing should be public, even if not announced yet. + channels1 = l1.rpc.listpeerchannels()['channels'] + channels2 = l2.rpc.listpeerchannels()['channels'] - assert [c['active'] for c in channels1] == [True, True] - assert [c['active'] for c in channels2] == [True, True] - # The incoming direction will be considered public, hence check for out - # outgoing only - assert len([c for c in channels1 if not c['public']]) == 2 - assert len([c for c in channels2 if not c['public']]) == 2 + assert [c['private'] for c in channels1] == [False] + assert [c['private'] for c in channels2] == [False] + + # Now proceed to funding-depth and do a full gossip round + l1.bitcoin.generate_block(5) + # Could happen in either order. + l1.daemon.wait_for_logs(['peer_out WIRE_ANNOUNCEMENT_SIGNATURES', + 'peer_in WIRE_ANNOUNCEMENT_SIGNATURES']) + + # Just wait for the update to kick off and then check the effect + needle = "Received node_announcement for node" + l1.daemon.wait_for_log(needle) + l2.daemon.wait_for_log(needle) + l1.wait_channel_active(only_one(channels1)['short_channel_id']) + l2.wait_channel_active(only_one(channels1)['short_channel_id']) # Test listchannels-by-source channels1 = l1.rpc.listchannels(source=l1.info['id'])['channels'] @@ -440,19 +449,6 @@ def test_gossip_jsonrpc(node_factory): with pytest.raises(RpcError, match=r"Can only specify one of.*"): l1.rpc.listchannels(short_channel_id="1x1x1", source=l2.info['id']) - # Now proceed to funding-depth and do a full gossip round - l1.bitcoin.generate_block(5) - # Could happen in either order. - l1.daemon.wait_for_logs(['peer_out WIRE_ANNOUNCEMENT_SIGNATURES', - 'peer_in WIRE_ANNOUNCEMENT_SIGNATURES']) - - # Just wait for the update to kick off and then check the effect - needle = "Received node_announcement for node" - l1.daemon.wait_for_log(needle) - l2.daemon.wait_for_log(needle) - l1.wait_channel_active(only_one(channels1)['short_channel_id']) - l2.wait_channel_active(only_one(channels1)['short_channel_id']) - nodes = l1.rpc.listnodes()['nodes'] assert set([n['nodeid'] for n in nodes]) == set([l1.info['id'], l2.info['id']]) @@ -561,14 +557,16 @@ def active(node): return sorted([c['short_channel_id'] for c in chans if c['active']]) def non_public(node): - chans = node.rpc.listchannels()['channels'] - return sorted([c['short_channel_id'] for c in chans if not c['public']]) + # Not just c["private"] == True, but immature ones too. + public_chans = [c['short_channel_id'] for c in node.rpc.listchannels()['channels']] + our_chans = [c['short_channel_id'] for c in node.rpc.listpeerchannels()['channels'] if c['state'] in ('CHANNELD_NORMAL', 'CHANNELD_AWAITING_SPLICE')] + return sorted(list(set(our_chans) - set(public_chans))) # Channels should be activated wait_for(lambda: active(l1) == [scid12, scid12, scid23, scid23]) wait_for(lambda: active(l2) == [scid12, scid12, scid23, scid23]) - # This one sees its private channel - wait_for(lambda: active(l3) == [scid12, scid12, scid23, scid23, scid34, scid34]) + # This one has private channels, but doesn't appear in listchannels. + wait_for(lambda: active(l3) == [scid12, scid12, scid23, scid23]) # l1 restarts and doesn't connect, but loads from persisted store, all # local channels should be disabled, leaving only the two l2 <-> l3 @@ -590,24 +588,24 @@ def non_public(node): wait_for(lambda: active(l1) == [scid23, scid23]) wait_for(lambda: active(l2) == [scid23, scid23]) - wait_for(lambda: active(l3) == [scid23, scid23, scid34, scid34]) + wait_for(lambda: active(l3) == [scid23, scid23]) # The channel l3 -> l4 should be known only to them assert non_public(l1) == [] assert non_public(l2) == [] - wait_for(lambda: non_public(l3) == [scid34, scid34]) - wait_for(lambda: non_public(l4) == [scid34, scid34]) + wait_for(lambda: non_public(l3) == [scid34]) + wait_for(lambda: non_public(l4) == [scid34]) # Finally, it should also remember the deletion after a restart l3.restart() l4.restart() l2.rpc.connect(l3.info['id'], 'localhost', l3.port) l3.rpc.connect(l4.info['id'], 'localhost', l4.port) - wait_for(lambda: active(l3) == [scid23, scid23, scid34, scid34]) + wait_for(lambda: active(l3) == [scid23, scid23]) # Both l3 and l4 should remember their local-only channel - wait_for(lambda: non_public(l3) == [scid34, scid34]) - wait_for(lambda: non_public(l4) == [scid34, scid34]) + wait_for(lambda: non_public(l3) == [scid34]) + wait_for(lambda: non_public(l4) == [scid34]) def test_routing_gossip_reconnect(node_factory):