2
0
mirror of synced 2025-01-11 09:06:56 +00:00

86 lines
2.7 KiB
C#
Raw Normal View History

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
}
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 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);
return group;
2023-04-12 16:06:04 +02:00
}
public void BringOffline(CodexNodeGroup group)
2023-04-13 11:07:36 +02:00
{
Log($"Stopping {group.Describe()}...");
2023-04-13 11:07:36 +02:00
var workflow = CreateWorkflow();
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();
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();
}
private void Log(string msg)
{
lifecycle.Log.Log(msg);
}
2023-04-12 16:06:04 +02:00
}
}