From c27e18633450600feaf5929abc92326c2cfa34a9 Mon Sep 17 00:00:00 2001 From: "R.B. Boyer" <4903+rboyer@users.noreply.github.com> Date: Thu, 19 May 2022 15:39:28 -0500 Subject: [PATCH] test: TestServer_RPC_MetricsIntercept should use a concurrency-safe metrics store (#13157) --- agent/consul/server_test.go | 18 +++++++++--------- 1 file changed, 9 insertions(+), 9 deletions(-) diff --git a/agent/consul/server_test.go b/agent/consul/server_test.go index 995e03aacd..72014f8f05 100644 --- a/agent/consul/server_test.go +++ b/agent/consul/server_test.go @@ -7,6 +7,7 @@ import ( "os" "reflect" "strings" + "sync" "sync/atomic" "testing" "time" @@ -1167,7 +1168,7 @@ func TestServer_RPC_MetricsIntercept_Off(t *testing.T) { t.Skip("too slow for testing.Short") } - storage := make(map[string]float32) + storage := &sync.Map{} // string -> float32 keyMakingFunc := func(key []string, labels []metrics.Label) string { allKey := strings.Join(key, "+") @@ -1181,7 +1182,7 @@ func TestServer_RPC_MetricsIntercept_Off(t *testing.T) { } simpleRecorderFunc := func(key []string, val float32, labels []metrics.Label) { - storage[keyMakingFunc(key, labels)] = val + storage.Store(keyMakingFunc(key, labels), val) } t.Run("test no net/rpc interceptor metric with nil func", func(t *testing.T) { @@ -1215,7 +1216,7 @@ func TestServer_RPC_MetricsIntercept_Off(t *testing.T) { key := keyMakingFunc(middleware.OneTwelveRPCSummary[0].Name, []metrics.Label{{Name: "method", Value: "Status.Ping"}}) - if _, ok := storage[key]; ok { + if _, ok := storage.Load(key); ok { t.Fatalf("Did not expect to find key %s in the metrics log, ", key) } }) @@ -1256,7 +1257,7 @@ func TestServer_RPC_MetricsIntercept_Off(t *testing.T) { key := keyMakingFunc(middleware.OneTwelveRPCSummary[0].Name, []metrics.Label{{Name: "method", Value: "Status.Ping"}}) - if _, ok := storage[key]; ok { + if _, ok := storage.Load(key); ok { t.Fatalf("Did not expect to find key %s in the metrics log, ", key) } }) @@ -1316,9 +1317,8 @@ func TestServer_RPC_MetricsIntercept(t *testing.T) { deps := newDefaultDeps(t, conf) // The method used to record metric observations here is similar to that used in - // interceptors_test.go; at present, we don't have a need to lock yet but if we do - // we can imitate that set up further or just factor it out as a "mock" metrics backend - storage := make(map[string]float32) + // interceptors_test.go. + storage := &sync.Map{} // string -> float32 keyMakingFunc := func(key []string, labels []metrics.Label) string { allKey := strings.Join(key, "+") @@ -1330,7 +1330,7 @@ func TestServer_RPC_MetricsIntercept(t *testing.T) { } simpleRecorderFunc := func(key []string, val float32, labels []metrics.Label) { - storage[keyMakingFunc(key, labels)] = val + storage.Store(keyMakingFunc(key, labels), val) } deps.NewRequestRecorderFunc = func(logger hclog.Logger, isLeader func() bool, localDC string) *middleware.RequestRecorder { // for the purposes of this test, we don't need isLeader or localDC @@ -1374,7 +1374,7 @@ func TestServer_RPC_MetricsIntercept(t *testing.T) { key := keyMakingFunc(middleware.OneTwelveRPCSummary[0].Name, expectedLabels) - if _, ok := storage[key]; !ok { + if _, ok := storage.Load(key); !ok { // the compound key will look like: "rpc+server+call+Status.Ping+false+read+test+unreported" t.Fatalf("Did not find key %s in the metrics log, ", key) }