Skip to content

Commit

Permalink
Enhance logging in reporting registrar
Browse files Browse the repository at this point in the history
  • Loading branch information
SergeyBrenko committed May 6, 2021
1 parent c944fa8 commit a719216
Show file tree
Hide file tree
Showing 2 changed files with 27 additions and 18 deletions.
8 changes: 8 additions & 0 deletions Logging/ZebrunnerNLogTarget.cs
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
using System;
using NLog;
using NLog.Layouts;
using NLog.Targets;
using ZafiraIntegration.Client.Requests;
using ZafiraIntegration.Registrar;
Expand All @@ -9,8 +10,15 @@ namespace ZafiraIntegration.Logging
[Target("Zebrunner")]
public class ZebrunnerNLogTarget : TargetWithLayout
{
private static readonly Logger Logger = LogManager.GetCurrentClassLogger();

private readonly LogsBuffer _logsBuffer = LogsBuffer.Instance;

public ZebrunnerNLogTarget()
{
Logger.Debug($"{DateTime.UtcNow} Creating instance of NLog Target.");
}

protected override void Write(LogEventInfo logEvent)
{
var currentTest = RunContext.GetCurrentTest();
Expand Down
37 changes: 19 additions & 18 deletions Registrar/ReportingRegistrar.cs
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@
using System.Reflection;
using System.Runtime.CompilerServices;
using System.Text;
using System.Threading;
using NLog;
using NLog.Targets;
using NUnit.Framework;
Expand Down Expand Up @@ -42,7 +43,7 @@ public void RegisterTestRunStart(AttributeTargets attributeTarget)
{
if (RunContext.GetCurrentTestRun() == null)
{
Logger.Debug("Registering test run start...");
Logger.Debug($"{DateTime.UtcNow} [{Thread.CurrentThread.Name}] Registering test run start...");
var startTestRunRequest = new StartTestRunRequest
{
Name = GetSuiteName(attributeTarget),
Expand All @@ -58,7 +59,7 @@ public void RegisterTestRunStart(AttributeTargets attributeTarget)
var saveTestRunResponse = _apiClient.RegisterTestRunStart(startTestRunRequest);
RunContext.SetCurrentTestRun(saveTestRunResponse);

Logger.Debug("Test run start was registered successfuly.");
Logger.Debug($"{DateTime.UtcNow} [{Thread.CurrentThread.Name}] ({saveTestRunResponse.Id}) Test run start was registered successfuly with id.");
}
}

Expand All @@ -83,28 +84,28 @@ private static StartTestRunRequest.JenkinsContextDto GetJenkinsContext()

public void RegisterTestRunFinish()
{
Logger.Debug("Registering test run finish...");
var testRun = RunContext.GetCurrentTestRun();
if (testRun != null)
{
Logger.Debug($"{DateTime.UtcNow} [{Thread.CurrentThread.Name}] ({testRun.Id}) Registering test run finish...");
var finishTestRunRequest = new FinishTestRunRequest
{
EndedAt = DateTime.UtcNow
};
var saveTestRunResponse = _apiClient.RegisterTestRunFinish(testRun.Id, finishTestRunRequest);
RunContext.SetCurrentTestRun(saveTestRunResponse);
Logger.Debug("Test run finish was registered successfuly.");

Logger.Debug($"{DateTime.UtcNow} [{Thread.CurrentThread.Name}] ({testRun.Id}) Test run finish was registered successfuly.");
}
}

public void RegisterTestStart(ITest test)
{
var testRunId = RunContext.GetCurrentTestRun()?.Id;
var testRun = RunContext.GetCurrentTestRun();
var testName = TestContext.CurrentContext.Test.ClassName + "." + TestContext.CurrentContext.Test.MethodName;
Logger.Debug($"Registering test start for test run ${testRunId}...");
Logger.Debug($"{DateTime.UtcNow} [{Thread.CurrentThread.Name}] ({testRun?.Id}) Registering test start...");

if (testRunId != null)
if (testRun != null)
{
var startTestRequest = new StartTestRequest
{
Expand All @@ -115,36 +116,36 @@ public void RegisterTestStart(ITest test)
Maintainer = MaintainerResolver.ResolveMaintainer(test),
Labels = LabelsResolver.ResolveLabels(test)
};
var saveTestResponse = _apiClient.RegisterTestStart((long) testRunId, startTestRequest);
var saveTestResponse = _apiClient.RegisterTestStart(testRun.Id, startTestRequest);
RunContext.SetCurrentTest(saveTestResponse);

var jobUrl = (Environment.GetEnvironmentVariable("ci_url") ?? DefaultJobUrl).TrimEnd('/');
var jobNumber = Environment.GetEnvironmentVariable("ci_build");
Artifact.AttachReferenceToTest("Demo", $"{jobUrl}/${jobNumber}/Screenshots/${testName}/report.html");
Artifact.AttachReferenceToTest("Log", $"{jobUrl}/${jobNumber}/Logs/${testName}/test.log");
Logger.Debug("Test start was registered successfuly.");

Logger.Debug($"{DateTime.UtcNow} [{Thread.CurrentThread.Name}] ({testRun.Id}, {saveTestResponse.Id}) Test start was registered successfuly.");
}
}

public void RegisterTestFinish()
{
var testRunId = RunContext.GetCurrentTestRun()?.Id;
var testId = RunContext.GetCurrentTest()?.Id;
Logger.Debug($"Registering test finish for test run with id ${testRunId} and test with id ${testId}...");
var testRun = RunContext.GetCurrentTestRun();
var test = RunContext.GetCurrentTest();
Logger.Debug($"{DateTime.UtcNow} [{Thread.CurrentThread.Name}] ({testRun?.Id}, {test?.Id}) Registering test finish...");

if (testRunId != null && testId != null)
if (testRun != null && test != null)
{
var finishTestRequest = new FinishTestRequest
{
EndedAt = DateTime.UtcNow,
Result = TestStatusToReason[TestContext.CurrentContext.Result.Outcome.Status],
Reason = GetFullStackTrace()
};
_apiClient.RegisterTestFinish((long) testRunId, (long) testId, finishTestRequest);
_apiClient.RegisterTestFinish(testRun.Id, test.Id, finishTestRequest);
RunContext.RemoveCurrentTest();
Logger.Debug("Test finish was registered successfuly.");

Logger.Debug($"{DateTime.UtcNow} [{Thread.CurrentThread.Name}] ({testRun.Id}, {test.Id}) Test finish was registered successfuly.");
}
}

Expand Down

0 comments on commit a719216

Please sign in to comment.