cs-codex-dist-tests/DistTestCore/CodexStarter.cs

70 lines
2.1 KiB
C#
Raw Normal View History

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