From 2a002f9bdd15b7e3e05a1a9b8e0ffab7368cf8e8 Mon Sep 17 00:00:00 2001 From: Roman Volosatovs Date: Wed, 2 Oct 2024 16:00:23 +0200 Subject: [PATCH] fix(quic): concat nested index paths Signed-off-by: Roman Volosatovs --- crates/transport-quic/src/lib.rs | 46 +++++++++++++++++++------------- tests/rust.rs | 1 - 2 files changed, 27 insertions(+), 20 deletions(-) diff --git a/crates/transport-quic/src/lib.rs b/crates/transport-quic/src/lib.rs index e98e7ca3..bce59715 100644 --- a/crates/transport-quic/src/lib.rs +++ b/crates/transport-quic/src/lib.rs @@ -484,19 +484,6 @@ pin_project! { impl wrpc_transport::Index for Outgoing { #[instrument(level = "trace", skip(self))] fn index(&self, path: &[usize]) -> anyhow::Result { - ensure!(!path.is_empty()); - let mut header = BytesMut::with_capacity(path.len().saturating_add(5)); - let depth = path.len(); - let n = u32::try_from(depth) - .map_err(|err| std::io::Error::new(std::io::ErrorKind::InvalidInput, err))?; - trace!(n, "encoding path length"); - Leb128Encoder.encode(n, &mut header)?; - for p in path { - let p = u32::try_from(*p) - .map_err(|err| std::io::Error::new(std::io::ErrorKind::InvalidInput, err))?; - trace!(p, "encoding path element"); - Leb128Encoder.encode(p, &mut header)?; - } match self { Self::Opening { path: base, @@ -509,12 +496,33 @@ impl wrpc_transport::Index for Outgoing { conn, io, .. - } => Ok(Self::Opening { - header: header.freeze(), - path: Arc::from([base, path].concat()), - conn: conn.clone(), - io: Arc::clone(io), - }), + } => { + ensure!(!path.is_empty()); + let path: Arc<[usize]> = if base.is_empty() { + Arc::from(path) + } else { + Arc::from([base.as_ref(), path].concat()) + }; + let mut header = BytesMut::with_capacity(path.len().saturating_add(5)); + let depth = path.len(); + let n = u32::try_from(depth) + .map_err(|err| std::io::Error::new(std::io::ErrorKind::InvalidInput, err))?; + trace!(n, "encoding path length"); + Leb128Encoder.encode(n, &mut header)?; + for p in path.as_ref() { + let p = u32::try_from(*p).map_err(|err| { + std::io::Error::new(std::io::ErrorKind::InvalidInput, err) + })?; + trace!(p, "encoding path element"); + Leb128Encoder.encode(p, &mut header)?; + } + Ok(Self::Opening { + header: header.freeze(), + path, + conn: conn.clone(), + io: Arc::clone(io), + }) + } } } } diff --git a/tests/rust.rs b/tests/rust.rs index 00bb4c11..d8b06a5f 100644 --- a/tests/rust.rs +++ b/tests/rust.rs @@ -1083,7 +1083,6 @@ async fn rust_bindgen_quic_sync() -> anyhow::Result<()> { #[cfg(feature = "quic")] #[test_log::test(tokio::test(flavor = "multi_thread"))] #[instrument(ret)] -#[ignore] // TODO: reenable async fn rust_bindgen_quic_async() -> anyhow::Result<()> { use core::net::Ipv6Addr; use core::pin::pin;