-
Notifications
You must be signed in to change notification settings - Fork 879
Expand file tree
/
Copy pathLoggerProviderTests.cs
More file actions
86 lines (66 loc) · 2.16 KB
/
LoggerProviderTests.cs
File metadata and controls
86 lines (66 loc) · 2.16 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
// Copyright The OpenTelemetry Authors
// SPDX-License-Identifier: Apache-2.0
using System.Diagnostics.CodeAnalysis;
using Xunit;
namespace OpenTelemetry.Logs.Tests;
public sealed class LoggerProviderTests
{
[Fact]
public void NoopLoggerReturnedTest()
{
using var provider = new NoopLoggerProvider();
var logger = provider.GetLogger(name: "TestLogger", version: "Version");
Assert.NotNull(logger);
Assert.Equal(typeof(NoopLogger), logger.GetType());
Assert.Equal(string.Empty, logger.Name);
Assert.Null(logger.Version);
}
[Fact]
public void LoggerReturnedWithInstrumentationScopeTest()
{
using var provider = new TestLoggerProvider();
var logger = provider.GetLogger(name: "TestLogger", version: "Version");
Assert.NotNull(logger);
Assert.Equal(typeof(TestLogger), logger.GetType());
Assert.Equal("TestLogger", logger.Name);
Assert.Equal("Version", logger.Version);
logger = provider.GetLogger(name: "TestLogger");
Assert.NotNull(logger);
Assert.Equal(typeof(TestLogger), logger.GetType());
Assert.Equal("TestLogger", logger.Name);
Assert.Null(logger.Version);
logger = provider.GetLogger();
Assert.NotNull(logger);
Assert.Equal(typeof(TestLogger), logger.GetType());
Assert.Equal(string.Empty, logger.Name);
Assert.Null(logger.Version);
}
private sealed class NoopLoggerProvider : LoggerProvider
{
}
private sealed class TestLoggerProvider : LoggerProvider
{
#if OPENTELEMETRY_API_EXPERIMENTAL_FEATURES_EXPOSED
protected override bool TryCreateLogger(
#else
internal override bool TryCreateLogger(
#endif
string? name,
[NotNullWhen(true)]
out Logger? logger)
{
logger = new TestLogger(name);
return true;
}
}
private sealed class TestLogger : Logger
{
public TestLogger(string? name)
: base(name)
{
}
public override void EmitLog(in LogRecordData data, in LogRecordAttributeList attributes)
{
}
}
}