AyCode.Core/AyCode.Core.Tests/TestModels/TestLogger.cs

57 lines
2.5 KiB
C#

using System.Runtime.CompilerServices;
using AyCode.Core.Enums;
using AyCode.Core.Loggers;
namespace AyCode.Core.Tests.TestModels;
/// <summary>
/// Test logger that captures log messages for assertions.
/// Does not require configuration or log writers.
/// </summary>
public class TestLogger : AcLoggerBase
{
public List<LogEntry> Logs { get; } = [];
public TestLogger() : base(AppType.Server, LogLevel.Detail, "TestLogger")
{
}
public override void Detail(string? text, string? categoryName = null, [CallerMemberName] string? memberName = null)
=> Logs.Add(new LogEntry(LogLevel.Detail, text, categoryName, memberName));
public override void Debug(string? text, string? categoryName = null, [CallerMemberName] string? memberName = null)
=> Logs.Add(new LogEntry(LogLevel.Debug, text, categoryName, memberName));
public override void Info(string? text, string? categoryName = null, [CallerMemberName] string? memberName = null)
=> Logs.Add(new LogEntry(LogLevel.Info, text, categoryName, memberName));
public override void Warning(string? text, string? categoryName = null, [CallerMemberName] string? memberName = null)
=> Logs.Add(new LogEntry(LogLevel.Warning, text, categoryName, memberName));
public override void Suggest(string? text, string? categoryName = null, [CallerMemberName] string? memberName = null)
=> Logs.Add(new LogEntry(LogLevel.Suggest, text, categoryName, memberName));
public override void Error(string? text, Exception? ex = null, string? categoryName = null, [CallerMemberName] string? memberName = null)
=> Logs.Add(new LogEntry(LogLevel.Error, text, categoryName, memberName, ex));
public void Clear() => Logs.Clear();
public bool HasErrorLogs => Logs.Any(l => l.Level == LogLevel.Error);
public bool HasWarningLogs => Logs.Any(l => l.Level == LogLevel.Warning);
public IEnumerable<LogEntry> ErrorLogs => Logs.Where(l => l.Level == LogLevel.Error);
public IEnumerable<LogEntry> WarningLogs => Logs.Where(l => l.Level == LogLevel.Warning);
public IEnumerable<string> GetErrorMessages() => ErrorLogs.Select(l => $"{l.Text} {l.Exception?.Message}");
public IEnumerable<string> GetAllMessages() => Logs.Select(l => l.ToString());
}
public record LogEntry(
LogLevel Level,
string? Text,
string? CategoryName = null,
string? MemberName = null,
Exception? Exception = null)
{
public override string ToString() => $"[{Level}] {Text}";
}