-
Notifications
You must be signed in to change notification settings - Fork 854
[Hosting] Throw startup exceptions #4006
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Changes from 3 commits
2da04dd
5e701ae
63f0a83
492113d
da40193
6c1b075
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
| Original file line number | Diff line number | Diff line change |
|---|---|---|
|
|
@@ -15,7 +15,6 @@ | |
| // </copyright> | ||
|
|
||
| using System.Diagnostics.Tracing; | ||
| using OpenTelemetry.Internal; | ||
|
|
||
| namespace OpenTelemetry.Extensions.Hosting.Implementation | ||
| { | ||
|
|
@@ -27,34 +26,10 @@ internal sealed class HostingExtensionsEventSource : EventSource | |
| { | ||
| public static HostingExtensionsEventSource Log = new(); | ||
|
|
||
| [NonEvent] | ||
| public void FailedInitialize(Exception ex) | ||
| [Event(1, Message = "OpenTelemetry TraverProvider and/or MeterProvider were not found in application services. SDK will remain disabled.", Level = EventLevel.Warning)] | ||
| public void SdkNotRegistered() | ||
|
||
| { | ||
| if (this.IsEnabled(EventLevel.Error, EventKeywords.All)) | ||
| { | ||
| this.FailedInitialize(ex.ToInvariantString()); | ||
| } | ||
| } | ||
|
|
||
| [NonEvent] | ||
| public void FailedOpenTelemetrySDK(Exception ex) | ||
| { | ||
| if (this.IsEnabled(EventLevel.Error, EventKeywords.All)) | ||
| { | ||
| this.FailedOpenTelemetrySDK(ex.ToInvariantString()); | ||
| } | ||
| } | ||
|
|
||
| [Event(1, Message = "An exception occurred while initializing OpenTelemetry Tracing. OpenTelemetry tracing will remain disabled. Exception: '{0}'.", Level = EventLevel.Error)] | ||
| public void FailedInitialize(string exception) | ||
| { | ||
| this.WriteEvent(1, exception); | ||
| } | ||
|
|
||
| [Event(2, Message = "An exception occurred while retrieving OpenTelemetry Tracer. OpenTelemetry tracing will remain disabled. Exception: '{0}'.", Level = EventLevel.Error)] | ||
| public void FailedOpenTelemetrySDK(string exception) | ||
| { | ||
| this.WriteEvent(2, exception); | ||
| this.WriteEvent(1); | ||
| } | ||
| } | ||
| } | ||
| Original file line number | Diff line number | Diff line change |
|---|---|---|
|
|
@@ -33,16 +33,9 @@ public TelemetryHostedService(IServiceProvider serviceProvider) | |
|
|
||
| public Task StartAsync(CancellationToken cancellationToken) | ||
| { | ||
| try | ||
| { | ||
| // The sole purpose of this HostedService is to ensure all | ||
| // instrumentations, exporters, etc., are created and started. | ||
| Initialize(this.serviceProvider); | ||
| } | ||
| catch (Exception ex) | ||
| { | ||
| HostingExtensionsEventSource.Log.FailedOpenTelemetrySDK(ex); | ||
| } | ||
| // The sole purpose of this HostedService is to ensure all | ||
| // instrumentations, exporters, etc., are created and started. | ||
| Initialize(this.serviceProvider); | ||
|
Member
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. nit: add a comment saying intentionally not catching ex, to let it bubble up. |
||
|
|
||
| return Task.CompletedTask; | ||
| } | ||
|
|
@@ -61,7 +54,7 @@ internal static void Initialize(IServiceProvider serviceProvider) | |
|
|
||
| if (meterProvider == null && tracerProvider == null) | ||
| { | ||
| throw new InvalidOperationException("Could not resolve either MeterProvider or TracerProvider through application ServiceProvider, OpenTelemetry SDK has not been initialized."); | ||
| HostingExtensionsEventSource.Log.SdkNotRegistered(); | ||
| } | ||
| } | ||
| } | ||
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,84 @@ | ||
| // <copyright file="HostingMeterExtensionTests.cs" company="OpenTelemetry Authors"> | ||
| // Copyright The OpenTelemetry Authors | ||
| // | ||
| // Licensed under the Apache License, Version 2.0 (the "License"); | ||
| // you may not use this file except in compliance with the License. | ||
| // You may obtain a copy of the License at | ||
| // | ||
| // http://www.apache.org/licenses/LICENSE-2.0 | ||
| // | ||
| // Unless required by applicable law or agreed to in writing, software | ||
| // distributed under the License is distributed on an "AS IS" BASIS, | ||
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
| // See the License for the specific language governing permissions and | ||
| // limitations under the License. | ||
| // </copyright> | ||
|
|
||
| using Microsoft.Extensions.Hosting; | ||
| using OpenTelemetry.Trace; | ||
| using Xunit; | ||
|
|
||
| namespace OpenTelemetry.Extensions.Hosting.Tests; | ||
|
|
||
| public class TelemetryHostedServiceTests | ||
| { | ||
| [Fact] | ||
| public async Task StartWithoutProvidersDoesNotThrow() | ||
| { | ||
| var builder = new HostBuilder().ConfigureServices(services => | ||
| { | ||
| services.AddOpenTelemetry() | ||
| .StartWithHost(); | ||
| }); | ||
|
|
||
| var host = builder.Build(); | ||
|
|
||
| await host.StartAsync().ConfigureAwait(false); | ||
|
|
||
| await host.StopAsync().ConfigureAwait(false); | ||
| } | ||
|
|
||
| [Fact] | ||
| public async Task StartWithExceptionsThrows() | ||
| { | ||
| bool expectedInnerExceptionThrown = false; | ||
|
|
||
| var builder = new HostBuilder().ConfigureServices(services => | ||
| { | ||
| services.AddOpenTelemetry() | ||
| .WithTracing(builder => | ||
| { | ||
| builder.ConfigureBuilder((sp, sdkBuilder) => | ||
| { | ||
| try | ||
| { | ||
| // Note: This throws because services cannot be | ||
| // registered after IServiceProvider has been | ||
| // created. | ||
| sdkBuilder.SetSampler<MySampler>(); | ||
| } | ||
| catch (NotSupportedException) | ||
| { | ||
| expectedInnerExceptionThrown = true; | ||
| throw; | ||
| } | ||
| }); | ||
| }) | ||
| .StartWithHost(); | ||
| }); | ||
|
|
||
| var host = builder.Build(); | ||
|
|
||
| await Assert.ThrowsAsync<NotSupportedException>(() => host.StartAsync()).ConfigureAwait(false); | ||
|
|
||
| await host.StopAsync().ConfigureAwait(false); | ||
|
|
||
| Assert.True(expectedInnerExceptionThrown); | ||
| } | ||
|
|
||
| private sealed class MySampler : Sampler | ||
| { | ||
| public override SamplingResult ShouldSample(in SamplingParameters samplingParameters) | ||
| => new SamplingResult(SamplingDecision.RecordAndSample); | ||
| } | ||
| } |
Uh oh!
There was an error while loading. Please reload this page.