From d2f9d055e044addc01240f8049f503857e1a4cdf Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Piotr=20Kie=C5=82kowicz?= Date: Wed, 31 Jan 2024 19:09:42 +0100 Subject: [PATCH] Rename SqlClientInstrumentationOptions to SqlClientTraceInstrumentationOptions (#5285) --- .../.publicApi/PublicAPI.Unshipped.txt | 32 +++++++++---------- .../CHANGELOG.md | 3 ++ .../SqlClientDiagnosticListener.cs | 6 ++-- .../SqlEventSourceListener.netfx.cs | 6 ++-- .../README.md | 6 ++-- .../SqlClientInstrumentation.cs | 2 +- ...> SqlClientTraceInstrumentationOptions.cs} | 2 +- .../TracerProviderBuilderExtensions.cs | 18 +++++------ .../SqlClientTests.cs | 6 ++-- ...ClientTraceInstrumentationOptionsTests.cs} | 10 +++--- .../SqlEventSourceTests.netfx.cs | 2 +- 11 files changed, 48 insertions(+), 45 deletions(-) rename src/OpenTelemetry.Instrumentation.SqlClient/{SqlClientInstrumentationOptions.cs => SqlClientTraceInstrumentationOptions.cs} (99%) rename test/OpenTelemetry.Instrumentation.SqlClient.Tests/{SqlClientInstrumentationOptionsTests.cs => SqlClientTraceInstrumentationOptionsTests.cs} (91%) diff --git a/src/OpenTelemetry.Instrumentation.SqlClient/.publicApi/PublicAPI.Unshipped.txt b/src/OpenTelemetry.Instrumentation.SqlClient/.publicApi/PublicAPI.Unshipped.txt index ee167e8aff..82f785235c 100644 --- a/src/OpenTelemetry.Instrumentation.SqlClient/.publicApi/PublicAPI.Unshipped.txt +++ b/src/OpenTelemetry.Instrumentation.SqlClient/.publicApi/PublicAPI.Unshipped.txt @@ -1,18 +1,18 @@ -OpenTelemetry.Instrumentation.SqlClient.SqlClientInstrumentationOptions -OpenTelemetry.Instrumentation.SqlClient.SqlClientInstrumentationOptions.EnableConnectionLevelAttributes.get -> bool -OpenTelemetry.Instrumentation.SqlClient.SqlClientInstrumentationOptions.EnableConnectionLevelAttributes.set -> void -OpenTelemetry.Instrumentation.SqlClient.SqlClientInstrumentationOptions.Enrich.get -> System.Action -OpenTelemetry.Instrumentation.SqlClient.SqlClientInstrumentationOptions.Enrich.set -> void -OpenTelemetry.Instrumentation.SqlClient.SqlClientInstrumentationOptions.Filter.get -> System.Func -OpenTelemetry.Instrumentation.SqlClient.SqlClientInstrumentationOptions.Filter.set -> void -OpenTelemetry.Instrumentation.SqlClient.SqlClientInstrumentationOptions.RecordException.get -> bool -OpenTelemetry.Instrumentation.SqlClient.SqlClientInstrumentationOptions.RecordException.set -> void -OpenTelemetry.Instrumentation.SqlClient.SqlClientInstrumentationOptions.SetDbStatementForStoredProcedure.get -> bool -OpenTelemetry.Instrumentation.SqlClient.SqlClientInstrumentationOptions.SetDbStatementForStoredProcedure.set -> void -OpenTelemetry.Instrumentation.SqlClient.SqlClientInstrumentationOptions.SetDbStatementForText.get -> bool -OpenTelemetry.Instrumentation.SqlClient.SqlClientInstrumentationOptions.SetDbStatementForText.set -> void -OpenTelemetry.Instrumentation.SqlClient.SqlClientInstrumentationOptions.SqlClientInstrumentationOptions() -> void +OpenTelemetry.Instrumentation.SqlClient.SqlClientTraceInstrumentationOptions +OpenTelemetry.Instrumentation.SqlClient.SqlClientTraceInstrumentationOptions.EnableConnectionLevelAttributes.get -> bool +OpenTelemetry.Instrumentation.SqlClient.SqlClientTraceInstrumentationOptions.EnableConnectionLevelAttributes.set -> void +OpenTelemetry.Instrumentation.SqlClient.SqlClientTraceInstrumentationOptions.Enrich.get -> System.Action +OpenTelemetry.Instrumentation.SqlClient.SqlClientTraceInstrumentationOptions.Enrich.set -> void +OpenTelemetry.Instrumentation.SqlClient.SqlClientTraceInstrumentationOptions.Filter.get -> System.Func +OpenTelemetry.Instrumentation.SqlClient.SqlClientTraceInstrumentationOptions.Filter.set -> void +OpenTelemetry.Instrumentation.SqlClient.SqlClientTraceInstrumentationOptions.RecordException.get -> bool +OpenTelemetry.Instrumentation.SqlClient.SqlClientTraceInstrumentationOptions.RecordException.set -> void +OpenTelemetry.Instrumentation.SqlClient.SqlClientTraceInstrumentationOptions.SetDbStatementForStoredProcedure.get -> bool +OpenTelemetry.Instrumentation.SqlClient.SqlClientTraceInstrumentationOptions.SetDbStatementForStoredProcedure.set -> void +OpenTelemetry.Instrumentation.SqlClient.SqlClientTraceInstrumentationOptions.SetDbStatementForText.get -> bool +OpenTelemetry.Instrumentation.SqlClient.SqlClientTraceInstrumentationOptions.SetDbStatementForText.set -> void +OpenTelemetry.Instrumentation.SqlClient.SqlClientTraceInstrumentationOptions.SqlClientTraceInstrumentationOptions() -> void OpenTelemetry.Trace.TracerProviderBuilderExtensions static OpenTelemetry.Trace.TracerProviderBuilderExtensions.AddSqlClientInstrumentation(this OpenTelemetry.Trace.TracerProviderBuilder builder) -> OpenTelemetry.Trace.TracerProviderBuilder -static OpenTelemetry.Trace.TracerProviderBuilderExtensions.AddSqlClientInstrumentation(this OpenTelemetry.Trace.TracerProviderBuilder builder, string name, System.Action configureSqlClientInstrumentationOptions) -> OpenTelemetry.Trace.TracerProviderBuilder -static OpenTelemetry.Trace.TracerProviderBuilderExtensions.AddSqlClientInstrumentation(this OpenTelemetry.Trace.TracerProviderBuilder builder, System.Action configureSqlClientInstrumentationOptions) -> OpenTelemetry.Trace.TracerProviderBuilder +static OpenTelemetry.Trace.TracerProviderBuilderExtensions.AddSqlClientInstrumentation(this OpenTelemetry.Trace.TracerProviderBuilder builder, string name, System.Action configureSqlClientTraceInstrumentationOptions) -> OpenTelemetry.Trace.TracerProviderBuilder +static OpenTelemetry.Trace.TracerProviderBuilderExtensions.AddSqlClientInstrumentation(this OpenTelemetry.Trace.TracerProviderBuilder builder, System.Action configureSqlClientTraceInstrumentationOptions) -> OpenTelemetry.Trace.TracerProviderBuilder diff --git a/src/OpenTelemetry.Instrumentation.SqlClient/CHANGELOG.md b/src/OpenTelemetry.Instrumentation.SqlClient/CHANGELOG.md index 31d8b70e2c..e027743699 100644 --- a/src/OpenTelemetry.Instrumentation.SqlClient/CHANGELOG.md +++ b/src/OpenTelemetry.Instrumentation.SqlClient/CHANGELOG.md @@ -8,6 +8,9 @@ Now that this suite of attributes are stable, this instrumentation will only emit the new attributes. ([#5270](https://github.com/open-telemetry/opentelemetry-dotnet/pull/5270)) +* **Breaking Change**: Renamed `SqlClientInstrumentationOptions` to + `SqlClientTraceInstrumentationOptions`. + ([#5285](https://github.com/open-telemetry/opentelemetry-dotnet/pull/5285)) ## 1.6.0-beta.3 diff --git a/src/OpenTelemetry.Instrumentation.SqlClient/Implementation/SqlClientDiagnosticListener.cs b/src/OpenTelemetry.Instrumentation.SqlClient/Implementation/SqlClientDiagnosticListener.cs index a29d155081..b16f6223aa 100644 --- a/src/OpenTelemetry.Instrumentation.SqlClient/Implementation/SqlClientDiagnosticListener.cs +++ b/src/OpenTelemetry.Instrumentation.SqlClient/Implementation/SqlClientDiagnosticListener.cs @@ -32,12 +32,12 @@ internal sealed class SqlClientDiagnosticListener : ListenerHandler private readonly PropertyFetcher commandTypeFetcher = new("CommandType"); private readonly PropertyFetcher commandTextFetcher = new("CommandText"); private readonly PropertyFetcher exceptionFetcher = new("Exception"); - private readonly SqlClientInstrumentationOptions options; + private readonly SqlClientTraceInstrumentationOptions options; - public SqlClientDiagnosticListener(string sourceName, SqlClientInstrumentationOptions options) + public SqlClientDiagnosticListener(string sourceName, SqlClientTraceInstrumentationOptions options) : base(sourceName) { - this.options = options ?? new SqlClientInstrumentationOptions(); + this.options = options ?? new SqlClientTraceInstrumentationOptions(); } public override bool SupportsNullActivity => true; diff --git a/src/OpenTelemetry.Instrumentation.SqlClient/Implementation/SqlEventSourceListener.netfx.cs b/src/OpenTelemetry.Instrumentation.SqlClient/Implementation/SqlEventSourceListener.netfx.cs index 7edf94ee2c..111e4878d3 100644 --- a/src/OpenTelemetry.Instrumentation.SqlClient/Implementation/SqlEventSourceListener.netfx.cs +++ b/src/OpenTelemetry.Instrumentation.SqlClient/Implementation/SqlEventSourceListener.netfx.cs @@ -29,13 +29,13 @@ internal sealed class SqlEventSourceListener : EventListener internal const int BeginExecuteEventId = 1; internal const int EndExecuteEventId = 2; - private readonly SqlClientInstrumentationOptions options; + private readonly SqlClientTraceInstrumentationOptions options; private EventSource adoNetEventSource; private EventSource mdsEventSource; - public SqlEventSourceListener(SqlClientInstrumentationOptions options = null) + public SqlEventSourceListener(SqlClientTraceInstrumentationOptions options = null) { - this.options = options ?? new SqlClientInstrumentationOptions(); + this.options = options ?? new SqlClientTraceInstrumentationOptions(); } public override void Dispose() diff --git a/src/OpenTelemetry.Instrumentation.SqlClient/README.md b/src/OpenTelemetry.Instrumentation.SqlClient/README.md index b67f9a788e..1df0435250 100644 --- a/src/OpenTelemetry.Instrumentation.SqlClient/README.md +++ b/src/OpenTelemetry.Instrumentation.SqlClient/README.md @@ -75,12 +75,12 @@ For an ASP.NET application, adding instrumentation is typically done in the ## Advanced configuration This instrumentation can be configured to change the default behavior by using -`SqlClientInstrumentationOptions`. +`SqlClientTraceInstrumentationOptions`. ### Capturing database statements -The `SqlClientInstrumentationOptions` class exposes two properties that can be -used to configure how the +The `SqlClientTraceInstrumentationOptions` class exposes two properties that can +be used to configure how the [`db.statement`](https://github.com/open-telemetry/semantic-conventions/blob/main/docs/database/database-spans.md#call-level-attributes) attribute is captured upon execution of a query but the behavior depends on the runtime used. diff --git a/src/OpenTelemetry.Instrumentation.SqlClient/SqlClientInstrumentation.cs b/src/OpenTelemetry.Instrumentation.SqlClient/SqlClientInstrumentation.cs index a5c5a527a5..9b4230a460 100644 --- a/src/OpenTelemetry.Instrumentation.SqlClient/SqlClientInstrumentation.cs +++ b/src/OpenTelemetry.Instrumentation.SqlClient/SqlClientInstrumentation.cs @@ -44,7 +44,7 @@ internal sealed class SqlClientInstrumentation : IDisposable [RequiresUnreferencedCode(SqlClientTrimmingUnsupportedMessage)] #endif public SqlClientInstrumentation( - SqlClientInstrumentationOptions options = null) + SqlClientTraceInstrumentationOptions options = null) { #if NETFRAMEWORK this.sqlEventSourceListener = new SqlEventSourceListener(options); diff --git a/src/OpenTelemetry.Instrumentation.SqlClient/SqlClientInstrumentationOptions.cs b/src/OpenTelemetry.Instrumentation.SqlClient/SqlClientTraceInstrumentationOptions.cs similarity index 99% rename from src/OpenTelemetry.Instrumentation.SqlClient/SqlClientInstrumentationOptions.cs rename to src/OpenTelemetry.Instrumentation.SqlClient/SqlClientTraceInstrumentationOptions.cs index e2d54565ce..3dec363163 100644 --- a/src/OpenTelemetry.Instrumentation.SqlClient/SqlClientInstrumentationOptions.cs +++ b/src/OpenTelemetry.Instrumentation.SqlClient/SqlClientTraceInstrumentationOptions.cs @@ -15,7 +15,7 @@ namespace OpenTelemetry.Instrumentation.SqlClient; /// /// For help and examples see: . /// -public class SqlClientInstrumentationOptions +public class SqlClientTraceInstrumentationOptions { /* * Match... diff --git a/src/OpenTelemetry.Instrumentation.SqlClient/TracerProviderBuilderExtensions.cs b/src/OpenTelemetry.Instrumentation.SqlClient/TracerProviderBuilderExtensions.cs index 774d64ed91..9634759bcc 100644 --- a/src/OpenTelemetry.Instrumentation.SqlClient/TracerProviderBuilderExtensions.cs +++ b/src/OpenTelemetry.Instrumentation.SqlClient/TracerProviderBuilderExtensions.cs @@ -26,28 +26,28 @@ public static class TracerProviderBuilderExtensions [RequiresUnreferencedCode(SqlClientInstrumentation.SqlClientTrimmingUnsupportedMessage)] #endif public static TracerProviderBuilder AddSqlClientInstrumentation(this TracerProviderBuilder builder) - => AddSqlClientInstrumentation(builder, name: null, configureSqlClientInstrumentationOptions: null); + => AddSqlClientInstrumentation(builder, name: null, configureSqlClientTraceInstrumentationOptions: null); /// /// Enables SqlClient instrumentation. /// /// being configured. - /// Callback action for configuring . + /// Callback action for configuring . /// The instance of to chain the calls. #if NET6_0_OR_GREATER [RequiresUnreferencedCode(SqlClientInstrumentation.SqlClientTrimmingUnsupportedMessage)] #endif public static TracerProviderBuilder AddSqlClientInstrumentation( this TracerProviderBuilder builder, - Action configureSqlClientInstrumentationOptions) - => AddSqlClientInstrumentation(builder, name: null, configureSqlClientInstrumentationOptions); + Action configureSqlClientTraceInstrumentationOptions) + => AddSqlClientInstrumentation(builder, name: null, configureSqlClientTraceInstrumentationOptions); /// /// Enables SqlClient instrumentation. /// /// being configured. /// Name which is used when retrieving options. - /// Callback action for configuring . + /// Callback action for configuring . /// The instance of to chain the calls. #if NET6_0_OR_GREATER [RequiresUnreferencedCode(SqlClientInstrumentation.SqlClientTrimmingUnsupportedMessage)] @@ -56,20 +56,20 @@ public static TracerProviderBuilder AddSqlClientInstrumentation( public static TracerProviderBuilder AddSqlClientInstrumentation( this TracerProviderBuilder builder, string name, - Action configureSqlClientInstrumentationOptions) + Action configureSqlClientTraceInstrumentationOptions) { Guard.ThrowIfNull(builder); name ??= Options.DefaultName; - if (configureSqlClientInstrumentationOptions != null) + if (configureSqlClientTraceInstrumentationOptions != null) { - builder.ConfigureServices(services => services.Configure(name, configureSqlClientInstrumentationOptions)); + builder.ConfigureServices(services => services.Configure(name, configureSqlClientTraceInstrumentationOptions)); } builder.AddInstrumentation(sp => { - var sqlOptions = sp.GetRequiredService>().Get(name); + var sqlOptions = sp.GetRequiredService>().Get(name); return new SqlClientInstrumentation(sqlOptions); }); diff --git a/test/OpenTelemetry.Instrumentation.SqlClient.Tests/SqlClientTests.cs b/test/OpenTelemetry.Instrumentation.SqlClient.Tests/SqlClientTests.cs index 01e1c3eaf7..ca05b959ee 100644 --- a/test/OpenTelemetry.Instrumentation.SqlClient.Tests/SqlClientTests.cs +++ b/test/OpenTelemetry.Instrumentation.SqlClient.Tests/SqlClientTests.cs @@ -47,12 +47,12 @@ public void SqlClient_NamedOptions() using var tracerProvider = Sdk.CreateTracerProviderBuilder() .ConfigureServices(services => { - services.Configure(o => defaultExporterOptionsConfigureOptionsInvocations++); + services.Configure(o => defaultExporterOptionsConfigureOptionsInvocations++); - services.Configure("Instrumentation2", o => namedExporterOptionsConfigureOptionsInvocations++); + services.Configure("Instrumentation2", o => namedExporterOptionsConfigureOptionsInvocations++); }) .AddSqlClientInstrumentation() - .AddSqlClientInstrumentation("Instrumentation2", configureSqlClientInstrumentationOptions: null) + .AddSqlClientInstrumentation("Instrumentation2", configureSqlClientTraceInstrumentationOptions: null) .Build(); Assert.Equal(1, defaultExporterOptionsConfigureOptionsInvocations); diff --git a/test/OpenTelemetry.Instrumentation.SqlClient.Tests/SqlClientInstrumentationOptionsTests.cs b/test/OpenTelemetry.Instrumentation.SqlClient.Tests/SqlClientTraceInstrumentationOptionsTests.cs similarity index 91% rename from test/OpenTelemetry.Instrumentation.SqlClient.Tests/SqlClientInstrumentationOptionsTests.cs rename to test/OpenTelemetry.Instrumentation.SqlClient.Tests/SqlClientTraceInstrumentationOptionsTests.cs index 7626706503..47ad7d4fe0 100644 --- a/test/OpenTelemetry.Instrumentation.SqlClient.Tests/SqlClientInstrumentationOptionsTests.cs +++ b/test/OpenTelemetry.Instrumentation.SqlClient.Tests/SqlClientTraceInstrumentationOptionsTests.cs @@ -7,9 +7,9 @@ namespace OpenTelemetry.Instrumentation.SqlClient.Tests; -public class SqlClientInstrumentationOptionsTests +public class SqlClientTraceInstrumentationOptionsTests { - static SqlClientInstrumentationOptionsTests() + static SqlClientTraceInstrumentationOptionsTests() { Activity.DefaultIdFormat = ActivityIdFormat.W3C; Activity.ForceDefaultIdFormat = true; @@ -45,7 +45,7 @@ public void ParseDataSourceTests( string expectedInstanceName, string expectedPort) { - var sqlConnectionDetails = SqlClientInstrumentationOptions.ParseDataSource(dataSource); + var sqlConnectionDetails = SqlClientTraceInstrumentationOptions.ParseDataSource(dataSource); Assert.NotNull(sqlConnectionDetails); Assert.Equal(expectedServerHostName, sqlConnectionDetails.ServerHostName); @@ -60,7 +60,7 @@ public void ParseDataSourceTests( [InlineData(true, "127.0.0.1,1434", null, "127.0.0.1", null, "1434")] [InlineData(true, "127.0.0.1\\instanceName, 1818", null, "127.0.0.1", "instanceName", "1818")] [InlineData(false, "localhost", "localhost", null, null, null)] - public void SqlClientInstrumentationOptions_EnableConnectionLevelAttributes( + public void SqlClientTraceInstrumentationOptions_EnableConnectionLevelAttributes( bool enableConnectionLevelAttributes, string dataSource, string expectedServerHostName, @@ -70,7 +70,7 @@ public void SqlClientInstrumentationOptions_EnableConnectionLevelAttributes( { var source = new ActivitySource("sql-client-instrumentation"); var activity = source.StartActivity("Test Sql Activity"); - var options = new SqlClientInstrumentationOptions() + var options = new SqlClientTraceInstrumentationOptions() { EnableConnectionLevelAttributes = enableConnectionLevelAttributes, }; diff --git a/test/OpenTelemetry.Instrumentation.SqlClient.Tests/SqlEventSourceTests.netfx.cs b/test/OpenTelemetry.Instrumentation.SqlClient.Tests/SqlEventSourceTests.netfx.cs index 2aede25223..b900fd8bf1 100644 --- a/test/OpenTelemetry.Instrumentation.SqlClient.Tests/SqlEventSourceTests.netfx.cs +++ b/test/OpenTelemetry.Instrumentation.SqlClient.Tests/SqlEventSourceTests.netfx.cs @@ -222,7 +222,7 @@ private static void VerifyActivityData( } else { - var connectionDetails = SqlClientInstrumentationOptions.ParseDataSource(dataSource); + var connectionDetails = SqlClientTraceInstrumentationOptions.ParseDataSource(dataSource); if (!string.IsNullOrEmpty(connectionDetails.ServerHostName)) {