From 55157588859eea3d5c53f9a12914e893b054deef Mon Sep 17 00:00:00 2001 From: dmachard <5562930+dmachard@users.noreply.github.com> Date: Wed, 9 Oct 2024 18:18:50 +0200 Subject: [PATCH] fix race condition in test --- workers/dnstapserver_test.go | 21 ++++++++++++++++----- workers/worker.go | 2 +- 2 files changed, 17 insertions(+), 6 deletions(-) diff --git a/workers/dnstapserver_test.go b/workers/dnstapserver_test.go index 4c391c56..756a9b62 100644 --- a/workers/dnstapserver_test.go +++ b/workers/dnstapserver_test.go @@ -11,6 +11,7 @@ import ( "github.com/dmachard/go-dnscollector/dnsutils" "github.com/dmachard/go-dnscollector/pkgconfig" + "github.com/dmachard/go-dnscollector/telemetry" "github.com/dmachard/go-dnstap-protobuf" "github.com/dmachard/go-framestream" "github.com/dmachard/go-logger" @@ -632,8 +633,16 @@ func Test_DnstapProcessor_TelemetryCounters(t *testing.T) { // run the consumer with a fake logger fl := GetWorkerForTest(pkgconfig.DefaultBufferSize) + cfg := pkgconfig.GetDefaultConfig() + cfg.Global.Telemetry.Enabled = true + cfg.Global.Worker.InternalMonitor = 1 + + config := pkgconfig.Config{} + metrics := telemetry.NewPrometheusCollector(&config) + // init the dnstap consumer - consumer := NewDNSTapProcessor(0, "peertest", pkgconfig.GetDefaultConfig(), logger, "test", 512) + consumer := NewDNSTapProcessor(0, "peertest", cfg, logger, "test", 512) + consumer.SetMetrics(metrics) consumer.AddDefaultRoute(fl) consumer.AddDroppedRoute(fl) @@ -654,12 +663,14 @@ func Test_DnstapProcessor_TelemetryCounters(t *testing.T) { // add packet to consumer and read output consumer.GetDataChannel() <- data + <-fl.GetInputChannel() + r := <-metrics.Record - if consumer.totalIngress != 1 { - t.Errorf("invalid total ingress oucnter: got %d expect 1", consumer.totalIngress) + if r.TotalIngress != 1 { + t.Errorf("invalid total ingress oucnter: got %d expect 1", r.TotalIngress) } - if consumer.totalEgress != 1 { - t.Errorf("invalid total egress counter: got %d expect 1", consumer.totalEgress) + if r.TotalEgress != 1 { + t.Errorf("invalid total egress counter: got %d expect 1", r.TotalEgress) } } diff --git a/workers/worker.go b/workers/worker.go index f793065d..b56a5754 100644 --- a/workers/worker.go +++ b/workers/worker.go @@ -232,7 +232,7 @@ func (w *GenericWorker) Monitor() { // // send to telemetry? if w.config.Global.Telemetry.Enabled && w.metrics != nil { - if w.totalIngress > 0 || w.totalForwarded > 0 || w.totalDropped > 0 { + if w.totalIngress > 0 || w.totalEgress > 0 || w.totalForwarded > 0 || w.totalDropped > 0 { w.metrics.Record <- telemetry.WorkerStats{ Name: w.GetName(), TotalIngress: w.totalIngress,