mirror of
https://github.com/logos-storage/logos-storage-nim-cs-dist-tests.git
synced 2026-05-10 03:19:39 +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>
87 lines
3.0 KiB
C#
87 lines
3.0 KiB
C#
using NUnit.Framework;
|
|
using MetricsPlugin;
|
|
using Utils;
|
|
using LogosStorageTests;
|
|
|
|
namespace ExperimentalTests.BasicTests
|
|
{
|
|
[TestFixture]
|
|
public class AsyncProfiling : LogosStorageDistTest
|
|
{
|
|
[Test]
|
|
public void AsyncProfileMetricsPlz()
|
|
{
|
|
var node = StartLogosStorage(s => s.EnableMetrics());
|
|
var metrics = Ci.GetMetricsFor(scrapeInterval: TimeSpan.FromSeconds(3.0), node).Single();
|
|
|
|
var file = GenerateTestFile(100.MB());
|
|
node.UploadFile(file);
|
|
|
|
Thread.Sleep(10000);
|
|
|
|
var profilerMetrics = new AsyncProfileMetrics(metrics.GetAllMetrics());
|
|
|
|
var log = GetTestLog();
|
|
log.Log($"{nameof(profilerMetrics.CallCount)} = {profilerMetrics.CallCount.Highest()}");
|
|
log.Log($"{nameof(profilerMetrics.ExecTime)} = {profilerMetrics.ExecTime.Highest()}");
|
|
log.Log($"{nameof(profilerMetrics.ExecTimeWithChildren)} = {profilerMetrics.ExecTimeWithChildren.Highest()}");
|
|
log.Log($"{nameof(profilerMetrics.SingleExecTimeMax)} = {profilerMetrics.SingleExecTimeMax.Highest()}");
|
|
log.Log($"{nameof(profilerMetrics.WallTime)} = {profilerMetrics.WallTime.Highest()}");
|
|
}
|
|
}
|
|
|
|
public class AsyncProfileMetrics
|
|
{
|
|
public AsyncProfileMetrics(Metrics metrics)
|
|
{
|
|
CallCount = CreateMetric(metrics, "chronos_call_count_total");
|
|
ExecTime = CreateMetric(metrics, "chronos_exec_time_total");
|
|
ExecTimeWithChildren = CreateMetric(metrics, "chronos_exec_time_with_children_total");
|
|
SingleExecTimeMax = CreateMetric(metrics, "chronos_single_exec_time_max");
|
|
WallTime = CreateMetric(metrics, "chronos_wall_time_total");
|
|
}
|
|
|
|
public AsyncProfileMetric CallCount { get; }
|
|
public AsyncProfileMetric ExecTime { get; }
|
|
public AsyncProfileMetric ExecTimeWithChildren { get; }
|
|
public AsyncProfileMetric SingleExecTimeMax { get; }
|
|
public AsyncProfileMetric WallTime { get; }
|
|
|
|
private static AsyncProfileMetric CreateMetric(Metrics metrics, string name)
|
|
{
|
|
var sets = metrics.Sets.Where(s => s.Name == name).ToArray();
|
|
return new AsyncProfileMetric(sets);
|
|
}
|
|
}
|
|
|
|
public class AsyncProfileMetric
|
|
{
|
|
private readonly MetricsSet[] metricsSets;
|
|
|
|
public AsyncProfileMetric(MetricsSet[] metricsSets)
|
|
{
|
|
this.metricsSets = metricsSets;
|
|
}
|
|
|
|
public MetricsSet Highest()
|
|
{
|
|
MetricsSet? result = null;
|
|
var highest = double.MinValue;
|
|
foreach (var metric in metricsSets)
|
|
{
|
|
foreach (var value in metric.Values)
|
|
{
|
|
if (value.Value >= highest)
|
|
{
|
|
highest = value.Value;
|
|
result = metric;
|
|
}
|
|
}
|
|
}
|
|
|
|
if (result == null) throw new Exception("None were highest");
|
|
return result;
|
|
}
|
|
}
|
|
}
|