-
-
Notifications
You must be signed in to change notification settings - Fork 230
Expand file tree
/
Copy pathSentryAspNetCoreStructuredLoggerProviderTests.cs
More file actions
105 lines (82 loc) · 3.35 KB
/
SentryAspNetCoreStructuredLoggerProviderTests.cs
File metadata and controls
105 lines (82 loc) · 3.35 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
#nullable enable
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Logging;
using Microsoft.Extensions.Options;
namespace Sentry.AspNetCore.Tests;
public class SentryAspNetCoreStructuredLoggerProviderTests
{
private class Fixture
{
public IOptions<SentryAspNetCoreOptions> Options { get; }
public IHub Hub { get; }
public MockClock Clock { get; }
public SdkVersion Sdk { get; }
public Fixture()
{
var loggingOptions = new SentryAspNetCoreOptions();
loggingOptions.Experimental.EnableLogs = true;
Options = Microsoft.Extensions.Options.Options.Create(loggingOptions);
Hub = Substitute.For<IHub>();
Clock = new MockClock();
Sdk = new SdkVersion
{
Name = "SDK Name",
Version = "SDK Version",
};
Hub.IsEnabled.Returns(true);
}
public SentryAspNetCoreStructuredLoggerProvider GetSut()
{
return new SentryAspNetCoreStructuredLoggerProvider(Options.Value, Hub, Clock, Sdk);
}
}
private readonly Fixture _fixture = new();
[Fact]
public void Ctor_DependencyInjection_CanCreate()
{
using var services = new ServiceCollection()
.AddLogging()
.AddSingleton<ILoggerProvider, SentryAspNetCoreStructuredLoggerProvider>()
.AddSingleton(_fixture.Options)
.AddSingleton(_fixture.Hub)
.BuildServiceProvider();
var logger = services.GetRequiredService<ILogger<SentryAspNetCoreStructuredLoggerProviderTests>>();
logger.Should().BeOfType<Logger<SentryAspNetCoreStructuredLoggerProviderTests>>();
}
[Fact]
public void CreateLogger_OfType()
{
var provider = _fixture.GetSut();
var logger = provider.CreateLogger("CategoryName");
logger.Should().BeOfType<Sentry.Extensions.Logging.SentryStructuredLogger>();
}
[Fact]
public void CreateLogger_DependencyInjection_CanLog()
{
SentryLog? capturedLog = null;
_fixture.Hub.Logger.Returns(Substitute.For<SentryStructuredLogger>());
_fixture.Hub.Logger.CaptureLog(Arg.Do<SentryLog>(log => capturedLog = log));
using var services = new ServiceCollection()
.AddLogging()
.AddSingleton<ILoggerProvider, SentryAspNetCoreStructuredLoggerProvider>()
.AddSingleton(_fixture.Options)
.AddSingleton(_fixture.Hub)
.BuildServiceProvider();
var logger = services.GetRequiredService<ILogger<SentryAspNetCoreStructuredLoggerProviderTests>>();
logger.LogInformation("message");
Assert.NotNull(capturedLog);
capturedLog.TryGetAttribute("category.name", out object? categoryName).Should().BeTrue();
categoryName.Should().Be(typeof(SentryAspNetCoreStructuredLoggerProviderTests).FullName);
capturedLog.TryGetAttribute("sentry.sdk.name", out object? name).Should().BeTrue();
name.Should().Be(Constants.SdkName);
capturedLog.TryGetAttribute("sentry.sdk.version", out object? version).Should().BeTrue();
version.Should().Be(SentryMiddleware.NameAndVersion.Version);
}
[Fact]
public void Dispose_NoOp()
{
var provider = _fixture.GetSut();
provider.Dispose();
provider.Dispose();
}
}