mirror of
https://github.com/space-wizards/RobustToolbox.git
synced 2026-02-15 03:30:53 +01:00
47 lines
1.1 KiB
C#
47 lines
1.1 KiB
C#
using Robust.Shared.Interfaces.Log;
|
|
using System;
|
|
using System.Collections.Generic;
|
|
using System.Diagnostics;
|
|
using System.IO;
|
|
using System.Text;
|
|
using NUnit.Framework;
|
|
using Robust.Shared.Log;
|
|
using Robust.Shared.Utility;
|
|
using Serilog.Events;
|
|
|
|
namespace Robust.UnitTesting
|
|
{
|
|
|
|
public sealed class TestLogHandler : ILogHandler, IDisposable
|
|
{
|
|
|
|
private readonly string _prefix;
|
|
|
|
private readonly TextWriter _writer;
|
|
|
|
private readonly Stopwatch _sw = Stopwatch.StartNew();
|
|
|
|
public TestLogHandler(string prefix)
|
|
{
|
|
_prefix = prefix;
|
|
_writer = TestContext.Out;
|
|
_writer.WriteLine($"{_prefix}: Started {DateTime.Now:o}");
|
|
}
|
|
|
|
public void Dispose()
|
|
{
|
|
_writer.Dispose();
|
|
}
|
|
|
|
public void Log(string sawmillName, LogEvent message)
|
|
{
|
|
var name = LogMessage.LogLevelToName(message.Level.ToRobust());
|
|
var seconds = _sw.ElapsedMilliseconds/1000d;
|
|
var rendered = message.RenderMessage();
|
|
_writer.WriteLine($"{_prefix}: {seconds:F3}s [{name}] {sawmillName}: {rendered}");
|
|
}
|
|
|
|
}
|
|
|
|
}
|