using NUnit.Framework; namespace Logging { public class FixtureLog : BaseLog { private readonly DateTime start; private readonly string fullName; private readonly LogConfig config; public FixtureLog(LogConfig config, string name = "") : base(config.DebugEnabled) { start = DateTime.UtcNow; var folder = DetermineFolder(config); var fixtureName = GetFixtureName(name); fullName = Path.Combine(folder, fixtureName); this.config = config; } public TestLog CreateTestLog(string name = "") { return new TestLog(fullName, config.DebugEnabled, name); } public void DeleteFolder() { Directory.Delete(fullName, true); } protected override string GetFullName() { return fullName; } private string DetermineFolder(LogConfig config) { return Path.Join( config.LogRoot, $"{start.Year}-{Pad(start.Month)}", Pad(start.Day)); } private string GetFixtureName(string name) { var test = TestContext.CurrentContext.Test; var className = test.ClassName!.Substring(test.ClassName.LastIndexOf('.') + 1); if (!string.IsNullOrEmpty(name)) className = name; return $"{Pad(start.Hour)}-{Pad(start.Minute)}-{Pad(start.Second)}Z_{className.Replace('.', '-')}"; } private static string Pad(int n) { return n.ToString().PadLeft(2, '0'); } } }