93 lines
3.5 KiB
C#
93 lines
3.5 KiB
C#
using DistTestCore.Logs;
|
|
using Logging;
|
|
using Utils;
|
|
|
|
namespace ContinuousTests
|
|
{
|
|
public class ContinuousTestRunner
|
|
{
|
|
private readonly EntryPointFactory entryPointFactory = new EntryPointFactory();
|
|
private readonly ConfigLoader configLoader = new ConfigLoader();
|
|
private readonly TestFactory testFactory = new TestFactory();
|
|
private readonly Configuration config;
|
|
private readonly CancellationToken cancelToken;
|
|
|
|
public ContinuousTestRunner(string[] args, CancellationToken cancelToken)
|
|
{
|
|
config = configLoader.Load(args);
|
|
this.cancelToken = cancelToken;
|
|
}
|
|
|
|
public void Run()
|
|
{
|
|
var overviewLog = new LogSplitter(
|
|
new FixtureLog(new LogConfig(config.LogPath, false), DateTime.UtcNow, "Overview"),
|
|
new ConsoleLog()
|
|
);
|
|
|
|
overviewLog.Log("Initializing...");
|
|
|
|
var entryPoint = entryPointFactory.CreateEntryPoint(config.KubeConfigFile, config.DataPath, config.CodexDeployment.Metadata.KubeNamespace, overviewLog);
|
|
entryPoint.Announce();
|
|
|
|
overviewLog.Log("Initialized. Performing startup checks...");
|
|
|
|
var startupChecker = new StartupChecker(entryPoint, config, cancelToken);
|
|
startupChecker.Check();
|
|
|
|
var taskFactory = new TaskFactory();
|
|
overviewLog.Log("Startup checks passed. Continuous tests starting...");
|
|
overviewLog.Log("");
|
|
var allTests = testFactory.CreateTests();
|
|
|
|
ClearAllCustomNamespaces(allTests, overviewLog);
|
|
|
|
var testLoops = allTests.Select(t => new TestLoop(entryPointFactory, taskFactory, config, overviewLog, t.GetType(), t.RunTestEvery, startupChecker, cancelToken)).ToArray();
|
|
|
|
foreach (var testLoop in testLoops)
|
|
{
|
|
if (cancelToken.IsCancellationRequested) break;
|
|
|
|
overviewLog.Log("Launching test-loop for " + testLoop.Name);
|
|
testLoop.Begin();
|
|
Thread.Sleep(TimeSpan.FromSeconds(5));
|
|
}
|
|
|
|
overviewLog.Log("Finished launching test-loops.");
|
|
WaitUntilFinished(overviewLog);
|
|
overviewLog.Log("Cancelling all test-loops...");
|
|
taskFactory.WaitAll();
|
|
overviewLog.Log("All tasks cancelled.");
|
|
}
|
|
|
|
private void WaitUntilFinished(LogSplitter overviewLog)
|
|
{
|
|
if (config.TargetDurationSeconds > 0)
|
|
{
|
|
var targetDuration = TimeSpan.FromSeconds(config.TargetDurationSeconds);
|
|
cancelToken.WaitHandle.WaitOne(targetDuration);
|
|
overviewLog.Log($"Congratulations! The targer duration has been reached! ({Time.FormatDuration(targetDuration)})");
|
|
}
|
|
else
|
|
{
|
|
cancelToken.WaitHandle.WaitOne();
|
|
}
|
|
}
|
|
|
|
private void ClearAllCustomNamespaces(ContinuousTest[] allTests, ILog log)
|
|
{
|
|
foreach (var test in allTests) ClearAllCustomNamespaces(test, log);
|
|
}
|
|
|
|
private void ClearAllCustomNamespaces(ContinuousTest test, ILog log)
|
|
{
|
|
if (string.IsNullOrEmpty(test.CustomK8sNamespace)) return;
|
|
|
|
log.Log($"Clearing namespace '{test.CustomK8sNamespace}'...");
|
|
|
|
var entryPoint = entryPointFactory.CreateEntryPoint(config.KubeConfigFile, config.DataPath, test.CustomK8sNamespace, log);
|
|
entryPoint.Tools.CreateWorkflow().DeleteNamespacesStartingWith(test.CustomK8sNamespace);
|
|
}
|
|
}
|
|
}
|