From 01415a7b4046406a7321a1564c88db6d5e24fa0b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Teo=20Klestrup=20R=C3=B6ijezon?= Date: Thu, 10 Jun 2021 02:24:02 +0200 Subject: [PATCH 1/8] Add Context method for resolving an Event's SpanRef Fixes #1428 --- tracing-subscriber/src/layer.rs | 23 +++++++++++++++++++++++ 1 file changed, 23 insertions(+) diff --git a/tracing-subscriber/src/layer.rs b/tracing-subscriber/src/layer.rs index ffdd89c10c..e1b6eeb04c 100644 --- a/tracing-subscriber/src/layer.rs +++ b/tracing-subscriber/src/layer.rs @@ -994,6 +994,29 @@ where } } + /// Finds the [`SpanRef`] associated with an [`Event`], if it has one. + /// + /// Compared to [`Context::current_span`] and [`Context::lookup_current`], + /// this respects overrides provided by the [`Event`]. + /// + /// Compared to [`Event::parent`], this automatically falls back to the contextual + /// span, if required. + #[inline] + #[cfg(feature = "registry")] + #[cfg_attr(docsrs, doc(cfg(feature = "registry")))] + pub fn event_span(&self, event: &Event<'_>) -> Option> + where + S: for<'lookup> LookupSpan<'lookup>, + { + if event.is_root() { + None + } else if event.is_contextual() { + self.lookup_current() + } else { + event.parent().and_then(|id| self.span(id)) + } + } + /// Returns metadata for the span with the given `id`, if it exists. /// /// If this returns `None`, then no span exists for that ID (either it has From cdb5d49f8e8cbd12c6b5fbef22a55844960e47ee Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Teo=20Klestrup=20R=C3=B6ijezon?= Date: Wed, 23 Jun 2021 10:43:06 +0200 Subject: [PATCH 2/8] Apply suggestions from code review Co-authored-by: Eliza Weisman --- tracing-subscriber/src/layer.rs | 21 ++++++++++++++++++++- 1 file changed, 20 insertions(+), 1 deletion(-) diff --git a/tracing-subscriber/src/layer.rs b/tracing-subscriber/src/layer.rs index e1b6eeb04c..1b2357a68c 100644 --- a/tracing-subscriber/src/layer.rs +++ b/tracing-subscriber/src/layer.rs @@ -994,13 +994,32 @@ where } } - /// Finds the [`SpanRef`] associated with an [`Event`], if it has one. + /// Returns a [`SpanRef`] for the parent span of the given [`Event`], if + /// it has a parent. + /// + /// If the event has an explicitly overridden parent, this method returns + /// a reference to that span. If the event's parent is the current span, + /// this returns a reference to the current span, if there is one. If this + /// returns `None`, then either the event's parent was explicitly set to + /// `None`, or the event's parent was defined contextually, but no span + /// is currently entered. /// /// Compared to [`Context::current_span`] and [`Context::lookup_current`], /// this respects overrides provided by the [`Event`]. /// /// Compared to [`Event::parent`], this automatically falls back to the contextual /// span, if required. + /// + ///
+ ///
Note
+ ///
+ ///
+ ///
+    /// Note: This requires the wrapped subscriber to implement the
+    /// LookupSpan trait.
+    /// See the documentation on Context's
+    /// declaration for details.
+    /// 
#[inline] #[cfg(feature = "registry")] #[cfg_attr(docsrs, doc(cfg(feature = "registry")))] From 598e8bdf7dec6b1ff17af6928296ddc0c53fb453 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Teo=20Klestrup=20R=C3=B6ijezon?= Date: Wed, 23 Jun 2021 10:58:41 +0200 Subject: [PATCH 3/8] Add usage example for `Context::event_span` --- tracing-subscriber/src/layer.rs | 33 +++++++++++++++++++++++++++++++++ 1 file changed, 33 insertions(+) diff --git a/tracing-subscriber/src/layer.rs b/tracing-subscriber/src/layer.rs index b963c42acb..966f257cd9 100644 --- a/tracing-subscriber/src/layer.rs +++ b/tracing-subscriber/src/layer.rs @@ -1019,6 +1019,39 @@ where /// Compared to [`Event::parent`], this automatically falls back to the contextual /// span, if required. /// + /// ```rust + /// use tracing::{Event, Subscriber}; + /// use tracing_subscriber::{ + /// layer::{Context, Layer}, + /// prelude::*, + /// registry::LookupSpan, + /// }; + /// + /// struct PrintingLayer; + /// impl Layer for PrintingLayer + /// where + /// S: Subscriber + for<'lookup> LookupSpan<'lookup>, + /// { + /// fn on_event(&self, event: &Event, ctx: Context) { + /// let span = ctx.event_span(event); + /// println!("Event in span: {:?}", span.map(|s| s.name())); + /// } + /// } + /// + /// tracing::subscriber::with_default(tracing_subscriber::registry().with(PrintingLayer), || { + /// tracing::info!("no span"); + /// // Prints: Event in span: None + /// + /// let span = tracing::info_span!("span"); + /// tracing::info!(parent: &span, "explicitly specified"); + /// // Prints: Event in span: Some("span") + /// + /// let _guard = span.enter(); + /// tracing::info!("contextual span"); + /// // Prints: Event in span: Some("span") + /// }); + /// ``` + /// ///
///
Note
///
From 3f635cb7fbb4567422a3bc37455d54fd7ec6d9cf Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Teo=20Klestrup=20R=C3=B6ijezon?= Date: Wed, 23 Jun 2021 11:15:45 +0200 Subject: [PATCH 4/8] Add test for Context::event_span --- tracing-subscriber/src/layer.rs | 38 +++++++++++++++++++++++++++++++++ 1 file changed, 38 insertions(+) diff --git a/tracing-subscriber/src/layer.rs b/tracing-subscriber/src/layer.rs index 966f257cd9..71ed8b503c 100644 --- a/tracing-subscriber/src/layer.rs +++ b/tracing-subscriber/src/layer.rs @@ -1269,6 +1269,8 @@ impl Identity { #[cfg(test)] pub(crate) mod tests { + use std::sync::{Arc, Mutex}; + use super::*; pub(crate) struct NopSubscriber; @@ -1383,4 +1385,40 @@ pub(crate) mod tests { ::downcast_ref::(&s).expect("layer 3 should downcast"); assert_eq!(&layer.0, "layer_3"); } + + #[test] + fn context_event_span() { + let last_event_span = Arc::new(Mutex::new(None)); + + struct RecordingLayer { + last_event_span: Arc>>, + } + impl Layer for RecordingLayer + where + S: Subscriber + for<'lookup> LookupSpan<'lookup>, + { + fn on_event(&self, event: &Event<'_>, ctx: Context<'_, S>) { + let span = ctx.event_span(event); + *self.last_event_span.lock().unwrap() = span.map(|s| s.name()); + } + } + + tracing::subscriber::with_default( + crate::registry().with(RecordingLayer { + last_event_span: last_event_span.clone(), + }), + || { + tracing::info!("no span"); + assert_eq!(*last_event_span.lock().unwrap(), None); + + let parent = tracing::info_span!("explicit"); + tracing::info!(parent: parent, "explicit span"); + assert_eq!(*last_event_span.lock().unwrap(), Some("explicit")); + + let _guard = tracing::info_span!("contextual").entered(); + tracing::info!("contextual span"); + assert_eq!(*last_event_span.lock().unwrap(), Some("contextual")); + }, + ); + } } From 390c1c7efd4a96ceb801d6ed9e7a03a442c6bb3a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Teo=20Klestrup=20R=C3=B6ijezon?= Date: Wed, 23 Jun 2021 11:16:58 +0200 Subject: [PATCH 5/8] Fix error looking up explicit span --- tracing-subscriber/src/layer.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/tracing-subscriber/src/layer.rs b/tracing-subscriber/src/layer.rs index 71ed8b503c..31e572d45e 100644 --- a/tracing-subscriber/src/layer.rs +++ b/tracing-subscriber/src/layer.rs @@ -1412,7 +1412,7 @@ pub(crate) mod tests { assert_eq!(*last_event_span.lock().unwrap(), None); let parent = tracing::info_span!("explicit"); - tracing::info!(parent: parent, "explicit span"); + tracing::info!(parent: &parent, "explicit span"); assert_eq!(*last_event_span.lock().unwrap(), Some("explicit")); let _guard = tracing::info_span!("contextual").entered(); From 18e58eab35fa3902914d4ab98018b622f2b3f203 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Teo=20Klestrup=20R=C3=B6ijezon?= Date: Wed, 23 Jun 2021 11:25:42 +0200 Subject: [PATCH 6/8] Add Context::event_scope as discussed --- tracing-subscriber/src/layer.rs | 36 +++++++++++++++++++++++++++++++++ 1 file changed, 36 insertions(+) diff --git a/tracing-subscriber/src/layer.rs b/tracing-subscriber/src/layer.rs index 31e572d45e..8ad4c963d7 100644 --- a/tracing-subscriber/src/layer.rs +++ b/tracing-subscriber/src/layer.rs @@ -1240,6 +1240,42 @@ where { Some(self.span(id)?.scope()) } + + /// Returns an iterator over the [stored data] for all the spans in the + /// current context, starting with the parent span of the specified event, + /// and ending with the root of the trace tree and ending with the current span. + /// + ///
+ ///
Note
+ ///
+ ///
+ ///
+    /// Note: Compared to scope this
+    /// returns the spans in reverse order (from leaf to root). Use
+    /// Scope::from_root
+    /// in case root-to-leaf ordering is desired.
+    /// 
+ /// + ///
+ ///
Note
+ ///
+ ///
+ ///
+    /// Note: This requires the wrapped subscriber to implement the
+    /// LookupSpan trait.
+    /// See the documentation on Context's
+    /// declaration for details.
+    /// 
+ /// + /// [stored data]: ../registry/struct.SpanRef.html + #[cfg(feature = "registry")] + #[cfg_attr(docsrs, doc(cfg(feature = "registry")))] + pub fn event_scope(&self, event: &Event<'_>) -> Option> + where + S: for<'lookup> registry::LookupSpan<'lookup>, + { + Some(self.event_span(event)?.scope()) + } } impl<'a, S> Context<'a, S> { From 8239cd3c3f8b67cfa3a9438fb147713c6a66ee48 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Teo=20Klestrup=20R=C3=B6ijezon?= Date: Wed, 23 Jun 2021 19:36:57 +0200 Subject: [PATCH 7/8] Apply suggestions from code review Co-authored-by: Eliza Weisman --- tracing-subscriber/src/layer.rs | 10 +--------- 1 file changed, 1 insertion(+), 9 deletions(-) diff --git a/tracing-subscriber/src/layer.rs b/tracing-subscriber/src/layer.rs index 8ad4c963d7..09d7274a84 100644 --- a/tracing-subscriber/src/layer.rs +++ b/tracing-subscriber/src/layer.rs @@ -1052,9 +1052,6 @@ where /// }); /// ``` /// - ///
- ///
Note
- ///
///
///
     /// Note: This requires the wrapped subscriber to implement the
@@ -1245,9 +1242,6 @@ where
     /// current context, starting with the parent span of the specified event,
     /// and ending with the root of the trace tree and ending with the current span.
     ///
-    /// 
- ///
Note
- ///
///
///
     /// Note: Compared to scope this
@@ -1256,9 +1250,6 @@ where
     /// in case root-to-leaf ordering is desired.
     /// 
/// - ///
- ///
Note
- ///
///
///
     /// Note: This requires the wrapped subscriber to implement the
@@ -1429,6 +1420,7 @@ pub(crate) mod tests {
         struct RecordingLayer {
             last_event_span: Arc>>,
         }
+        
         impl Layer for RecordingLayer
         where
             S: Subscriber + for<'lookup> LookupSpan<'lookup>,

From 21fc815904062cc37fc237253ba96d63d6555003 Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?Teo=20Klestrup=20R=C3=B6ijezon?= 
Date: Wed, 23 Jun 2021 19:50:57 +0200
Subject: [PATCH 8/8] Satisfy rustfmt

---
 tracing-subscriber/src/layer.rs | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/tracing-subscriber/src/layer.rs b/tracing-subscriber/src/layer.rs
index 09d7274a84..aa996aaed3 100644
--- a/tracing-subscriber/src/layer.rs
+++ b/tracing-subscriber/src/layer.rs
@@ -1420,7 +1420,7 @@ pub(crate) mod tests {
         struct RecordingLayer {
             last_event_span: Arc>>,
         }
-        
+
         impl Layer for RecordingLayer
         where
             S: Subscriber + for<'lookup> LookupSpan<'lookup>,