diff --git a/examples/AspNet/Global.asax.cs b/examples/AspNet/Global.asax.cs index c1fc938f69..2dc5ae1053 100644 --- a/examples/AspNet/Global.asax.cs +++ b/examples/AspNet/Global.asax.cs @@ -36,10 +36,8 @@ public class WebApiApplication : HttpApplication protected void Application_Start() { var builder = Sdk.CreateTracerProviderBuilder() - .AddAspNetInstrumentation(options => options.Propagator = new B3Propagator()) - .AddHttpClientInstrumentation( - httpClientOptions => httpClientOptions.Propagator = new B3Propagator(), - httpWebRequestOptions => httpWebRequestOptions.Propagator = new B3Propagator()); + .AddAspNetInstrumentation() + .AddHttpClientInstrumentation(); switch (ConfigurationManager.AppSettings["UseExporter"].ToLowerInvariant()) { diff --git a/src/OpenTelemetry.Instrumentation.AspNet/AspNetInstrumentationOptions.cs b/src/OpenTelemetry.Instrumentation.AspNet/AspNetInstrumentationOptions.cs index c0c97345e7..ea0e9f0616 100644 --- a/src/OpenTelemetry.Instrumentation.AspNet/AspNetInstrumentationOptions.cs +++ b/src/OpenTelemetry.Instrumentation.AspNet/AspNetInstrumentationOptions.cs @@ -17,7 +17,6 @@ using System; using System.Diagnostics; using System.Web; -using OpenTelemetry.Context.Propagation; namespace OpenTelemetry.Instrumentation.AspNet { @@ -26,12 +25,6 @@ namespace OpenTelemetry.Instrumentation.AspNet /// public class AspNetInstrumentationOptions { - /// - /// Gets or sets for context propagation. - /// By default, will be used. - /// - public TextMapPropagator Propagator { get; set; } - /// /// Gets or sets a Filter function to filter instrumentation for requests on a per request basis. /// The Filter gets the HttpContext, and should return a boolean. diff --git a/src/OpenTelemetry.Instrumentation.AspNet/CHANGELOG.md b/src/OpenTelemetry.Instrumentation.AspNet/CHANGELOG.md index dd2c46a185..7fcd29b50b 100644 --- a/src/OpenTelemetry.Instrumentation.AspNet/CHANGELOG.md +++ b/src/OpenTelemetry.Instrumentation.AspNet/CHANGELOG.md @@ -6,8 +6,11 @@ to CompositeTextMapPropagator. IPropagator is renamed to TextMapPropagator and changed from interface to abstract class. ([#1427](https://github.com/open-telemetry/opentelemetry-dotnet/pull/1427)) -* Propagators.DefaultTextMapPropagator will be used as the default Propagator +* Propagators.DefaultTextMapPropagator will be used as the default Propagator. ([#1427](https://github.com/open-telemetry/opentelemetry-dotnet/pull/1428)) +* Removed Propagator from Instrumentation Options. Instrumentation now always + respect the Propagator.DefaultTextMapPropagator. + ([#1448](https://github.com/open-telemetry/opentelemetry-dotnet/pull/1448)) ## 0.7.0-beta.1 diff --git a/src/OpenTelemetry.Instrumentation.AspNet/Implementation/HttpInListener.cs b/src/OpenTelemetry.Instrumentation.AspNet/Implementation/HttpInListener.cs index ac7d363670..25fc3b9773 100644 --- a/src/OpenTelemetry.Instrumentation.AspNet/Implementation/HttpInListener.cs +++ b/src/OpenTelemetry.Instrumentation.AspNet/Implementation/HttpInListener.cs @@ -69,7 +69,7 @@ public override void OnStartActivity(Activity activity, object payload) var request = context.Request; var requestValues = request.Unvalidated; - var textMapPropagator = this.options.Propagator ?? Propagators.DefaultTextMapPropagator; + var textMapPropagator = Propagators.DefaultTextMapPropagator; if (!(textMapPropagator is TraceContextPropagator)) { @@ -140,7 +140,7 @@ public override void OnStopActivity(Activity activity, object payload) Activity activityToEnrich = activity; Activity createdActivity = null; - var textMapPropagator = this.options.Propagator ?? Propagators.DefaultTextMapPropagator; + var textMapPropagator = Propagators.DefaultTextMapPropagator; bool isCustomPropagator = !(textMapPropagator is TraceContextPropagator); if (isCustomPropagator) diff --git a/src/OpenTelemetry.Instrumentation.AspNet/README.md b/src/OpenTelemetry.Instrumentation.AspNet/README.md index 53e330a452..1ad20d0af4 100644 --- a/src/OpenTelemetry.Instrumentation.AspNet/README.md +++ b/src/OpenTelemetry.Instrumentation.AspNet/README.md @@ -71,12 +71,7 @@ public class WebApiApplication : HttpApplication ## Advanced configuration This instrumentation can be configured to change the default behavior by using -`AspNetInstrumentationOptions`, which allows configuring `Propagator` and -`Filter` as explained below. - -### Propagator - -TODO +`AspNetInstrumentationOptions`, which allows configuring `Filter` as explained below. ### Filter diff --git a/src/OpenTelemetry.Instrumentation.AspNetCore/AspNetCoreInstrumentationOptions.cs b/src/OpenTelemetry.Instrumentation.AspNetCore/AspNetCoreInstrumentationOptions.cs index da3b9a908f..528bae8674 100644 --- a/src/OpenTelemetry.Instrumentation.AspNetCore/AspNetCoreInstrumentationOptions.cs +++ b/src/OpenTelemetry.Instrumentation.AspNetCore/AspNetCoreInstrumentationOptions.cs @@ -17,7 +17,6 @@ using System; using System.Diagnostics; using Microsoft.AspNetCore.Http; -using OpenTelemetry.Context.Propagation; namespace OpenTelemetry.Instrumentation.AspNetCore { @@ -26,12 +25,6 @@ namespace OpenTelemetry.Instrumentation.AspNetCore /// public class AspNetCoreInstrumentationOptions { - /// - /// Gets or sets for context propagation. - /// By default, will be used. - /// - public TextMapPropagator Propagator { get; set; } = Propagators.DefaultTextMapPropagator; - /// /// Gets or sets a Filter function to filter instrumentation for requests on a per request basis. /// The Filter gets the HttpContext, and should return a boolean. diff --git a/src/OpenTelemetry.Instrumentation.AspNetCore/CHANGELOG.md b/src/OpenTelemetry.Instrumentation.AspNetCore/CHANGELOG.md index 0de5b6a486..5d3d4a29ff 100644 --- a/src/OpenTelemetry.Instrumentation.AspNetCore/CHANGELOG.md +++ b/src/OpenTelemetry.Instrumentation.AspNetCore/CHANGELOG.md @@ -16,6 +16,9 @@ ([#1427](https://github.com/open-telemetry/opentelemetry-dotnet/pull/1427)) * Propagators.DefaultTextMapPropagator will be used as the default Propagator ([#1427](https://github.com/open-telemetry/opentelemetry-dotnet/pull/1428)) +* Removed Propagator from Instrumentation Options. Instrumentation now always + respect the Propagator.DefaultTextMapPropagator. + ([#1448](https://github.com/open-telemetry/opentelemetry-dotnet/pull/1448)) ## 0.7.0-beta.1 diff --git a/src/OpenTelemetry.Instrumentation.AspNetCore/Implementation/HttpInListener.cs b/src/OpenTelemetry.Instrumentation.AspNetCore/Implementation/HttpInListener.cs index 9015af938b..03cde029a9 100644 --- a/src/OpenTelemetry.Instrumentation.AspNetCore/Implementation/HttpInListener.cs +++ b/src/OpenTelemetry.Instrumentation.AspNetCore/Implementation/HttpInListener.cs @@ -78,9 +78,10 @@ public override void OnStartActivity(Activity activity, object payload) } var request = context.Request; - if (!this.hostingSupportsW3C || !(this.options.Propagator is TraceContextPropagator)) + var textMapPropagator = Propagators.DefaultTextMapPropagator; + if (!this.hostingSupportsW3C || !(textMapPropagator is TraceContextPropagator)) { - var ctx = this.options.Propagator.Extract(default, request, HttpRequestHeaderValuesGetter); + var ctx = textMapPropagator.Extract(default, request, HttpRequestHeaderValuesGetter); if (ctx.ActivityContext.IsValid() && ctx.ActivityContext != new ActivityContext(activity.TraceId, activity.ParentSpanId, activity.ActivityTraceFlags, activity.TraceStateString, true)) diff --git a/src/OpenTelemetry.Instrumentation.AspNetCore/README.md b/src/OpenTelemetry.Instrumentation.AspNetCore/README.md index 2f6955cdc2..5e822fcd80 100644 --- a/src/OpenTelemetry.Instrumentation.AspNetCore/README.md +++ b/src/OpenTelemetry.Instrumentation.AspNetCore/README.md @@ -54,14 +54,9 @@ public void ConfigureServices(IServiceCollection services) ## Advanced configuration This instrumentation can be configured to change the default behavior by using -`AspNetCoreInstrumentationOptions`, which allows configuring -[`Propagator`](#propagator) and adding [`Filter`](#filter), +`AspNetCoreInstrumentationOptions`, which allows adding [`Filter`](#filter), [`Enrich`](#enrich) as explained below. -### Propagator - -TODO - ### Filter This instrumentation by default collects all the incoming http requests. It diff --git a/src/OpenTelemetry.Instrumentation.Http/CHANGELOG.md b/src/OpenTelemetry.Instrumentation.Http/CHANGELOG.md index 0e4d8e4a63..d04bfe3d81 100644 --- a/src/OpenTelemetry.Instrumentation.Http/CHANGELOG.md +++ b/src/OpenTelemetry.Instrumentation.Http/CHANGELOG.md @@ -12,6 +12,9 @@ ([#1427](https://github.com/open-telemetry/opentelemetry-dotnet/pull/1427)) * Propagators.DefaultTextMapPropagator will be used as the default Propagator ([#1427](https://github.com/open-telemetry/opentelemetry-dotnet/pull/1428)) +* Removed Propagator from Instrumentation Options. Instrumentation now always + respect the Propagator.DefaultTextMapPropagator. + ([#1448](https://github.com/open-telemetry/opentelemetry-dotnet/pull/1448)) ## 0.7.0-beta.1 diff --git a/src/OpenTelemetry.Instrumentation.Http/HttpClientInstrumentationOptions.cs b/src/OpenTelemetry.Instrumentation.Http/HttpClientInstrumentationOptions.cs index eaf8fd1dcf..3d836d8bad 100644 --- a/src/OpenTelemetry.Instrumentation.Http/HttpClientInstrumentationOptions.cs +++ b/src/OpenTelemetry.Instrumentation.Http/HttpClientInstrumentationOptions.cs @@ -18,7 +18,6 @@ using System.Diagnostics; using System.Net.Http; using System.Runtime.CompilerServices; -using OpenTelemetry.Context.Propagation; using OpenTelemetry.Instrumentation.Http.Implementation; using OpenTelemetry.Trace; @@ -34,12 +33,6 @@ public class HttpClientInstrumentationOptions /// public bool SetHttpFlavor { get; set; } - /// - /// Gets or sets for context propagation. - /// By default, will be used. - /// - public TextMapPropagator Propagator { get; set; } = Propagators.DefaultTextMapPropagator; - /// /// Gets or sets a Filter function to filter instrumentation for requests on a per request basis. /// The Filter gets the HttpRequestMessage, and should return a boolean. diff --git a/src/OpenTelemetry.Instrumentation.Http/HttpWebRequestInstrumentationOptions.netfx.cs b/src/OpenTelemetry.Instrumentation.Http/HttpWebRequestInstrumentationOptions.netfx.cs index c96a901bed..c9d3497e89 100644 --- a/src/OpenTelemetry.Instrumentation.Http/HttpWebRequestInstrumentationOptions.netfx.cs +++ b/src/OpenTelemetry.Instrumentation.Http/HttpWebRequestInstrumentationOptions.netfx.cs @@ -18,7 +18,6 @@ using System; using System.Diagnostics; using System.Net; -using OpenTelemetry.Context.Propagation; using OpenTelemetry.Instrumentation.Http.Implementation; using OpenTelemetry.Trace; @@ -34,15 +33,6 @@ public class HttpWebRequestInstrumentationOptions /// public bool SetHttpFlavor { get; set; } - /// - /// Gets or sets for context propagation. Default value: with & . - /// - public TextMapPropagator Propagator { get; set; } = new CompositeTextMapPropagator(new TextMapPropagator[] - { - new TraceContextPropagator(), - new BaggagePropagator(), - }); - /// /// Gets or sets a Filter function to filter instrumentation for requests on a per request basis. /// The Filter gets the HttpWebRequest, and should return a boolean. diff --git a/src/OpenTelemetry.Instrumentation.Http/Implementation/HttpHandlerDiagnosticListener.cs b/src/OpenTelemetry.Instrumentation.Http/Implementation/HttpHandlerDiagnosticListener.cs index ec810f3a65..9b877fa601 100644 --- a/src/OpenTelemetry.Instrumentation.Http/Implementation/HttpHandlerDiagnosticListener.cs +++ b/src/OpenTelemetry.Instrumentation.Http/Implementation/HttpHandlerDiagnosticListener.cs @@ -83,7 +83,7 @@ public override void OnStartActivity(Activity activity, object payload) return; } - if (this.options.Propagator.Extract(default, request, HttpRequestMessageHeaderValuesGetter) != default) + if (Propagators.DefaultTextMapPropagator.Extract(default, request, HttpRequestMessageHeaderValuesGetter) != default) { // this request is already instrumented, we should back off activity.IsAllDataRequested = false; @@ -115,9 +115,11 @@ public override void OnStartActivity(Activity activity, object payload) } } - if (!(this.httpClientSupportsW3C && this.options.Propagator is TraceContextPropagator)) + var textMapPropagator = Propagators.DefaultTextMapPropagator; + + if (!(this.httpClientSupportsW3C && textMapPropagator is TraceContextPropagator)) { - this.options.Propagator.Inject(new PropagationContext(activity.Context, Baggage.Current), request, HttpRequestMessageHeaderValueSetter); + textMapPropagator.Inject(new PropagationContext(activity.Context, Baggage.Current), request, HttpRequestMessageHeaderValueSetter); } } diff --git a/src/OpenTelemetry.Instrumentation.Http/Implementation/HttpWebRequestActivitySource.netfx.cs b/src/OpenTelemetry.Instrumentation.Http/Implementation/HttpWebRequestActivitySource.netfx.cs index 7603cf37a2..cef7f85585 100644 --- a/src/OpenTelemetry.Instrumentation.Http/Implementation/HttpWebRequestActivitySource.netfx.cs +++ b/src/OpenTelemetry.Instrumentation.Http/Implementation/HttpWebRequestActivitySource.netfx.cs @@ -196,11 +196,11 @@ private static void AddExceptionTags(Exception exception, Activity activity) [MethodImpl(MethodImplOptions.AggressiveInlining)] private static void InstrumentRequest(HttpWebRequest request, ActivityContext activityContext) - => Options.Propagator.Inject(new PropagationContext(activityContext, Baggage.Current), request, HttpWebRequestHeaderValuesSetter); + => Propagators.DefaultTextMapPropagator.Inject(new PropagationContext(activityContext, Baggage.Current), request, HttpWebRequestHeaderValuesSetter); [MethodImpl(MethodImplOptions.AggressiveInlining)] private static bool IsRequestInstrumented(HttpWebRequest request) - => Options.Propagator.Extract(default, request, HttpWebRequestHeaderValuesGetter) != default; + => Propagators.DefaultTextMapPropagator.Extract(default, request, HttpWebRequestHeaderValuesGetter) != default; private static void ProcessRequest(HttpWebRequest request) { diff --git a/test/OpenTelemetry.Instrumentation.AspNet.Tests/HttpInListenerTests.cs b/test/OpenTelemetry.Instrumentation.AspNet.Tests/HttpInListenerTests.cs index 40326f39fe..bf4c110a45 100644 --- a/test/OpenTelemetry.Instrumentation.AspNet.Tests/HttpInListenerTests.cs +++ b/test/OpenTelemetry.Instrumentation.AspNet.Tests/HttpInListenerTests.cs @@ -144,6 +144,7 @@ public void AspNetRequestsAreCollectedSuccessfully( } var activityProcessor = new Mock>(); + Sdk.SetDefaultTextMapPropagator(propagator.Object); using (openTelemetry = Sdk.CreateTracerProviderBuilder() .AddAspNetInstrumentation( (options) => @@ -163,11 +164,6 @@ public void AspNetRequestsAreCollectedSuccessfully( return httpContext.Request.Path != filter; }; - if (!carrierFormat.Equals("TraceContext")) - { - options.Propagator = propagator.Object; - } - options.Enrich = ActivityEnrichment; }) .SetResource(expectedResource) diff --git a/test/OpenTelemetry.Instrumentation.AspNetCore.Tests/BasicTests.cs b/test/OpenTelemetry.Instrumentation.AspNetCore.Tests/BasicTests.cs index b343af26f1..77ffb9f227 100644 --- a/test/OpenTelemetry.Instrumentation.AspNetCore.Tests/BasicTests.cs +++ b/test/OpenTelemetry.Instrumentation.AspNetCore.Tests/BasicTests.cs @@ -58,21 +58,6 @@ public void AddAspNetCoreInstrumentation_BadArgs() Assert.Throws(() => builder.AddAspNetCoreInstrumentation()); } - [Fact] - public void DefaultPropagatorIsFromPropagators() - { - var options = new AspNetCoreInstrumentationOptions(); - Assert.Same(Propagators.DefaultTextMapPropagator, options.Propagator); - } - - [Fact] - public void PropagatorSetDoesNotAffectGlobalPropagators() - { - var options = new AspNetCoreInstrumentationOptions(); - options.Propagator = new TraceContextPropagator(); - Assert.NotSame(Propagators.DefaultTextMapPropagator, options.Propagator); - } - [Fact] public async Task StatusIsUnsetOn200Response() { @@ -225,8 +210,9 @@ public async Task CustomPropagator() .WithWebHostBuilder(builder => builder.ConfigureTestServices(services => { + Sdk.SetDefaultTextMapPropagator(propagator.Object); this.openTelemetrySdk = Sdk.CreateTracerProviderBuilder() - .AddAspNetCoreInstrumentation((opt) => opt.Propagator = propagator.Object) + .AddAspNetCoreInstrumentation() .AddProcessor(activityProcessor.Object) .Build(); }))) @@ -250,6 +236,11 @@ public async Task CustomPropagator() Assert.Equal(expectedTraceId, activity.Context.TraceId); Assert.Equal(expectedSpanId, activity.ParentSpanId); + Sdk.SetDefaultTextMapPropagator(new CompositeTextMapPropagator(new TextMapPropagator[] + { + new TraceContextPropagator(), + new BaggagePropagator(), + })); } [Fact] diff --git a/test/OpenTelemetry.Instrumentation.Http.Tests/HttpClientTests.Basic.netcore31.cs b/test/OpenTelemetry.Instrumentation.Http.Tests/HttpClientTests.Basic.netcore31.cs index de76619afe..b0a5f284e9 100644 --- a/test/OpenTelemetry.Instrumentation.Http.Tests/HttpClientTests.Basic.netcore31.cs +++ b/test/OpenTelemetry.Instrumentation.Http.Tests/HttpClientTests.Basic.netcore31.cs @@ -74,9 +74,6 @@ public async Task HttpClientInstrumentationInjectsHeadersAsync(bool shouldEnrich parent.TraceStateString = "k1=v1,k2=v2"; parent.ActivityTraceFlags = ActivityTraceFlags.Recorded; - // Ensure that the header value func does not throw if the header key can't be found - var mockPropagator = new Mock(); - // var isInjectedHeaderValueGetterThrows = false; // mockTextFormat // .Setup(x => x.IsInjected(It.IsAny(), It.IsAny>>())) @@ -97,7 +94,6 @@ public async Task HttpClientInstrumentationInjectsHeadersAsync(bool shouldEnrich using (Sdk.CreateTracerProviderBuilder() .AddHttpClientInstrumentation(o => { - o.Propagator = mockPropagator.Object; if (shouldEnrich) { o.Enrich = ActivityEnrichment; @@ -155,10 +151,11 @@ public async Task HttpClientInstrumentationInjectsHeadersAsync_CustomFormat(bool parent.TraceStateString = "k1=v1,k2=v2"; parent.ActivityTraceFlags = ActivityTraceFlags.Recorded; + Sdk.SetDefaultTextMapPropagator(propagator.Object); + using (Sdk.CreateTracerProviderBuilder() .AddHttpClientInstrumentation((opt) => { - opt.Propagator = propagator.Object; if (shouldEnrich) { opt.Enrich = ActivityEnrichment; @@ -187,6 +184,11 @@ public async Task HttpClientInstrumentationInjectsHeadersAsync_CustomFormat(bool Assert.Equal($"00/{activity.Context.TraceId}/{activity.Context.SpanId}/01", traceparents.Single()); Assert.Equal("k1=v1,k2=v2", tracestates.Single()); + Sdk.SetDefaultTextMapPropagator(new CompositeTextMapPropagator(new TextMapPropagator[] + { + new TraceContextPropagator(), + new BaggagePropagator(), + })); } [Fact] diff --git a/test/OpenTelemetry.Instrumentation.Http.Tests/HttpWebRequestTests.Basic.netfx.cs b/test/OpenTelemetry.Instrumentation.Http.Tests/HttpWebRequestTests.Basic.netfx.cs index 3e14632d67..f1bfcfbd17 100644 --- a/test/OpenTelemetry.Instrumentation.Http.Tests/HttpWebRequestTests.Basic.netfx.cs +++ b/test/OpenTelemetry.Instrumentation.Http.Tests/HttpWebRequestTests.Basic.netfx.cs @@ -107,10 +107,10 @@ public async Task HttpWebRequestInstrumentationInjectsHeadersAsyncWhenActivityIs contentFromPropagator = context.ActivityContext; }); - // Sdk.SetDefaultTextMapPropagator(propagator.Object); + Sdk.SetDefaultTextMapPropagator(propagator.Object); using var shutdownSignal = Sdk.CreateTracerProviderBuilder() .AddProcessor(activityProcessor.Object) - .AddHttpWebRequestInstrumentation(options => options.Propagator = propagator.Object) + .AddHttpWebRequestInstrumentation() .Build(); var request = (HttpWebRequest)WebRequest.Create(this.url); @@ -135,6 +135,11 @@ public async Task HttpWebRequestInstrumentationInjectsHeadersAsyncWhenActivityIs Assert.NotEqual(default, contentFromPropagator.SpanId); parent.Stop(); + Sdk.SetDefaultTextMapPropagator(new CompositeTextMapPropagator(new TextMapPropagator[] + { + new TraceContextPropagator(), + new BaggagePropagator(), + })); } [Fact] @@ -149,9 +154,10 @@ public async Task HttpWebRequestInstrumentationInjectsHeadersAsync_CustomFormat( }); var activityProcessor = new Mock>(); + Sdk.SetDefaultTextMapPropagator(propagator.Object); using var shutdownSignal = Sdk.CreateTracerProviderBuilder() .AddProcessor(activityProcessor.Object) - .AddHttpWebRequestInstrumentation(options => options.Propagator = propagator.Object) + .AddHttpWebRequestInstrumentation() .Build(); var request = (HttpWebRequest)WebRequest.Create(this.url); @@ -182,6 +188,11 @@ public async Task HttpWebRequestInstrumentationInjectsHeadersAsync_CustomFormat( Assert.Equal("k1=v1,k2=v2", tracestate); parent.Stop(); + Sdk.SetDefaultTextMapPropagator(new CompositeTextMapPropagator(new TextMapPropagator[] + { + new TraceContextPropagator(), + new BaggagePropagator(), + })); } [Fact]