mirror of
https://github.com/logos-storage/logos-storage-nim-cs-dist-tests.git
synced 2026-05-12 04: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>
64 lines
2.1 KiB
C#
64 lines
2.1 KiB
C#
using LogosStorageClient;
|
|
using Logging;
|
|
using static LogosStorageTests.Helpers.FullConnectivityHelper;
|
|
|
|
namespace LogosStorageTests.Helpers
|
|
{
|
|
public class PeerConnectionTestHelpers : IFullConnectivityImplementation
|
|
{
|
|
private readonly FullConnectivityHelper helper;
|
|
|
|
public PeerConnectionTestHelpers(ILog log)
|
|
{
|
|
helper = new FullConnectivityHelper(log, this);
|
|
}
|
|
|
|
public void AssertFullyConnected(IEnumerable<IStorageNode> nodes)
|
|
{
|
|
helper.AssertFullyConnected(nodes);
|
|
}
|
|
|
|
public string Description()
|
|
{
|
|
return "Peer Discovery";
|
|
}
|
|
|
|
public string ValidateEntry(Entry entry, Entry[] allEntries)
|
|
{
|
|
var result = string.Empty;
|
|
foreach (var peer in entry.Response.Table.Nodes)
|
|
{
|
|
var expected = GetExpectedDiscoveryEndpoint(allEntries, peer);
|
|
if (expected != peer.Address)
|
|
{
|
|
result += $"Node:{entry.Node.GetName()} has incorrect peer table entry. Was: '{peer.Address}', expected: '{expected}'. ";
|
|
}
|
|
}
|
|
return result;
|
|
}
|
|
|
|
public PeerConnectionState Check(Entry from, Entry to)
|
|
{
|
|
var peerId = to.Response.Id;
|
|
|
|
var response = from.Node.GetDebugPeer(peerId);
|
|
if (!response.IsPeerFound)
|
|
{
|
|
return PeerConnectionState.NoConnection;
|
|
}
|
|
if (!string.IsNullOrEmpty(response.PeerId) && response.Addresses.Any())
|
|
{
|
|
return PeerConnectionState.Connection;
|
|
}
|
|
return PeerConnectionState.Unknown;
|
|
}
|
|
|
|
private static string GetExpectedDiscoveryEndpoint(Entry[] allEntries, DebugInfoTableNode node)
|
|
{
|
|
var peer = allEntries.SingleOrDefault(e => e.Response.Table.LocalNode.PeerId == node.PeerId);
|
|
if (peer == null) return $"peerId: {node.PeerId} is not known.";
|
|
return peer.Node.GetDiscoveryEndpoint().ToString();
|
|
}
|
|
}
|
|
}
|