2
0
mirror of synced 2025-01-27 16:56:04 +00:00

63 lines
2.1 KiB
C#
Raw Normal View History

2023-04-14 09:54:07 +02:00
using DistTestCore.Logs;
2023-04-13 14:36:17 +02:00
using KubernetesWorkflow;
2023-04-13 11:30:19 +02:00
using Logging;
using Utils;
2023-04-12 13:53:55 +02:00
namespace DistTestCore
{
public class TestLifecycle
{
private DateTime testStart = DateTime.MinValue;
2023-04-13 14:36:17 +02:00
public TestLifecycle(TestLog log, Configuration configuration, ITimeSet timeSet)
2023-06-22 14:37:37 +02:00
: this(log, configuration, timeSet, new WorkflowCreator(log, configuration.GetK8sConfiguration(timeSet)))
{
}
public TestLifecycle(TestLog log, Configuration configuration, ITimeSet timeSet, WorkflowCreator workflowCreator)
2023-04-12 13:53:55 +02:00
{
2023-04-14 14:53:39 +02:00
Log = log;
Configuration = configuration;
TimeSet = timeSet;
2023-04-13 14:36:17 +02:00
2023-04-12 16:06:04 +02:00
FileManager = new FileManager(Log, configuration);
2023-04-13 14:36:17 +02:00
CodexStarter = new CodexStarter(this, workflowCreator);
PrometheusStarter = new PrometheusStarter(this, workflowCreator);
2023-04-14 09:54:07 +02:00
GethStarter = new GethStarter(this, workflowCreator);
testStart = DateTime.UtcNow;
2023-04-12 16:06:04 +02:00
}
2023-04-12 13:53:55 +02:00
2023-04-12 16:06:04 +02:00
public TestLog Log { get; }
public Configuration Configuration { get; }
public ITimeSet TimeSet { get; }
2023-04-12 16:06:04 +02:00
public FileManager FileManager { get; }
public CodexStarter CodexStarter { get; }
2023-04-13 14:36:17 +02:00
public PrometheusStarter PrometheusStarter { get; }
2023-04-14 09:54:07 +02:00
public GethStarter GethStarter { get; }
2023-04-12 13:53:55 +02:00
2023-04-12 16:06:04 +02:00
public void DeleteAllResources()
{
CodexStarter.DeleteAllResources();
FileManager.DeleteAllTestFiles();
2023-04-12 13:53:55 +02:00
}
2023-04-13 11:30:19 +02:00
2023-06-27 15:28:00 +02:00
public IDownloadedLog DownloadLog(RunningContainer container)
2023-04-13 11:30:19 +02:00
{
var subFile = Log.CreateSubfile();
2023-06-27 15:28:00 +02:00
var description = container.Name;
var handler = new LogDownloadHandler(container, description, subFile);
2023-04-13 11:30:19 +02:00
2023-04-14 14:53:39 +02:00
Log.Log($"Downloading logs for {description} to file '{subFile.FullFilename}'");
2023-06-27 15:28:00 +02:00
CodexStarter.DownloadLog(container, handler);
2023-04-13 11:30:19 +02:00
2023-06-27 15:28:00 +02:00
return new DownloadedLog(subFile, description);
2023-04-13 11:30:19 +02:00
}
public string GetTestDuration()
{
var testDuration = DateTime.UtcNow - testStart;
return Time.FormatDuration(testDuration);
}
2023-04-12 13:53:55 +02:00
}
}