2023-03-27 14:49:34 +02:00
using NUnit.Framework ;
2023-03-27 16:24:04 +02:00
using System.Text ;
2023-03-27 14:49:34 +02:00
namespace CodexDistTestCore
{
public class MetricsAggregator
{
private readonly TestLog log ;
private readonly K8sManager k8sManager ;
private PrometheusInfo ? activePrometheus ;
public MetricsAggregator ( TestLog log , K8sManager k8sManager )
{
this . log = log ;
this . k8sManager = k8sManager ;
}
2023-03-27 16:24:04 +02:00
public MetricsAccess BeginCollectingMetricsFor ( OnlineCodexNode [ ] nodes )
2023-03-27 14:49:34 +02:00
{
2023-03-27 16:24:04 +02:00
if ( activePrometheus ! = null )
{
Assert . Fail ( "Incorrect test setup: 'GatherMetrics' may be called only once during a test run. Metrics service targets cannot be changed once started. :(" ) ;
throw new InvalidOperationException ( ) ;
}
2023-03-27 14:49:34 +02:00
2023-03-27 16:24:04 +02:00
log . Log ( $"Starting metrics collecting for {nodes.Length} nodes..." ) ;
2023-03-27 14:49:34 +02:00
2023-03-27 16:24:04 +02:00
var config = GeneratePrometheusConfig ( nodes ) ;
StartPrometheusPod ( config ) ;
2023-03-27 14:49:34 +02:00
2023-03-27 16:24:04 +02:00
log . Log ( "Metrics service started." ) ;
return new MetricsAccess ( activePrometheus ! ) ;
2023-03-27 14:49:34 +02:00
}
public void DownloadAllMetrics ( )
{
}
2023-03-27 16:24:04 +02:00
private void StartPrometheusPod ( string config )
2023-03-27 14:49:34 +02:00
{
if ( activePrometheus ! = null ) return ;
2023-03-27 16:24:04 +02:00
activePrometheus = k8sManager . BringOnlinePrometheus ( config ) ;
2023-03-27 14:49:34 +02:00
}
2023-03-27 16:24:04 +02:00
private string GeneratePrometheusConfig ( OnlineCodexNode [ ] nodes )
2023-03-27 14:49:34 +02:00
{
2023-03-27 16:24:04 +02:00
var config = "" ;
config + = "global:\n" ;
config + = " scrape_interval: 30s\n" ;
config + = " scrape_timeout: 10s\n" ;
config + = "\n" ;
config + = "scrape_configs:\n" ;
config + = " - job_name: services\n" ;
config + = " metrics_path: /metrics\n" ;
config + = " static_configs:\n" ;
config + = " - targets:\n" ;
config + = " - 'prometheus:9090'\n" ;
foreach ( var node in nodes )
2023-03-27 14:49:34 +02:00
{
var ip = node . Group . PodInfo ! . Ip ;
2023-03-27 16:24:04 +02:00
var port = node . Container . MetricsPort ;
config + = $" - '{ip}:{port}'\n" ;
2023-03-27 14:49:34 +02:00
}
2023-03-27 16:24:04 +02:00
var bytes = Encoding . ASCII . GetBytes ( config ) ;
return Convert . ToBase64String ( bytes ) ;
2023-03-27 14:49:34 +02:00
}
}
public class PrometheusInfo
{
public PrometheusInfo ( int servicePort , PodInfo podInfo )
{
ServicePort = servicePort ;
PodInfo = podInfo ;
}
public int ServicePort { get ; }
public PodInfo PodInfo { get ; }
}
}