From e683b00aece126487b1c275938885eee7731825a Mon Sep 17 00:00:00 2001 From: Gabriel Goller Date: Mon, 30 Oct 2023 22:13:19 +0100 Subject: [PATCH] attributes: added missing RecordTypes for instrument (#2781) When using a function annotated with `#[instrument]` it parses the parameters of the function and records them either using `Value` or using `std::fmt::Debug`. There were a few types that implement `Value` but were missing the RecordTypes array. Added them + a unit test for a single one. Fixed: #2775 --- tracing-attributes/src/expand.rs | 5 +++++ tracing-attributes/tests/instrument.rs | 8 +++++--- 2 files changed, 10 insertions(+), 3 deletions(-) diff --git a/tracing-attributes/src/expand.rs b/tracing-attributes/src/expand.rs index a7123e5239..321f0ce810 100644 --- a/tracing-attributes/src/expand.rs +++ b/tracing-attributes/src/expand.rs @@ -422,10 +422,13 @@ impl RecordType { "i32", "u64", "i64", + "u128", + "i128", "f32", "f64", "usize", "isize", + "String", "NonZeroU8", "NonZeroI8", "NonZeroU16", @@ -434,6 +437,8 @@ impl RecordType { "NonZeroI32", "NonZeroU64", "NonZeroI64", + "NonZeroU128", + "NonZeroI128", "NonZeroUsize", "NonZeroIsize", "Wrapping", diff --git a/tracing-attributes/tests/instrument.rs b/tracing-attributes/tests/instrument.rs index f751eebf69..351ae53e18 100644 --- a/tracing-attributes/tests/instrument.rs +++ b/tracing-attributes/tests/instrument.rs @@ -51,7 +51,7 @@ fn override_everything() { #[test] fn fields() { #[instrument(target = "my_target", level = "debug")] - fn my_fn(arg1: usize, arg2: bool) {} + fn my_fn(arg1: usize, arg2: bool, arg3: String) {} let span = expect::span() .named("my_fn") @@ -68,6 +68,7 @@ fn fields() { expect::field("arg1") .with_value(&2usize) .and(expect::field("arg2").with_value(&false)) + .and(expect::field("arg3").with_value(&"Cool".to_string())) .only(), ), ) @@ -79,6 +80,7 @@ fn fields() { expect::field("arg1") .with_value(&3usize) .and(expect::field("arg2").with_value(&true)) + .and(expect::field("arg3").with_value(&"Still Cool".to_string())) .only(), ), ) @@ -89,8 +91,8 @@ fn fields() { .run_with_handle(); with_default(subscriber, || { - my_fn(2, false); - my_fn(3, true); + my_fn(2, false, "Cool".to_string()); + my_fn(3, true, "Still Cool".to_string()); }); handle.assert_finished();