mirror of
https://github.com/GeWuYou/GFramework.git
synced 2026-03-23 03:04:29 +08:00
- 将所有小写的命名空间导入更正为首字母大写格式 - 统一 GFramework 框架的命名空间引用规范 - 修复 core、ecs、godot 等模块的命名空间导入错误 - 标准化文档示例代码中的 using 语句格式 - 确保所有文档中的命名空间引用保持一致性 - 更新 global using 语句以匹配正确的命名空间格式
109 lines
3.2 KiB
C#
109 lines
3.2 KiB
C#
using System.IO;
|
|
using GFramework.Core.Abstractions.Logging;
|
|
using GFramework.Core.Logging.Appenders;
|
|
using GFramework.Core.Logging.Filters;
|
|
using GFramework.Core.Logging.Formatters;
|
|
using NUnit.Framework;
|
|
|
|
namespace GFramework.Core.Tests.Logging;
|
|
|
|
/// <summary>
|
|
/// 测试 ConsoleAppender 的功能和行为
|
|
/// </summary>
|
|
[TestFixture]
|
|
public class ConsoleAppenderTests
|
|
{
|
|
[SetUp]
|
|
public void SetUp()
|
|
{
|
|
_stringWriter = new StringWriter();
|
|
_appender = new ConsoleAppender(new DefaultLogFormatter(), _stringWriter, useColors: false);
|
|
}
|
|
|
|
[TearDown]
|
|
public void TearDown()
|
|
{
|
|
_appender?.Dispose();
|
|
_stringWriter?.Dispose();
|
|
}
|
|
|
|
private StringWriter _stringWriter = null!;
|
|
private ConsoleAppender _appender = null!;
|
|
|
|
[Test]
|
|
public void Constructor_WithNullFormatter_ShouldThrowArgumentNullException()
|
|
{
|
|
Assert.Throws<ArgumentNullException>(() => new ConsoleAppender(null!));
|
|
}
|
|
|
|
[Test]
|
|
public void Append_ShouldWriteToWriter()
|
|
{
|
|
var entry = new LogEntry(DateTime.UtcNow, LogLevel.Info, "TestLogger", "Test message", null, null);
|
|
|
|
_appender.Append(entry);
|
|
|
|
var output = _stringWriter.ToString();
|
|
Assert.That(output, Does.Contain("Test message"));
|
|
Assert.That(output, Does.Contain("INFO"));
|
|
}
|
|
|
|
[Test]
|
|
public void Append_WithFilter_ShouldRespectFilter()
|
|
{
|
|
var filter = new LogLevelFilter(LogLevel.Warning);
|
|
var appender = new ConsoleAppender(new DefaultLogFormatter(), _stringWriter, useColors: false, filter: filter);
|
|
|
|
var infoEntry = new LogEntry(DateTime.UtcNow, LogLevel.Info, "TestLogger", "Info message", null, null);
|
|
var warningEntry = new LogEntry(DateTime.UtcNow, LogLevel.Warning, "TestLogger", "Warning message", null, null);
|
|
|
|
appender.Append(infoEntry);
|
|
appender.Append(warningEntry);
|
|
|
|
var output = _stringWriter.ToString();
|
|
Assert.That(output, Does.Not.Contain("Info message"));
|
|
Assert.That(output, Does.Contain("Warning message"));
|
|
|
|
appender.Dispose();
|
|
}
|
|
|
|
[Test]
|
|
public void Flush_ShouldFlushWriter()
|
|
{
|
|
var entry = new LogEntry(DateTime.UtcNow, LogLevel.Info, "TestLogger", "Test message", null, null);
|
|
|
|
_appender.Append(entry);
|
|
_appender.Flush();
|
|
|
|
var output = _stringWriter.ToString();
|
|
Assert.That(output, Does.Contain("Test message"));
|
|
}
|
|
|
|
[Test]
|
|
public void Dispose_ShouldFlushWriter()
|
|
{
|
|
var entry = new LogEntry(DateTime.UtcNow, LogLevel.Info, "TestLogger", "Test message", null, null);
|
|
|
|
_appender.Append(entry);
|
|
_appender.Dispose();
|
|
|
|
var output = _stringWriter.ToString();
|
|
Assert.That(output, Does.Contain("Test message"));
|
|
}
|
|
|
|
[Test]
|
|
public void Append_MultipleEntries_ShouldWriteAll()
|
|
{
|
|
for (int i = 0; i < 10; i++)
|
|
{
|
|
var entry = new LogEntry(DateTime.UtcNow, LogLevel.Info, "TestLogger", $"Message {i}", null, null);
|
|
_appender.Append(entry);
|
|
}
|
|
|
|
var output = _stringWriter.ToString();
|
|
for (int i = 0; i < 10; i++)
|
|
{
|
|
Assert.That(output, Does.Contain($"Message {i}"));
|
|
}
|
|
}
|
|
} |