diff --git a/libp2p.nimble b/libp2p.nimble index f95e925..1393867 100644 --- a/libp2p.nimble +++ b/libp2p.nimble @@ -59,8 +59,6 @@ task testpubsub_slim, "Runs pubsub tests": runTest("pubsub/testgossipinternal", sign = false, verify = false, moreoptions = "-d:pubsub_internal_testing") runTest("pubsub/testpubsub") runTest("pubsub/testpubsub", sign = false, verify = false, moreoptions = "-d:libp2p_pubsub_anonymize=true") - runTest("pubsub/testgossipinternal10", sign = false, verify = false, moreoptions = "-d:pubsub_internal_testing") - runTest("pubsub/testpubsub", moreoptions = "-d:fallback_gossipsub_10") task testfilter, "Run PKI filter test": runTest("testpkifilter", diff --git a/libp2p/protocols/pubsub/gossipsub.nim b/libp2p/protocols/pubsub/gossipsub.nim index 7a60ef4..1122d5b 100644 --- a/libp2p/protocols/pubsub/gossipsub.nim +++ b/libp2p/protocols/pubsub/gossipsub.nim @@ -304,7 +304,7 @@ proc grafted(g: GossipSub, p: PubSubPeer, topic: string) = stats.topicInfos[topic] = info assert(g.peerStats[p].topicInfos[topic].inMesh == true) - trace "grafted", p + trace "grafted", peer=p, topic do: g.onNewPeer(p) g.grafted(p, topic) @@ -329,7 +329,7 @@ proc pruned(g: GossipSub, p: PubSubPeer, topic: string) = # mgetOrPut does not work, so we gotta do this without referencing stats.topicInfos[topic] = info - trace "pruned", p + trace "pruned", peer=p, topic proc peerExchangeList(g: GossipSub, topic: string): seq[PeerInfoMsg] = var peers = g.gossipsub.getOrDefault(topic, initHashSet[PubSubPeer]()).toSeq() @@ -367,7 +367,8 @@ method onPubSubPeerEvent*(p: GossipSub, peer: PubsubPeer, event: PubSubPeerEvent # If a send connection is lost, it's better to remove peer from the mesh - # if it gets reestablished, the peer will be readded to the mesh, and if it # doesn't, well.. then we hope the peer is going away! - for _, peers in p.mesh.mpairs(): + for topic, peers in p.mesh.mpairs(): + p.pruned(peer, topic) peers.excl(peer) for _, peers in p.fanout.mpairs(): peers.excl(peer) diff --git a/libp2p/protocols/pubsub/pubsubpeer.nim b/libp2p/protocols/pubsub/pubsubpeer.nim index a3ed506..9f5d709 100644 --- a/libp2p/protocols/pubsub/pubsubpeer.nim +++ b/libp2p/protocols/pubsub/pubsubpeer.nim @@ -227,7 +227,7 @@ proc send*(p: PubSubPeer, msg: RPCMsg, anonymize: bool) = asyncSpawn sendImpl(conn, encoded) when defined(libp2p_expensive_metrics): - for x in mm.messages: + for x in msg.messages: for t in x.topicIDs: # metrics libp2p_pubsub_sent_messages.inc(labelValues = [$p.peerId, t])