From 374ca8b447267c0d33cd86ceb2c6820f4cdfe499 Mon Sep 17 00:00:00 2001 From: Jacques Grove Date: Tue, 31 Oct 2023 20:58:22 -0700 Subject: [PATCH 1/3] Fixes #14414: resilient_server metrics name/prefix logic is inverted, leading to no metrics being recorded Signed-off-by: Jacques Grove --- go/vt/srvtopo/resilient_server.go | 2 +- go/vt/srvtopo/resilient_server_test.go | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/go/vt/srvtopo/resilient_server.go b/go/vt/srvtopo/resilient_server.go index d1521952ab0..8aa779c2a3d 100644 --- a/go/vt/srvtopo/resilient_server.go +++ b/go/vt/srvtopo/resilient_server.go @@ -85,7 +85,7 @@ func NewResilientServer(ctx context.Context, base *topo.Server, counterPrefix st } var metric string - if counterPrefix == "" { + if counterPrefix != "" { metric = counterPrefix + "Counts" } else { metric = "" diff --git a/go/vt/srvtopo/resilient_server_test.go b/go/vt/srvtopo/resilient_server_test.go index c237d43f300..fe248f56087 100644 --- a/go/vt/srvtopo/resilient_server_test.go +++ b/go/vt/srvtopo/resilient_server_test.go @@ -811,7 +811,7 @@ func TestSrvKeyspaceListener(t *testing.T) { srvTopoCacheRefresh = 1 * time.Second }() - rs := NewResilientServer(ctx, ts, "TestGetSrvKeyspaceWatcher") + rs := NewResilientServer(ctx, ts, "TestGetSrvKeyspaceListener") cancelCtx, cancelFunc := context.WithCancel(context.Background()) var callbackCount atomic.Int32 From 243dc77a7f2b74a96da2201cb0477543b4c202ed Mon Sep 17 00:00:00 2001 From: Jacques Grove Date: Wed, 1 Nov 2023 07:28:13 -0700 Subject: [PATCH 2/3] Address review comments Signed-off-by: Jacques Grove --- go/vt/srvtopo/resilient_server.go | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/go/vt/srvtopo/resilient_server.go b/go/vt/srvtopo/resilient_server.go index 8aa779c2a3d..0cbccbdb31c 100644 --- a/go/vt/srvtopo/resilient_server.go +++ b/go/vt/srvtopo/resilient_server.go @@ -84,11 +84,9 @@ func NewResilientServer(ctx context.Context, base *topo.Server, counterPrefix st log.Fatalf("srv_topo_cache_refresh must be less than or equal to srv_topo_cache_ttl") } - var metric string + metric := "" if counterPrefix != "" { metric = counterPrefix + "Counts" - } else { - metric = "" } counts := stats.NewCountersWithSingleLabel(metric, "Resilient srvtopo server operations", "type") From 6661f526915247fac7591386e457fab6580e1560 Mon Sep 17 00:00:00 2001 From: deepthi Date: Wed, 15 Nov 2023 13:02:44 -0800 Subject: [PATCH 3/3] tests: fix panic from initializing same stats variable twice Signed-off-by: deepthi --- go/vt/vttablet/tabletserver/vstreamer/testenv/testenv.go | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/go/vt/vttablet/tabletserver/vstreamer/testenv/testenv.go b/go/vt/vttablet/tabletserver/vstreamer/testenv/testenv.go index c40e180110f..a05dc3b2c05 100644 --- a/go/vt/vttablet/tabletserver/vstreamer/testenv/testenv.go +++ b/go/vt/vttablet/tabletserver/vstreamer/testenv/testenv.go @@ -20,6 +20,7 @@ package testenv import ( "context" "fmt" + "math/rand" "os" "regexp" "strings" @@ -75,7 +76,9 @@ func Init(ctx context.Context) (*Env, error) { if err := te.TopoServ.CreateShard(ctx, te.KeyspaceName, te.ShardName); err != nil { panic(err) } - te.SrvTopo = srvtopo.NewResilientServer(ctx, te.TopoServ, "TestTopo") + // Add a random suffix to metric name to avoid panic. Another option would have been to generate a random string. + suffix := rand.Int() + te.SrvTopo = srvtopo.NewResilientServer(ctx, te.TopoServ, "TestTopo"+fmt.Sprint(suffix)) cfg := vttest.Config{ Topology: &vttestpb.VTTestTopology{