mirror of
https://github.com/logos-storage/logos-storage-nim-cs-dist-tests.git
synced 2026-05-07 18:09:36 +00:00
* ci(docker): build dist-tests images * Update to .net 10, kubernetes client 18.0.13 Kubernetes client 18.0.13 is compatible with Kubernetes 1.34.x. The Kubernetes version is selected automatically by kubeadm in docker desktop (v1.34.1). See https://github.com/kubernetes-client/csharp#version-compatibility for a compatibility table. * Updates to support Kubernetes upgrade * bump openapi.yaml to match openapi.yaml in the logos-storage-nim docker image * bump doc to .net 10 * bump docker to .net 10 * Build image with latest tag always Always build an image with a latest tag (as well as a sha commit hash) when there's a push to master * docker image tag as "latest" only when pushing to master * Update docker image to install doctl * Remove doctl install kubeconfig is now created and uses a plain bearer token instead of using doctl as a credential mgr * Rename and remove all instances of Codex * Further remove CodexNetDeployer as it is no longer needed --------- Co-authored-by: Adam Uhlíř <adam@uhlir.dev>
71 lines
2.2 KiB
C#
71 lines
2.2 KiB
C#
using NUnit.Framework;
|
|
using Logging;
|
|
using Utils;
|
|
using Core;
|
|
using StoragePlugin;
|
|
using LogosStorageClient;
|
|
|
|
namespace ContinuousTests
|
|
{
|
|
public class NodeRunner
|
|
{
|
|
private readonly EntryPointFactory entryPointFactory = new EntryPointFactory();
|
|
private readonly IStorageNode[] nodes;
|
|
private readonly Configuration config;
|
|
private readonly ILog log;
|
|
private readonly string customNamespace;
|
|
|
|
public NodeRunner(IStorageNode[] nodes, Configuration config, ILog log, string customNamespace)
|
|
{
|
|
this.nodes = nodes;
|
|
this.config = config;
|
|
this.log = log;
|
|
this.customNamespace = customNamespace;
|
|
}
|
|
|
|
public void RunNode(Action<ILogosStorageSetup> setup, Action<IStorageNode> operation)
|
|
{
|
|
RunNode(nodes.ToList().PickOneRandom(), setup, operation);
|
|
}
|
|
|
|
public void RunNode(IStorageNode bootstrapNode, Action<ILogosStorageSetup> setup, Action<IStorageNode> operation)
|
|
{
|
|
var entryPoint = CreateEntryPoint();
|
|
// We have to be sure that the transient node we start is using the same image as whatever's already in the deployed network.
|
|
// Therefore, we use the image of the bootstrap node.
|
|
LogosStorageDockerImage.Override = bootstrapNode.GetImageName();
|
|
|
|
try
|
|
{
|
|
var debugInfo = bootstrapNode.GetDebugInfo();
|
|
Assert.That(!string.IsNullOrEmpty(debugInfo.Spr));
|
|
|
|
var node = entryPoint.CreateInterface().StartStorageNode(s =>
|
|
{
|
|
setup(s);
|
|
s.WithBootstrapNode(bootstrapNode);
|
|
});
|
|
|
|
try
|
|
{
|
|
operation(node);
|
|
}
|
|
catch
|
|
{
|
|
node.DownloadLog();
|
|
throw;
|
|
}
|
|
}
|
|
finally
|
|
{
|
|
entryPoint.Tools.CreateWorkflow().DeleteNamespace(wait: false);
|
|
}
|
|
}
|
|
|
|
private EntryPoint CreateEntryPoint()
|
|
{
|
|
return entryPointFactory.CreateEntryPoint(config.KubeConfigFile, config.DataPath, customNamespace, log);
|
|
}
|
|
}
|
|
}
|