2023-03-21 13:20:21 +01:00
|
|
|
|
using CodexDistTestCore;
|
2023-03-26 10:57:54 +02:00
|
|
|
|
using CodexDistTestCore.Config;
|
2023-03-17 11:43:29 +01:00
|
|
|
|
using NUnit.Framework;
|
|
|
|
|
|
2023-03-21 13:20:21 +01:00
|
|
|
|
namespace Tests.BasicTests
|
2023-03-17 11:43:29 +01:00
|
|
|
|
{
|
|
|
|
|
[TestFixture]
|
2023-03-21 13:20:21 +01:00
|
|
|
|
public class SimpleTests : DistTest
|
2023-03-17 11:43:29 +01:00
|
|
|
|
{
|
2023-03-28 10:25:48 +02:00
|
|
|
|
[Test]
|
|
|
|
|
public void GetDebugInfo()
|
|
|
|
|
{
|
|
|
|
|
var dockerImage = new CodexDockerImage();
|
2023-03-21 08:30:40 +01:00
|
|
|
|
|
2023-03-28 10:25:48 +02:00
|
|
|
|
var node = SetupCodexNodes(1).BringOnline()[0];
|
2023-03-17 11:43:29 +01:00
|
|
|
|
|
2023-03-28 10:25:48 +02:00
|
|
|
|
var debugInfo = node.GetDebugInfo();
|
2023-03-20 09:23:32 +01:00
|
|
|
|
|
2023-03-28 10:25:48 +02:00
|
|
|
|
Assert.That(debugInfo.spr, Is.Not.Empty);
|
|
|
|
|
Assert.That(debugInfo.codex.revision, Is.EqualTo(dockerImage.GetExpectedImageRevision()));
|
|
|
|
|
}
|
2023-03-20 09:23:32 +01:00
|
|
|
|
|
2023-03-28 10:25:48 +02:00
|
|
|
|
[Test, DontDownloadLogsAndMetricsOnFailure]
|
|
|
|
|
public void CanAccessLogs()
|
|
|
|
|
{
|
|
|
|
|
var node = SetupCodexNodes(1).BringOnline()[0];
|
2023-03-20 09:23:32 +01:00
|
|
|
|
|
2023-03-28 10:25:48 +02:00
|
|
|
|
var log = node.DownloadLog();
|
2023-03-20 09:23:32 +01:00
|
|
|
|
|
2023-03-28 10:25:48 +02:00
|
|
|
|
log.AssertLogContains("Started codex node");
|
|
|
|
|
}
|
2023-03-20 09:23:32 +01:00
|
|
|
|
|
2023-03-26 10:57:54 +02:00
|
|
|
|
[Test]
|
2023-03-27 14:49:34 +02:00
|
|
|
|
public void MetricsExample()
|
2023-03-26 10:57:54 +02:00
|
|
|
|
{
|
2023-03-27 14:49:34 +02:00
|
|
|
|
var group = SetupCodexNodes(2)
|
|
|
|
|
.EnableMetrics()
|
|
|
|
|
.BringOnline();
|
2023-03-20 09:23:32 +01:00
|
|
|
|
|
2023-03-27 14:49:34 +02:00
|
|
|
|
var metrics = GatherMetrics(group);
|
2023-03-19 10:49:03 +01:00
|
|
|
|
|
2023-03-28 13:43:25 +02:00
|
|
|
|
var group2 = SetupCodexNodes(2)
|
|
|
|
|
.EnableMetrics()
|
|
|
|
|
.BringOnline();
|
|
|
|
|
|
|
|
|
|
var metrics2 = GatherMetrics(group2);
|
|
|
|
|
|
2023-03-27 14:49:34 +02:00
|
|
|
|
var primary = group[0];
|
|
|
|
|
var secondary = group[1];
|
2023-03-28 13:43:25 +02:00
|
|
|
|
var primary2 = group2[0];
|
|
|
|
|
var secondary2 = group2[1];
|
|
|
|
|
|
2023-03-27 14:49:34 +02:00
|
|
|
|
primary.ConnectToPeer(secondary);
|
2023-03-28 13:43:25 +02:00
|
|
|
|
primary2.ConnectToPeer(secondary2);
|
2023-03-19 10:49:03 +01:00
|
|
|
|
|
2023-03-27 14:49:34 +02:00
|
|
|
|
AssertWithTimeout(
|
|
|
|
|
() => metrics.GetMostRecentInt("libp2p_peers", primary),
|
|
|
|
|
isEqualTo: 1,
|
|
|
|
|
"Number of peers metric was incorrect.");
|
2023-03-28 13:43:25 +02:00
|
|
|
|
|
|
|
|
|
AssertWithTimeout(
|
|
|
|
|
() => metrics2.GetMostRecentInt("libp2p_peers", primary2),
|
|
|
|
|
isEqualTo: 1,
|
|
|
|
|
"Aaa");
|
2023-03-26 10:57:54 +02:00
|
|
|
|
}
|
2023-03-22 14:49:01 +01:00
|
|
|
|
|
2023-03-28 10:25:48 +02:00
|
|
|
|
[Test]
|
|
|
|
|
public void OneClientTest()
|
|
|
|
|
{
|
|
|
|
|
var primary = SetupCodexNodes(1).BringOnline()[0];
|
2023-03-23 12:41:34 +01:00
|
|
|
|
|
2023-03-28 10:25:48 +02:00
|
|
|
|
var testFile = GenerateTestFile(1.MB());
|
2023-03-23 12:41:34 +01:00
|
|
|
|
|
2023-03-28 10:25:48 +02:00
|
|
|
|
var contentId = primary.UploadFile(testFile);
|
2023-03-23 12:41:34 +01:00
|
|
|
|
|
2023-03-28 10:25:48 +02:00
|
|
|
|
var downloadedFile = primary.DownloadContent(contentId);
|
2023-03-22 14:49:01 +01:00
|
|
|
|
|
2023-03-28 10:25:48 +02:00
|
|
|
|
testFile.AssertIsEqual(downloadedFile);
|
|
|
|
|
}
|
2023-03-24 14:16:59 +01:00
|
|
|
|
|
2023-03-28 10:25:48 +02:00
|
|
|
|
[Test]
|
|
|
|
|
public void TwoClientsOnePodTest()
|
|
|
|
|
{
|
|
|
|
|
var group = SetupCodexNodes(2).BringOnline();
|
2023-03-24 14:16:59 +01:00
|
|
|
|
|
2023-03-28 10:25:48 +02:00
|
|
|
|
var primary = group[0];
|
|
|
|
|
var secondary = group[1];
|
2023-03-26 10:45:01 +02:00
|
|
|
|
|
2023-03-28 10:25:48 +02:00
|
|
|
|
PerformTwoClientTest(primary, secondary);
|
|
|
|
|
}
|
2023-03-26 10:45:01 +02:00
|
|
|
|
|
2023-03-28 10:25:48 +02:00
|
|
|
|
[Test]
|
|
|
|
|
public void TwoClientsTwoPodsTest()
|
|
|
|
|
{
|
|
|
|
|
var primary = SetupCodexNodes(1).BringOnline()[0];
|
2023-03-22 14:49:01 +01:00
|
|
|
|
|
2023-03-28 10:25:48 +02:00
|
|
|
|
var secondary = SetupCodexNodes(1).BringOnline()[0];
|
2023-03-27 10:27:08 +02:00
|
|
|
|
|
2023-03-28 10:25:48 +02:00
|
|
|
|
PerformTwoClientTest(primary, secondary);
|
|
|
|
|
}
|
2023-03-27 14:49:34 +02:00
|
|
|
|
|
2023-03-28 13:43:25 +02:00
|
|
|
|
//[Test]
|
|
|
|
|
//public void TwoClientsTwoLocationsTest()
|
|
|
|
|
//{
|
|
|
|
|
// var primary = SetupCodexNodes(1)
|
|
|
|
|
// .At(Location.BensLaptop)
|
|
|
|
|
// .BringOnline()[0];
|
2023-03-27 14:49:34 +02:00
|
|
|
|
|
2023-03-28 13:43:25 +02:00
|
|
|
|
// var secondary = SetupCodexNodes(1)
|
|
|
|
|
// .At(Location.BensOldGamingMachine)
|
|
|
|
|
// .BringOnline()[0];
|
2023-03-27 14:49:34 +02:00
|
|
|
|
|
2023-03-28 13:43:25 +02:00
|
|
|
|
// PerformTwoClientTest(primary, secondary);
|
|
|
|
|
//}
|
2023-03-27 10:27:08 +02:00
|
|
|
|
|
2023-03-22 14:49:01 +01:00
|
|
|
|
private void PerformTwoClientTest(IOnlineCodexNode primary, IOnlineCodexNode secondary)
|
|
|
|
|
{
|
2023-03-22 11:27:51 +01:00
|
|
|
|
primary.ConnectToPeer(secondary);
|
2023-03-19 10:49:03 +01:00
|
|
|
|
|
2023-03-22 11:27:51 +01:00
|
|
|
|
var testFile = GenerateTestFile(1.MB());
|
2023-03-19 10:49:03 +01:00
|
|
|
|
|
2023-03-22 11:27:51 +01:00
|
|
|
|
var contentId = primary.UploadFile(testFile);
|
2023-03-19 10:49:03 +01:00
|
|
|
|
|
2023-03-22 11:27:51 +01:00
|
|
|
|
var downloadedFile = secondary.DownloadContent(contentId);
|
|
|
|
|
|
|
|
|
|
testFile.AssertIsEqual(downloadedFile);
|
|
|
|
|
}
|
2023-03-17 11:43:29 +01:00
|
|
|
|
}
|
|
|
|
|
}
|