39 lines
1.2 KiB
C#
39 lines
1.2 KiB
C#
using Microsoft.Extensions.Logging;
|
||
using Xunit.Abstractions;
|
||
|
||
namespace TestProject1.XUnit.Logging;
|
||
|
||
/// <summary>
|
||
/// 适用于Xunit的日志记录器,使用ITestOutputHelper输出
|
||
/// </summary>
|
||
public class XunitLogger : ILogger
|
||
{
|
||
private readonly ITestOutputHelper _testOutputHelper;
|
||
private readonly string _categoryName;
|
||
|
||
public XunitLogger(ITestOutputHelper testOutputHelper, string categoryName)
|
||
{
|
||
_testOutputHelper = testOutputHelper;
|
||
_categoryName = categoryName;
|
||
}
|
||
|
||
public IDisposable? BeginScope<TState>(TState state) where TState : notnull
|
||
=> NoopDisposable.Instance;
|
||
|
||
public bool IsEnabled(LogLevel logLevel)
|
||
=> true;
|
||
|
||
public void Log<TState>(LogLevel logLevel, EventId eventId, TState state, Exception? exception,
|
||
Func<TState, Exception?, string> formatter)
|
||
{
|
||
_testOutputHelper.WriteLine($"{_categoryName} [{eventId}] {formatter(state, exception)}");
|
||
if (exception != null)
|
||
_testOutputHelper.WriteLine(exception.ToString());
|
||
}
|
||
|
||
private class NoopDisposable : IDisposable
|
||
{
|
||
public static readonly NoopDisposable Instance = new();
|
||
public void Dispose() { }
|
||
}
|
||
} |