From d18eaf2fcb35eaebd75659716a6565708e5973a6 Mon Sep 17 00:00:00 2001 From: Jeremy Fitzhardinge Date: Mon, 13 Sep 2021 10:53:19 -0700 Subject: [PATCH] chore: docs and tests cleanups(#1556) * small doc cleanups * subscriber: Use NoSubscriber in Layer tests No need for another no-op subscriber. * subscriber: add some compile-time tests for dyn Layer Make sure that `Box>` and `Arc>` meet all the constraints to be actually usable. --- tracing-core/src/subscriber.rs | 4 +-- tracing-subscriber/src/fmt/writer.rs | 22 ++++++++---- tracing-subscriber/src/layer/tests.rs | 48 ++++++++++++--------------- 3 files changed, 39 insertions(+), 35 deletions(-) diff --git a/tracing-core/src/subscriber.rs b/tracing-core/src/subscriber.rs index 6e943808fd..f6113a0add 100644 --- a/tracing-core/src/subscriber.rs +++ b/tracing-core/src/subscriber.rs @@ -564,10 +564,10 @@ impl Interest { } } -/// A no-op [`Subscriber`] +/// A no-op [`Subscriber`]. /// /// [`NoSubscriber`] implements the [`Subscriber`] trait by never being enabled, -/// never being interested in any callsite, and drops all spans and events. +/// never being interested in any callsite, and dropping all spans and events. #[derive(Debug, Copy, Clone)] pub struct NoSubscriber(()); diff --git a/tracing-subscriber/src/fmt/writer.rs b/tracing-subscriber/src/fmt/writer.rs index f01fa2d8e8..492c0fb1b7 100644 --- a/tracing-subscriber/src/fmt/writer.rs +++ b/tracing-subscriber/src/fmt/writer.rs @@ -342,7 +342,7 @@ pub trait MakeWriterExt<'a>: MakeWriter<'a> { /// determine if a writer should be produced for a given span or event. /// /// If the predicate returns `false`, the wrapped [`MakeWriter`]'s - /// [`make_writer_for`][mwf] will return [`OptionalWriter::none`]. + /// [`make_writer_for`][mwf] will return [`OptionalWriter::none`][own]. /// Otherwise, it calls the wrapped [`MakeWriter`]'s /// [`make_writer_for`][mwf] method, and returns the produced writer. /// @@ -404,6 +404,7 @@ pub trait MakeWriterExt<'a>: MakeWriter<'a> { /// /// [`Metadata`]: tracing_core::Metadata /// [mwf]: MakeWriter::make_writer_for + /// [own]: EitherWriter::none fn with_filter(self, filter: F) -> WithFilter where Self: Sized, @@ -446,7 +447,7 @@ pub trait MakeWriterExt<'a>: MakeWriter<'a> { /// Combines `self` with another type implementing [`MakeWriter`], returning /// a new [`MakeWriter`] that calls `other`'s [`make_writer`] if `self`'s - /// `make_writer` returns [`OptionalWriter::none`]. + /// `make_writer` returns [`OptionalWriter::none`][own]. /// /// # Examples /// @@ -466,6 +467,7 @@ pub trait MakeWriterExt<'a>: MakeWriter<'a> { /// ``` /// /// [`make_writer`]: MakeWriter::make_writer + /// [own]: EitherWriter::none fn or_else(self, other: B) -> OrElse where Self: MakeWriter<'a, Writer = OptionalWriter> + Sized, @@ -596,13 +598,15 @@ pub struct WithMinLevel { /// A [`MakeWriter`] combinator that wraps a [`MakeWriter`] with a predicate for /// span and event [`Metadata`], so that the [`MakeWriter::make_writer_for`] -/// method returns [`OptionalWriter::some`] when the predicate returns `true`, -/// and [`OptionalWriter::none`] when the predicate returns `false`. +/// method returns [`OptionalWriter::some`][ows] when the predicate returns `true`, +/// and [`OptionalWriter::none`][own] when the predicate returns `false`. /// /// This is returned by the [`MakeWriterExt::with_filter`] method. See the /// method documentation for details. /// /// [`Metadata`]: tracing_core::Metadata +/// [ows]: EitherWriter::some +/// [own]: EitherWriter::none #[derive(Copy, Clone, Debug, Eq, PartialEq)] pub struct WithFilter { make: M, @@ -611,10 +615,12 @@ pub struct WithFilter { /// Combines a [`MakeWriter`] that returns an [`OptionalWriter`] with another /// [`MakeWriter`], so that the second [`MakeWriter`] is used when the first -/// [`MakeWriter`] returns [`OptionalWriter::none`]. +/// [`MakeWriter`] returns [`OptionalWriter::none`][own]. /// /// This is returned by the [`MakeWriterExt::or_else] method. See the /// method documentation for details. +/// +/// [own]: EitherWriter::none #[derive(Copy, Clone, Debug, Eq, PartialEq)] pub struct OrElse { inner: A, @@ -874,12 +880,13 @@ impl From> for OptionalWriter { impl WithMaxLevel { /// Wraps the provided [`MakeWriter`] with a maximum [`Level`], so that it - /// returns [`OptionalWriter::none`] for spans and events whose level is + /// returns [`OptionalWriter::none`][own] for spans and events whose level is /// more verbose than the maximum level. /// /// See [`MakeWriterExt::with_max_level`] for details. /// /// [`Level`]: tracing_core::Level + /// [own]: EitherWriter::none pub fn new(make: M, level: tracing_core::Level) -> Self { Self { make, level } } @@ -907,12 +914,13 @@ impl<'a, M: MakeWriter<'a>> MakeWriter<'a> for WithMaxLevel { impl WithMinLevel { /// Wraps the provided [`MakeWriter`] with a minimum [`Level`], so that it - /// returns [`OptionalWriter::none`] for spans and events whose level is + /// returns [`OptionalWriter::none`][own] for spans and events whose level is /// less verbose than the maximum level. /// /// See [`MakeWriterExt::with_min_level`] for details. /// /// [`Level`]: tracing_core::Level + /// [own]: EitherWriter::none pub fn new(make: M, level: tracing_core::Level) -> Self { Self { make, level } } diff --git a/tracing-subscriber/src/layer/tests.rs b/tracing-subscriber/src/layer/tests.rs index 68ac956a37..34c91a7c86 100644 --- a/tracing-subscriber/src/layer/tests.rs +++ b/tracing-subscriber/src/layer/tests.rs @@ -1,26 +1,5 @@ use super::*; - -pub(crate) struct NopSubscriber; - -impl Subscriber for NopSubscriber { - fn register_callsite(&self, _: &'static Metadata<'static>) -> Interest { - Interest::never() - } - - fn enabled(&self, _: &Metadata<'_>) -> bool { - false - } - - fn new_span(&self, _: &span::Attributes<'_>) -> span::Id { - span::Id::from_u64(1) - } - - fn record(&self, _: &span::Id, _: &span::Record<'_>) {} - fn record_follows_from(&self, _: &span::Id, _: &span::Id) {} - fn event(&self, _: &Event<'_>) {} - fn enter(&self, _: &span::Id) {} - fn exit(&self, _: &span::Id) {} -} +use tracing_core::subscriber::NoSubscriber; #[derive(Debug)] pub(crate) struct NopLayer; @@ -64,16 +43,19 @@ impl Subscriber for StringSubscriber { } fn assert_subscriber(_s: impl Subscriber) {} +fn assert_layer(_l: &impl Layer) {} #[test] fn layer_is_subscriber() { - let s = NopLayer.with_subscriber(NopSubscriber); + let s = NopLayer.with_subscriber(NoSubscriber::default()); assert_subscriber(s) } #[test] fn two_layers_are_subscriber() { - let s = NopLayer.and_then(NopLayer).with_subscriber(NopSubscriber); + let s = NopLayer + .and_then(NopLayer) + .with_subscriber(NoSubscriber::default()); assert_subscriber(s) } @@ -82,10 +64,24 @@ fn three_layers_are_subscriber() { let s = NopLayer .and_then(NopLayer) .and_then(NopLayer) - .with_subscriber(NopSubscriber); + .with_subscriber(NoSubscriber::default()); assert_subscriber(s) } +#[test] +fn box_layer_is_layer() { + let l: Box + Send + Sync> = Box::new(NopLayer); + assert_layer(&l); + l.with_subscriber(NoSubscriber::default()); +} + +#[test] +fn arc_layer_is_layer() { + let l: Arc + Send + Sync> = Arc::new(NopLayer); + assert_layer(&l); + l.with_subscriber(NoSubscriber::default()); +} + #[test] fn downcasts_to_subscriber() { let s = NopLayer @@ -102,7 +98,7 @@ fn downcasts_to_layer() { let s = StringLayer("layer_1".into()) .and_then(StringLayer2("layer_2".into())) .and_then(StringLayer3("layer_3".into())) - .with_subscriber(NopSubscriber); + .with_subscriber(NoSubscriber::default()); let layer = ::downcast_ref::(&s).expect("layer 1 should downcast"); assert_eq!(&layer.0, "layer_1"); let layer =