114 lines
3.6 KiB
C#
Raw Normal View History

2024-04-01 11:00:52 +02:00
using CodexPlugin;
2023-09-12 15:43:30 +02:00
using DistTestCore;
2023-09-15 15:52:02 +02:00
using GethPlugin;
2023-09-13 11:25:08 +02:00
using MetricsPlugin;
2024-10-01 13:38:08 +02:00
using Nethereum.JsonRpc.Client;
2023-09-12 15:43:30 +02:00
using NUnit.Framework;
using Utils;
namespace CodexTests.BasicTests
2023-09-12 15:43:30 +02:00
{
[TestFixture]
2023-09-19 16:22:07 +02:00
public class ExampleTests : CodexDistTest
2023-09-12 15:43:30 +02:00
{
2024-10-01 13:38:08 +02:00
[Test]
public void A()
{
var oneMb = GenerateTestFile(1.MB(), "oneMB");
var fiveMb = GenerateTestFile(5.MB(), "fiveMb");
var tenMb = GenerateTestFile(10.MB(), "tenMb");
var hundredMb = GenerateTestFile(100.MB(), "hundredMb");
var oneGb = GenerateTestFile(1.GB(), "oneGb");
var a = 0;
}
2023-09-12 15:43:30 +02:00
[Test]
public void CodexLogExample()
{
2024-05-09 09:32:48 +02:00
var primary = StartCodex(s => s.WithLogLevel(CodexLogLevel.Trace, new CodexLogCustomTopics(CodexLogLevel.Warn, CodexLogLevel.Warn)));
2023-09-12 15:43:30 +02:00
2023-11-10 08:20:08 +01:00
var cid = primary.UploadFile(GenerateTestFile(5.MB()));
2024-03-26 14:07:06 +01:00
var localDatasets = primary.LocalFiles();
CollectionAssert.Contains(localDatasets.Content.Select(c => c.Cid), cid);
2023-09-12 15:43:30 +02:00
2024-10-01 13:38:08 +02:00
var nameMap = new Dictionary<string, string>();
AddNameMapping(nameMap, primary);
Get().Replacer = line =>
{
if (line == null) return null;
foreach (var pair in nameMap)
{
line = line.Replace(pair.Key, pair.Value);
}
return line;
};
2023-09-14 15:26:46 +02:00
var log = Ci.DownloadLog(primary);
2023-09-12 15:43:30 +02:00
log.AssertLogContains("Uploaded file");
}
2024-10-01 13:38:08 +02:00
private void AddNameMapping(Dictionary<string, string> nameMap, ICodexNode node)
{
var name = node.GetName();
var info = node.GetDebugInfo();
var nodeId = info.Table.LocalNode.NodeId;
var peerId = info.Table.LocalNode.PeerId;
nameMap.Add(nodeId, name);
nameMap.Add(peerId, name);
nameMap.Add(CodexUtils.ToShortId(nodeId), name);
nameMap.Add(CodexUtils.ToShortId(peerId), name);
nameMap.Add(CodexUtils.ToNodeIdShortId(nodeId), name);
nameMap.Add(CodexUtils.ToNodeIdShortId(peerId), name);
}
2023-09-12 15:43:30 +02:00
[Test]
public void TwoMetricsExample()
{
2024-05-09 09:32:48 +02:00
var group = StartCodex(2, s => s.EnableMetrics());
var group2 = StartCodex(2, s => s.EnableMetrics());
2023-09-13 11:25:08 +02:00
2023-09-13 11:59:21 +02:00
var primary = group[0];
var secondary = group[1];
var primary2 = group2[0];
var secondary2 = group2[1];
2023-09-12 15:43:30 +02:00
2023-09-19 11:51:59 +02:00
var metrics = Ci.GetMetricsFor(primary, primary2);
2023-09-12 15:43:30 +02:00
2023-09-13 11:59:21 +02:00
primary.ConnectToPeer(secondary);
primary2.ConnectToPeer(secondary2);
2023-09-12 15:43:30 +02:00
2023-09-13 11:59:21 +02:00
Thread.Sleep(TimeSpan.FromMinutes(2));
2023-09-12 15:43:30 +02:00
2023-09-13 11:59:21 +02:00
metrics[0].AssertThat("libp2p_peers", Is.EqualTo(1));
metrics[1].AssertThat("libp2p_peers", Is.EqualTo(1));
2024-06-06 10:31:31 +02:00
LogNodeStatus(primary, metrics[0]);
LogNodeStatus(primary2, metrics[1]);
2023-09-12 15:43:30 +02:00
}
[Test]
public void GethBootstrapTest()
{
var boot = Ci.StartGethNode(s => s.WithName("boot").IsMiner());
var disconnected = Ci.StartGethNode(s => s.WithName("disconnected"));
var follow = Ci.StartGethNode(s => s.WithBootstrapNode(boot).WithName("follow"));
Thread.Sleep(12000);
var bootN = boot.GetSyncedBlockNumber();
var discN = disconnected.GetSyncedBlockNumber();
var followN = follow.GetSyncedBlockNumber();
Assert.That(bootN, Is.EqualTo(followN));
Assert.That(discN, Is.LessThan(bootN));
}
2023-09-12 15:43:30 +02:00
}
}