2
0
mirror of synced 2025-01-14 02:24:28 +00:00

64 lines
2.3 KiB
C#
Raw Normal View History

2023-09-13 16:06:05 +02:00
using Logging;
using Newtonsoft.Json;
using System.Globalization;
2023-09-13 16:06:05 +02:00
2023-09-20 10:51:47 +02:00
namespace DistTestCore.Logs
2023-09-13 16:06:05 +02:00
{
public class StatusLog
{
private readonly object fileLock = new();
private readonly string deployId;
2023-09-13 16:06:05 +02:00
private readonly string fullName;
private readonly string fixtureName;
2023-11-10 15:28:53 +01:00
private readonly string testType;
2023-09-13 16:06:05 +02:00
public StatusLog(LogConfig config, DateTime start, string testType, string deployId, string name = "")
2023-09-13 16:06:05 +02:00
{
fullName = NameUtils.GetFixtureFullName(config, start, name) + "_STATUS.log";
fixtureName = NameUtils.GetRawFixtureName();
2023-11-10 15:28:53 +01:00
this.testType = testType;
this.deployId = deployId;
2023-09-13 16:06:05 +02:00
}
public void ConcludeTest(DistTestResult resultStatus, TimeSpan testDuration, Dictionary<string, string> data)
{
ConcludeTest(resultStatus.Status, testDuration.TotalSeconds.ToString(CultureInfo.InvariantCulture), data);
}
2024-07-26 10:14:54 +02:00
public void ConcludeTest(string result, TimeSpan testDuration, Dictionary<string, string> data)
{
ConcludeTest(result, testDuration.TotalSeconds.ToString(CultureInfo.InvariantCulture), data);
}
2023-09-13 16:06:05 +02:00
public void ConcludeTest(string resultStatus, string testDuration, Dictionary<string, string> data)
{
data.Add("timestamp", DateTime.UtcNow.ToString("o"));
data.Add("deployid", deployId);
2023-09-13 16:06:05 +02:00
data.Add("status", resultStatus);
data.Add("category", NameUtils.GetCategoryName());
data.Add("fixturename", fixtureName);
if (!data.ContainsKey("testname")) data.Add("testname", NameUtils.GetTestMethodName());
2023-11-10 15:28:53 +01:00
data.Add("testid", NameUtils.GetTestId());
data.Add("testtype", testType);
2023-09-13 16:06:05 +02:00
data.Add("testduration", testDuration);
data.Add("testframeworkrevision", GitInfo.GetStatus());
2023-09-13 16:06:05 +02:00
Write(data);
}
private void Write(Dictionary<string, string> data)
{
try
{
lock (fileLock)
{
File.AppendAllLines(fullName, new[] { JsonConvert.SerializeObject(data) });
}
}
catch (Exception ex)
{
Console.WriteLine("Unable to write to status log: " + ex);
}
}
}
}