From cafcebc79cab6161a0c56b688cd600049236ba63 Mon Sep 17 00:00:00 2001 From: nihohit Date: Tue, 23 Jan 2024 10:07:54 +0000 Subject: [PATCH] Standalone client: Improve connection errors. 1. Add explicit error if primary node wasn't found. 2. Change the error message format, depending on how many internal errors it contains. --- glide-core/src/client/standalone_client.rs | 40 ++++++++++++++++++---- 1 file changed, 34 insertions(+), 6 deletions(-) diff --git a/glide-core/src/client/standalone_client.rs b/glide-core/src/client/standalone_client.rs index 97f87bcfcf..a350dfc09b 100644 --- a/glide-core/src/client/standalone_client.rs +++ b/glide-core/src/client/standalone_client.rs @@ -43,7 +43,7 @@ pub struct StandaloneClient { pub enum StandaloneClientConnectionError { NoAddressesProvided, - FailedConnection(Vec<(String, RedisError)>), + FailedConnection(Vec<(Option, RedisError)>), } impl std::fmt::Debug for StandaloneClientConnectionError { @@ -53,10 +53,29 @@ impl std::fmt::Debug for StandaloneClientConnectionError { write!(f, "No addresses provided") } StandaloneClientConnectionError::FailedConnection(errs) => { - writeln!(f, "Received errors:")?; - for (address, error) in errs { - writeln!(f, "{address}: {error}")?; - } + match errs.len() { + 0 => { + writeln!(f, "Failed without explicit error")?; + } + 1 => { + let (ref address, ref error) = errs[0]; + match address { + Some(address) => { + writeln!(f, "Received error for address `{address}`: {error}")? + } + None => writeln!(f, "Received error: {error}")?, + } + } + _ => { + writeln!(f, "Received errors:")?; + for (address, error) in errs { + match address { + Some(address) => writeln!(f, "{address}: {error}")?, + None => writeln!(f, "{error}")?, + } + } + } + }; Ok(()) } } @@ -104,12 +123,21 @@ impl StandaloneClient { } Err((address, (connection, err))) => { nodes.push(connection); - addresses_and_errors.push((address, err)); + addresses_and_errors.push((Some(address), err)); } } } let Some(primary_index) = primary_index else { + if addresses_and_errors.is_empty() { + addresses_and_errors.insert( + 0, + ( + None, + RedisError::from((redis::ErrorKind::ClientError, "No primary node found")), + ), + ) + }; return Err(StandaloneClientConnectionError::FailedConnection( addresses_and_errors, ));