mirror of
https://github.com/logos-storage/logos-storage-nim-cs-dist-tests.git
synced 2026-05-08 02:19:31 +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>
48 lines
1.4 KiB
C#
48 lines
1.4 KiB
C#
using LogosStorageClient;
|
|
using LogosStorageTests;
|
|
using FileUtils;
|
|
using NUnit.Framework;
|
|
using System.Diagnostics;
|
|
using Utils;
|
|
|
|
namespace LogosStorageReleaseTests.DataTests
|
|
{
|
|
public class InterruptUploadTest : LogosStorageDistTest
|
|
{
|
|
[Test]
|
|
public void UploadInterruptTest()
|
|
{
|
|
var nodes = StartLogosStorage(10);
|
|
|
|
var tasks = nodes.Select(n => Task<bool>.Run(() => RunInterruptUploadTest(n)));
|
|
Task.WaitAll(tasks.ToArray());
|
|
|
|
Assert.That(tasks.Select(t => t.Result).All(r => r == true));
|
|
|
|
WaitAndCheckNodesStaysAlive(TimeSpan.FromMinutes(2), nodes);
|
|
}
|
|
|
|
private bool RunInterruptUploadTest(IStorageNode node)
|
|
{
|
|
var file = GenerateTestFile(300.MB());
|
|
|
|
var process = StartCurlUploadProcess(node, file);
|
|
|
|
Thread.Sleep(500);
|
|
process.Kill();
|
|
Thread.Sleep(1000);
|
|
|
|
var log = node.DownloadLog();
|
|
return !log.GetLinesContaining("Unhandled exception in async proc, aborting").Any();
|
|
}
|
|
|
|
private Process StartCurlUploadProcess(IStorageNode node, TrackedFile file)
|
|
{
|
|
var apiAddress = node.GetApiEndpoint();
|
|
var codexUrl = $"{apiAddress}/api/storage/v1/data";
|
|
var filePath = file.Filename;
|
|
return Process.Start("curl", $"-X POST {codexUrl} -H \"Content-Type: application/octet-stream\" -T {filePath}");
|
|
}
|
|
}
|
|
}
|