cs-codex-dist-tests/Tests/CodexTests/BasicTests/ExampleTests.cs

142 lines
5.5 KiB
C#
Raw Normal View History

2023-09-15 14:27:08 +00:00
using CodexContractsPlugin;
using CodexPlugin;
2023-09-12 13:43:30 +00:00
using DistTestCore;
2023-09-15 13:52:02 +00:00
using GethPlugin;
2023-09-13 09:25:08 +00:00
using MetricsPlugin;
using Nethereum.Hex.HexConvertors.Extensions;
2023-09-12 13:43:30 +00:00
using NUnit.Framework;
using Utils;
namespace CodexTests.BasicTests
2023-09-12 13:43:30 +00:00
{
[TestFixture]
2023-09-19 14:22:07 +00:00
public class ExampleTests : CodexDistTest
2023-09-12 13:43:30 +00:00
{
[Test]
public void CodexLogExample()
{
var primary = AddCodex(s => s.WithLogLevel(CodexLogLevel.Trace, new CodexLogCustomTopics(CodexLogLevel.Warn, CodexLogLevel.Warn)));
2023-09-12 13:43:30 +00:00
2023-11-10 07:20:08 +00:00
var cid = primary.UploadFile(GenerateTestFile(5.MB()));
var content = primary.LocalFiles();
CollectionAssert.Contains(content.Select(c => c.Cid), cid);
2023-09-12 13:43:30 +00:00
2023-09-14 13:26:46 +00:00
var log = Ci.DownloadLog(primary);
2023-09-12 13:43:30 +00:00
log.AssertLogContains("Uploaded file");
}
[Test]
public void TwoMetricsExample()
{
2023-09-19 14:22:07 +00:00
var group = AddCodex(2, s => s.EnableMetrics());
var group2 = AddCodex(2, s => s.EnableMetrics());
2023-09-13 09:25:08 +00:00
2023-09-13 09:59:21 +00:00
var primary = group[0];
var secondary = group[1];
var primary2 = group2[0];
var secondary2 = group2[1];
2023-09-12 13:43:30 +00:00
2023-09-19 09:51:59 +00:00
var metrics = Ci.GetMetricsFor(primary, primary2);
2023-09-12 13:43:30 +00:00
2023-09-13 09:59:21 +00:00
primary.ConnectToPeer(secondary);
primary2.ConnectToPeer(secondary2);
2023-09-12 13:43:30 +00:00
2023-09-13 09:59:21 +00:00
Thread.Sleep(TimeSpan.FromMinutes(2));
2023-09-12 13:43:30 +00:00
2023-09-13 09:59:21 +00:00
metrics[0].AssertThat("libp2p_peers", Is.EqualTo(1));
metrics[1].AssertThat("libp2p_peers", Is.EqualTo(1));
2023-09-12 13:43:30 +00:00
}
[Test]
2023-09-22 05:43:46 +00:00
public void MarketplaceExample()
2023-09-12 13:43:30 +00:00
{
2023-09-19 14:22:07 +00:00
var sellerInitialBalance = 234.TestTokens();
var buyerInitialBalance = 1000.TestTokens();
var fileSize = 10.MB();
2023-09-15 13:52:02 +00:00
2023-09-19 14:22:07 +00:00
var geth = Ci.StartGethNode(s => s.IsMiner().WithName("disttest-geth"));
var contracts = Ci.StartCodexContracts(geth);
2023-09-15 14:27:08 +00:00
2023-09-22 05:43:46 +00:00
var seller = AddCodex(s => s
2024-01-18 09:24:59 +00:00
.WithLogLevel(CodexLogLevel.Trace, new CodexLogCustomTopics(CodexLogLevel.Error, CodexLogLevel.Error, CodexLogLevel.Warn))
2023-09-22 05:43:46 +00:00
.WithStorageQuota(11.GB())
.EnableMarketplace(geth, contracts, initialEth: 10.Eth(), initialTokens: sellerInitialBalance, isValidator: true)
.WithSimulateProofFailures(failEveryNProofs: 3));
2023-10-30 12:30:14 +00:00
AssertBalance(contracts, seller, Is.EqualTo(sellerInitialBalance));
2023-09-19 14:22:07 +00:00
seller.Marketplace.MakeStorageAvailable(
size: 10.GB(),
2023-09-20 10:02:32 +00:00
minPriceForTotalSpace: 1.TestTokens(),
2023-09-19 14:22:07 +00:00
maxCollateral: 20.TestTokens(),
maxDuration: TimeSpan.FromMinutes(3));
2023-09-12 13:43:30 +00:00
2023-09-19 14:22:07 +00:00
var testFile = GenerateTestFile(fileSize);
2023-09-12 13:43:30 +00:00
2023-09-19 14:22:07 +00:00
var buyer = AddCodex(s => s
.WithBootstrapNode(seller)
2023-09-20 06:45:55 +00:00
.EnableMarketplace(geth, contracts, initialEth: 10.Eth(), initialTokens: buyerInitialBalance));
2023-10-30 12:30:14 +00:00
AssertBalance(contracts, buyer, Is.EqualTo(buyerInitialBalance));
2023-09-12 13:43:30 +00:00
2023-09-19 14:22:07 +00:00
var contentId = buyer.UploadFile(testFile);
var purchaseContract = buyer.Marketplace.RequestStorage(contentId,
pricePerSlotPerSecond: 2.TestTokens(),
requiredCollateral: 10.TestTokens(),
minRequiredNumberOfNodes: 1,
proofProbability: 5,
duration: TimeSpan.FromMinutes(1));
2023-09-12 13:43:30 +00:00
2023-09-19 14:22:07 +00:00
purchaseContract.WaitForStorageContractStarted(fileSize);
2023-09-12 13:43:30 +00:00
2023-12-20 09:55:29 +00:00
var requests = contracts.GetStorageRequests(GetTestRunTimeRange());
Assert.That(requests.Length, Is.EqualTo(1));
var request = requests.Single();
2023-12-20 10:34:23 +00:00
Assert.That(request.ClientAddress, Is.EqualTo(buyer.EthAddress));
2023-12-20 09:55:29 +00:00
Assert.That(request.Ask.Slots, Is.EqualTo(1));
2023-10-30 12:30:14 +00:00
AssertBalance(contracts, seller, Is.LessThan(sellerInitialBalance), "Collateral was not placed.");
2023-09-12 13:43:30 +00:00
var filledSlotEvents = contracts.GetSlotFilledEvents(GetTestRunTimeRange());
Assert.That(filledSlotEvents.Length, Is.EqualTo(1));
var filledSlotEvent = filledSlotEvents.Single();
Assert.That(filledSlotEvent.SlotIndex.IsZero);
Assert.That(filledSlotEvent.RequestId.ToHex(), Is.EqualTo(request.RequestId.ToHex()));
Assert.That(filledSlotEvent.Host, Is.EqualTo(seller.EthAddress));
2023-12-20 10:34:23 +00:00
var slotHost = contracts.GetSlotHost(request, 0);
Assert.That(slotHost, Is.EqualTo(seller.EthAddress));
2023-09-19 14:22:07 +00:00
purchaseContract.WaitForStorageContractFinished();
2023-09-12 13:43:30 +00:00
2023-10-30 12:30:14 +00:00
AssertBalance(contracts, seller, Is.GreaterThan(sellerInitialBalance), "Seller was not paid for storage.");
AssertBalance(contracts, buyer, Is.LessThan(buyerInitialBalance), "Buyer was not charged for storage.");
2024-01-18 08:55:07 +00:00
var log = Ci.DownloadLog(seller);
log.AssertLogContains("Received a request to store a slot!");
log.AssertLogContains("Received proof challenge");
log.AssertLogContains("Collecting input for proof");
2023-12-20 08:48:22 +00:00
//CheckLogForErrors(seller, buyer);
2023-09-12 13:43:30 +00: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 13:43:30 +00:00
}
}