-
Notifications
You must be signed in to change notification settings - Fork 10
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Fix issue where AppInsights SDK doesn't load/configure correctly due …
…to keyed services being registered in DI (#594)
- Loading branch information
1 parent
e261880
commit dc62cf8
Showing
9 changed files
with
165 additions
and
18 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,94 @@ | ||
|
||
using Microsoft.Extensions.DependencyInjection; | ||
using Xunit; | ||
using Microsoft.AspNetCore.Hosting; | ||
using Microsoft.Extensions.FileProviders; | ||
using Microsoft.Extensions.Configuration; | ||
using Microsoft.ApplicationInsights.Extensibility; | ||
using Microsoft.ApplicationInsights; | ||
using System.Diagnostics.Tracing; | ||
|
||
namespace Altinn.App.Api.Tests; | ||
|
||
public class DITests | ||
{ | ||
private sealed record FakeWebHostEnvironment : IWebHostEnvironment, IHostingEnvironment | ||
{ | ||
private string _env = ""; | ||
|
||
public string WebRootPath { get => new DirectoryInfo("./").FullName; set => throw new NotImplementedException(); } | ||
public IFileProvider WebRootFileProvider { get => throw new NotImplementedException(); set => throw new NotImplementedException(); } | ||
public string ApplicationName { get => "test"; set => throw new NotImplementedException(); } | ||
public IFileProvider ContentRootFileProvider { get => throw new NotImplementedException(); set => throw new NotImplementedException(); } | ||
public string ContentRootPath { get => new DirectoryInfo("./").FullName; set => throw new NotImplementedException(); } | ||
public string EnvironmentName { get => _env; set => _env = value; } | ||
} | ||
|
||
private sealed class AppInsightsListener : EventListener | ||
{ | ||
private readonly List<EventSource> _eventSources = []; | ||
public readonly List<EventWrittenEventArgs> Events = []; | ||
|
||
protected override void OnEventSourceCreated(EventSource eventSource) | ||
{ | ||
|
||
if (eventSource.Name == "Microsoft-ApplicationInsights-AspNetCore") | ||
{ | ||
_eventSources.Add(eventSource); | ||
EnableEvents(eventSource, EventLevel.Verbose, EventKeywords.All); | ||
} | ||
|
||
base.OnEventSourceCreated(eventSource); | ||
} | ||
|
||
protected override void OnEventWritten(EventWrittenEventArgs eventData) | ||
{ | ||
if (eventData.EventSource.Name != "Microsoft-ApplicationInsights-AspNetCore") | ||
{ | ||
return; | ||
} | ||
|
||
Events.Add(eventData); | ||
base.OnEventWritten(eventData); | ||
} | ||
|
||
public override void Dispose() | ||
{ | ||
foreach (var eventSource in _eventSources) | ||
{ | ||
DisableEvents(eventSource); | ||
} | ||
base.Dispose(); | ||
} | ||
} | ||
|
||
[Fact] | ||
public void AppInsights_Registers_Correctly() | ||
{ | ||
using var listener = new AppInsightsListener(); | ||
|
||
var services = new ServiceCollection(); | ||
var env = new FakeWebHostEnvironment { EnvironmentName = "Development" }; | ||
|
||
services.AddSingleton<IWebHostEnvironment>(env); | ||
services.AddSingleton<IHostingEnvironment>(env); | ||
|
||
var config = new ConfigurationBuilder() | ||
.AddInMemoryCollection([ | ||
new KeyValuePair<string, string?>("ApplicationInsights:InstrumentationKey", "test") | ||
]).Build(); | ||
|
||
Extensions.ServiceCollectionExtensions.AddAltinnAppServices(services, config, env); | ||
|
||
using var sp = services.BuildServiceProvider(); | ||
|
||
var telemetryConfig = sp.GetRequiredService<TelemetryConfiguration>(); | ||
Assert.NotNull(telemetryConfig); | ||
|
||
var client = sp.GetRequiredService<TelemetryClient>(); | ||
Assert.NotNull(client); | ||
|
||
EventLevel[] errorLevels = [EventLevel.Error, EventLevel.Critical]; | ||
Assert.Empty(listener.Events.Where(e => errorLevels.Contains(e.Level))); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters