mirror of
https://github.com/GeWuYou/GFramework.git
synced 2026-03-22 19:03:29 +08:00
- 为 AsyncLogAppender 添加完整功能测试,包括异步写入、缓冲区管理、并发处理等场景 - 为 CachedLoggerFactory 添加缓存机制测试,验证相同名称和级别的日志记录器重用 - 为 CompositeFilter 添加过滤器组合测试,验证多个过滤器的逻辑组合功能 - 为 CompositeLogger 添加复合日志记录器测试,验证多追加器写入和级别过滤功能 - 为 ConsoleAppender 添加控制台追加器测试,验证格式化输出和过滤器支持 - 为 DefaultLogFormatter 添加默认格式化器测试,验证基本格式化和异常处理功能 - 为 FileAppender 添加文件追加器测试,验证文件写入、目录创建和追加模式功能 - 为 JsonLogFormatter 添加 JSON 格式化器测试,验证 JSON 输出和属性序列化功能 - 为 LogContext 添加日志上下文测试,验证属性推送和作用域管理功能
95 lines
3.1 KiB
C#
95 lines
3.1 KiB
C#
using System.IO;
|
|
using GFramework.Core.Abstractions.logging;
|
|
using GFramework.Core.logging;
|
|
using NUnit.Framework;
|
|
|
|
namespace GFramework.Core.Tests.logging;
|
|
|
|
/// <summary>
|
|
/// 测试 CachedLoggerFactory 的功能和行为
|
|
/// </summary>
|
|
[TestFixture]
|
|
public class CachedLoggerFactoryTests
|
|
{
|
|
[Test]
|
|
public void Constructor_WithNullInnerFactory_ShouldThrowArgumentNullException()
|
|
{
|
|
Assert.Throws<ArgumentNullException>(() => new CachedLoggerFactory(null!));
|
|
}
|
|
|
|
[Test]
|
|
public void GetLogger_WithSameNameAndLevel_ShouldReturnSameInstance()
|
|
{
|
|
var innerFactory = new ConsoleLoggerFactory();
|
|
var cachedFactory = new CachedLoggerFactory(innerFactory);
|
|
|
|
var logger1 = cachedFactory.GetLogger("TestLogger", LogLevel.Info);
|
|
var logger2 = cachedFactory.GetLogger("TestLogger", LogLevel.Info);
|
|
|
|
Assert.That(logger1, Is.SameAs(logger2));
|
|
}
|
|
|
|
[Test]
|
|
public void GetLogger_WithDifferentNames_ShouldReturnDifferentInstances()
|
|
{
|
|
var innerFactory = new ConsoleLoggerFactory();
|
|
var cachedFactory = new CachedLoggerFactory(innerFactory);
|
|
|
|
var logger1 = cachedFactory.GetLogger("Logger1", LogLevel.Info);
|
|
var logger2 = cachedFactory.GetLogger("Logger2", LogLevel.Info);
|
|
|
|
Assert.That(logger1, Is.Not.SameAs(logger2));
|
|
}
|
|
|
|
[Test]
|
|
public void GetLogger_WithDifferentLevels_ShouldReturnDifferentInstances()
|
|
{
|
|
var innerFactory = new ConsoleLoggerFactory();
|
|
var cachedFactory = new CachedLoggerFactory(innerFactory);
|
|
|
|
var logger1 = cachedFactory.GetLogger("TestLogger", LogLevel.Info);
|
|
var logger2 = cachedFactory.GetLogger("TestLogger", LogLevel.Debug);
|
|
|
|
Assert.That(logger1, Is.Not.SameAs(logger2));
|
|
}
|
|
|
|
[Test]
|
|
public void GetLogger_MultipleCalls_ShouldOnlyCreateOnce()
|
|
{
|
|
var trackingFactory = new TrackingLoggerFactory();
|
|
var cachedFactory = new CachedLoggerFactory(trackingFactory);
|
|
|
|
cachedFactory.GetLogger("TestLogger", LogLevel.Info);
|
|
cachedFactory.GetLogger("TestLogger", LogLevel.Info);
|
|
cachedFactory.GetLogger("TestLogger", LogLevel.Info);
|
|
|
|
Assert.That(trackingFactory.CreateCount, Is.EqualTo(1));
|
|
}
|
|
|
|
[Test]
|
|
public void GetLogger_WithMultipleNamesAndLevels_ShouldCacheCorrectly()
|
|
{
|
|
var trackingFactory = new TrackingLoggerFactory();
|
|
var cachedFactory = new CachedLoggerFactory(trackingFactory);
|
|
|
|
cachedFactory.GetLogger("Logger1", LogLevel.Info);
|
|
cachedFactory.GetLogger("Logger1", LogLevel.Debug);
|
|
cachedFactory.GetLogger("Logger2", LogLevel.Info);
|
|
cachedFactory.GetLogger("Logger1", LogLevel.Info); // 缓存命中
|
|
cachedFactory.GetLogger("Logger2", LogLevel.Info); // 缓存命中
|
|
|
|
Assert.That(trackingFactory.CreateCount, Is.EqualTo(3));
|
|
}
|
|
|
|
// 辅助测试类
|
|
private class TrackingLoggerFactory : ILoggerFactory
|
|
{
|
|
public int CreateCount { get; private set; }
|
|
|
|
public ILogger GetLogger(string name, LogLevel minLevel = LogLevel.Info)
|
|
{
|
|
CreateCount++;
|
|
return new ConsoleLogger(name, minLevel, new StringWriter(), false);
|
|
}
|
|
}
|
|
} |