From 941f699f5f6811ead00f27a51068e302000c46e4 Mon Sep 17 00:00:00 2001 From: OlivierHecart Date: Fri, 27 Sep 2024 12:22:12 +0200 Subject: [PATCH] Fix peers start conditions bug (#1477) * connect_peers returns false if not connected to avoid wrong start_contitions notif * Document `connect` and `connect_peer` * Clarify comments * Update comments --------- Co-authored-by: Mahmoud Mazouz --- zenoh/src/net/routing/hat/p2p_peer/gossip.rs | 2 +- zenoh/src/net/runtime/orchestrator.rs | 12 ++++++++---- 2 files changed, 9 insertions(+), 5 deletions(-) diff --git a/zenoh/src/net/routing/hat/p2p_peer/gossip.rs b/zenoh/src/net/routing/hat/p2p_peer/gossip.rs index b3216c6b8c..d69eb74cc7 100644 --- a/zenoh/src/net/routing/hat/p2p_peer/gossip.rs +++ b/zenoh/src/net/routing/hat/p2p_peer/gossip.rs @@ -427,8 +427,8 @@ impl Network { .get_transport_unicast(&zid) .await .is_none() + && runtime.connect_peer(&zid, &locators).await { - runtime.connect_peer(&zid, &locators).await; runtime .start_conditions() .terminate_peer_connector_zid(zid) diff --git a/zenoh/src/net/runtime/orchestrator.rs b/zenoh/src/net/runtime/orchestrator.rs index faadf5eb5c..c95f47a970 100644 --- a/zenoh/src/net/runtime/orchestrator.rs +++ b/zenoh/src/net/runtime/orchestrator.rs @@ -911,7 +911,7 @@ impl Runtime { } } - /// Returns `true` if a new Transport instance has been opened with `zid`. + /// Returns `true` if a new Transport instance is established with `zid` or had already been established. #[must_use] async fn connect(&self, zid: &ZenohIdProto, scouted_locators: &[Locator]) -> bool { if !self.insert_pending_connection(*zid).await { @@ -1024,7 +1024,8 @@ impl Runtime { } } - pub async fn connect_peer(&self, zid: &ZenohIdProto, locators: &[Locator]) { + /// Returns `true` if a new Transport instance is established with `zid` or had already been established. + pub async fn connect_peer(&self, zid: &ZenohIdProto, locators: &[Locator]) -> bool { let manager = self.manager(); if zid != &manager.zid() { let has_unicast = manager.get_transport_unicast(zid).await.is_some(); @@ -1042,10 +1043,13 @@ impl Runtime { if !has_unicast && !has_multicast { tracing::debug!("Try to connect to peer {} via any of {:?}", zid, locators); - let _ = self.connect(zid, locators).await; + self.connect(zid, locators).await } else { tracing::trace!("Already connected scouted peer: {}", zid); + true } + } else { + true } } @@ -1089,7 +1093,7 @@ impl Runtime { ) { Runtime::scout(ucast_sockets, what, addr, move |hello| async move { if !hello.locators.is_empty() { - self.connect_peer(&hello.zid, &hello.locators).await + self.connect_peer(&hello.zid, &hello.locators).await; } else { tracing::warn!("Received Hello with no locators: {:?}", hello); }