2026-04-17 15:03:22 +10:00
|
|
|
|
using LogosStorageClient;
|
|
|
|
|
|
using LogosStorageTests;
|
2024-11-21 10:46:11 +01:00
|
|
|
|
using NUnit.Framework;
|
2026-05-27 12:44:38 +10:00
|
|
|
|
using StoragePlugin;
|
2024-11-21 10:46:11 +01:00
|
|
|
|
using Utils;
|
2024-11-21 10:03:09 +01:00
|
|
|
|
|
2026-04-17 15:03:22 +10:00
|
|
|
|
namespace LogosStorageReleaseTests.DataTests
|
2024-11-21 10:03:09 +01:00
|
|
|
|
{
|
2024-11-21 10:46:11 +01:00
|
|
|
|
[TestFixture]
|
2026-04-17 15:03:22 +10:00
|
|
|
|
public class TwoClientTests : LogosStorageDistTest
|
2024-11-21 10:03:09 +01:00
|
|
|
|
{
|
2024-11-21 10:46:11 +01:00
|
|
|
|
[Test]
|
|
|
|
|
|
public void TwoClientTest()
|
|
|
|
|
|
{
|
2026-05-27 12:44:38 +10:00
|
|
|
|
var uploader = StartLogosStorage(s =>
|
|
|
|
|
|
s.WithName("Uploader").WithLogFormat(LogosStorageLogFormat.Json)
|
|
|
|
|
|
);
|
|
|
|
|
|
var downloader = StartLogosStorage(s =>
|
|
|
|
|
|
s.WithName("Downloader")
|
|
|
|
|
|
.WithBootstrapNode(uploader)
|
|
|
|
|
|
.WithLogFormat(LogosStorageLogFormat.Json)
|
|
|
|
|
|
);
|
2024-11-21 10:46:11 +01:00
|
|
|
|
|
|
|
|
|
|
PerformTwoClientTest(uploader, downloader);
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
[Test]
|
2024-11-29 09:24:43 +01:00
|
|
|
|
[Ignore("Location selection is currently unavailable.")]
|
2024-11-21 10:46:11 +01:00
|
|
|
|
public void TwoClientsTwoLocationsTest()
|
|
|
|
|
|
{
|
|
|
|
|
|
var locations = Ci.GetKnownLocations();
|
|
|
|
|
|
if (locations.NumberOfLocations < 2)
|
|
|
|
|
|
{
|
|
|
|
|
|
Assert.Inconclusive("Two-locations test requires 2 nodes to be available in the cluster.");
|
|
|
|
|
|
return;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2026-05-27 12:44:38 +10:00
|
|
|
|
var uploader = Ci.StartStorageNode(s =>
|
|
|
|
|
|
s.WithName("Uploader")
|
|
|
|
|
|
.At(locations.Get(0))
|
|
|
|
|
|
.WithLogFormat(LogosStorageLogFormat.Json)
|
|
|
|
|
|
);
|
|
|
|
|
|
var downloader = Ci.StartStorageNode(s =>
|
|
|
|
|
|
s.WithName("Downloader")
|
|
|
|
|
|
.WithBootstrapNode(uploader)
|
|
|
|
|
|
.At(locations.Get(1))
|
|
|
|
|
|
.WithLogFormat(LogosStorageLogFormat.Json)
|
|
|
|
|
|
);
|
2024-11-21 10:46:11 +01:00
|
|
|
|
|
|
|
|
|
|
PerformTwoClientTest(uploader, downloader);
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2026-04-17 15:03:22 +10:00
|
|
|
|
private void PerformTwoClientTest(IStorageNode uploader, IStorageNode downloader)
|
2024-11-21 10:46:11 +01:00
|
|
|
|
{
|
|
|
|
|
|
PerformTwoClientTest(uploader, downloader, 10.MB());
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2026-04-17 15:03:22 +10:00
|
|
|
|
private void PerformTwoClientTest(IStorageNode uploader, IStorageNode downloader, ByteSize size)
|
2024-11-21 10:46:11 +01:00
|
|
|
|
{
|
|
|
|
|
|
var testFile = GenerateTestFile(size);
|
|
|
|
|
|
|
|
|
|
|
|
var contentId = uploader.UploadFile(testFile);
|
|
|
|
|
|
AssertNodesContainFile(contentId, uploader);
|
|
|
|
|
|
|
|
|
|
|
|
var downloadedFile = downloader.DownloadContent(contentId);
|
|
|
|
|
|
AssertNodesContainFile(contentId, uploader, downloader);
|
|
|
|
|
|
|
|
|
|
|
|
testFile.AssertIsEqual(downloadedFile);
|
|
|
|
|
|
CheckLogForErrors(uploader, downloader);
|
|
|
|
|
|
}
|
2024-11-21 10:03:09 +01:00
|
|
|
|
}
|
|
|
|
|
|
}
|