2023-04-12 16:12:04 +02:00
|
|
|
|
using DistTestCore.Codex;
|
|
|
|
|
using KubernetesWorkflow;
|
2023-04-12 16:06:04 +02:00
|
|
|
|
|
|
|
|
|
namespace DistTestCore
|
|
|
|
|
{
|
|
|
|
|
public class CodexStarter
|
|
|
|
|
{
|
2023-04-13 09:33:10 +02:00
|
|
|
|
private readonly TestLifecycle lifecycle;
|
2023-04-13 14:36:17 +02:00
|
|
|
|
private readonly WorkflowCreator workflowCreator;
|
2023-04-12 16:06:04 +02:00
|
|
|
|
|
2023-04-13 14:36:17 +02:00
|
|
|
|
public CodexStarter(TestLifecycle lifecycle, WorkflowCreator workflowCreator)
|
2023-04-12 16:06:04 +02:00
|
|
|
|
{
|
2023-04-13 09:33:10 +02:00
|
|
|
|
this.lifecycle = lifecycle;
|
2023-04-13 14:36:17 +02:00
|
|
|
|
this.workflowCreator = workflowCreator;
|
2023-04-12 16:06:04 +02:00
|
|
|
|
}
|
|
|
|
|
|
2023-04-13 11:53:54 +02:00
|
|
|
|
public List<CodexNodeGroup> RunningGroups { get; } = new List<CodexNodeGroup>();
|
|
|
|
|
|
2023-04-13 09:33:10 +02:00
|
|
|
|
public ICodexNodeGroup BringOnline(CodexSetup codexSetup)
|
2023-04-12 16:06:04 +02:00
|
|
|
|
{
|
2023-04-13 14:36:17 +02:00
|
|
|
|
var containers = StartCodexContainers(codexSetup);
|
2023-04-13 11:53:54 +02:00
|
|
|
|
|
2023-04-13 14:36:17 +02:00
|
|
|
|
var metricAccessFactory = lifecycle.PrometheusStarter.CollectMetricsFor(codexSetup, containers);
|
2023-04-12 16:06:04 +02:00
|
|
|
|
|
2023-04-13 14:36:17 +02:00
|
|
|
|
var codexNodeFactory = new CodexNodeFactory(lifecycle, metricAccessFactory);
|
2023-04-12 16:12:04 +02:00
|
|
|
|
|
2023-04-13 14:36:17 +02:00
|
|
|
|
var group = CreateCodexGroup(codexSetup, containers, codexNodeFactory);
|
2023-04-13 11:53:54 +02:00
|
|
|
|
|
|
|
|
|
return group;
|
2023-04-12 16:06:04 +02:00
|
|
|
|
}
|
|
|
|
|
|
2023-04-13 11:53:54 +02:00
|
|
|
|
public void BringOffline(CodexNodeGroup group)
|
2023-04-13 11:07:36 +02:00
|
|
|
|
{
|
2023-04-13 11:53:54 +02:00
|
|
|
|
Log($"Stopping {group.Describe()}...");
|
2023-04-13 11:07:36 +02:00
|
|
|
|
var workflow = CreateWorkflow();
|
2023-04-13 11:53:54 +02:00
|
|
|
|
workflow.Stop(group.Containers);
|
|
|
|
|
RunningGroups.Remove(group);
|
|
|
|
|
Log("Stopped.");
|
2023-04-13 11:07:36 +02:00
|
|
|
|
}
|
|
|
|
|
|
2023-04-12 16:06:04 +02:00
|
|
|
|
public void DeleteAllResources()
|
|
|
|
|
{
|
2023-04-13 11:07:36 +02:00
|
|
|
|
var workflow = CreateWorkflow();
|
2023-04-12 16:06:04 +02:00
|
|
|
|
workflow.DeleteAllResources();
|
2023-04-13 11:53:54 +02:00
|
|
|
|
|
|
|
|
|
RunningGroups.Clear();
|
2023-04-12 16:06:04 +02:00
|
|
|
|
}
|
2023-04-13 11:07:36 +02:00
|
|
|
|
|
2023-04-13 11:30:19 +02:00
|
|
|
|
public void DownloadLog(RunningContainer container, ILogHandler logHandler)
|
|
|
|
|
{
|
|
|
|
|
var workflow = CreateWorkflow();
|
|
|
|
|
workflow.DownloadContainerLog(container, logHandler);
|
|
|
|
|
}
|
2023-04-13 14:36:17 +02:00
|
|
|
|
|
|
|
|
|
private RunningContainers StartCodexContainers(CodexSetup codexSetup)
|
|
|
|
|
{
|
|
|
|
|
Log($"Starting {codexSetup.Describe()}...");
|
|
|
|
|
|
|
|
|
|
var workflow = CreateWorkflow();
|
|
|
|
|
var startupConfig = new StartupConfig();
|
|
|
|
|
startupConfig.Add(codexSetup);
|
|
|
|
|
|
|
|
|
|
return workflow.Start(codexSetup.NumberOfNodes, codexSetup.Location, new CodexContainerRecipe(), startupConfig);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private CodexNodeGroup CreateCodexGroup(CodexSetup codexSetup, RunningContainers runningContainers, CodexNodeFactory codexNodeFactory)
|
|
|
|
|
{
|
|
|
|
|
var group = new CodexNodeGroup(lifecycle, codexSetup, runningContainers, codexNodeFactory);
|
|
|
|
|
RunningGroups.Add(group);
|
|
|
|
|
|
|
|
|
|
Log($"Started at '{group.Containers.RunningPod.Ip}'");
|
|
|
|
|
return group;
|
|
|
|
|
}
|
2023-04-13 11:30:19 +02:00
|
|
|
|
|
2023-04-13 11:07:36 +02:00
|
|
|
|
private StartupWorkflow CreateWorkflow()
|
|
|
|
|
{
|
|
|
|
|
return workflowCreator.CreateWorkflow();
|
|
|
|
|
}
|
2023-04-13 11:53:54 +02:00
|
|
|
|
|
|
|
|
|
private void Log(string msg)
|
|
|
|
|
{
|
|
|
|
|
lifecycle.Log.Log(msg);
|
|
|
|
|
}
|
2023-04-12 16:06:04 +02:00
|
|
|
|
}
|
|
|
|
|
}
|