From d19657404faf768fd3259b9baeb9172f4907343b Mon Sep 17 00:00:00 2001 From: Daniel Nephin Date: Wed, 14 Oct 2020 14:17:31 -0400 Subject: [PATCH] agent/grpc: fix a flaky test by performing more retries Instead of using retry.Run, which appears to have problems in some cases where it does not emit an error message, use a for loop. Increase the number of attempts and remove any sleep, since this operation is not that expensive to do in a tight loop --- agent/grpc/client_test.go | 15 +++++++++------ agent/grpc/stats_test.go | 3 --- 2 files changed, 9 insertions(+), 9 deletions(-) diff --git a/agent/grpc/client_test.go b/agent/grpc/client_test.go index 4bd82b6667..8504d088c6 100644 --- a/agent/grpc/client_test.go +++ b/agent/grpc/client_test.go @@ -13,7 +13,6 @@ import ( "github.com/hashicorp/consul/agent/grpc/internal/testservice" "github.com/hashicorp/consul/agent/grpc/resolver" "github.com/hashicorp/consul/agent/metadata" - "github.com/hashicorp/consul/sdk/testutil/retry" ) func TestNewDialer_WithTLSWrapper(t *testing.T) { @@ -84,7 +83,7 @@ func newScheme(n string) string { } func TestClientConnPool_IntegrationWithGRPCResolver_Rebalance(t *testing.T) { - count := 4 + count := 5 cfg := resolver.Config{Scheme: newScheme(t.Name())} res := resolver.NewServerResolverBuilder(cfg) resolver.RegisterWithGRPC(res) @@ -118,13 +117,17 @@ func TestClientConnPool_IntegrationWithGRPCResolver_Rebalance(t *testing.T) { t.Run("rebalance the dc", func(t *testing.T) { // Rebalance is random, but if we repeat it a few times it should give us a // new server. - retry.RunWith(fastRetry, t, func(r *retry.R) { + attempts := 100 + for i := 0; i < attempts; i++ { res.NewRebalancer("dc1")() resp, err := client.Something(ctx, &testservice.Req{}) - require.NoError(r, err) - require.NotEqual(r, resp.ServerName, first.ServerName) - }) + require.NoError(t, err) + if resp.ServerName != first.ServerName { + return + } + } + t.Fatalf("server was not rebalanced after %v attempts", attempts) }) } diff --git a/agent/grpc/stats_test.go b/agent/grpc/stats_test.go index 5b77170029..f16cfb9cbe 100644 --- a/agent/grpc/stats_test.go +++ b/agent/grpc/stats_test.go @@ -15,7 +15,6 @@ import ( "google.golang.org/grpc" "github.com/hashicorp/consul/agent/grpc/internal/testservice" - "github.com/hashicorp/consul/sdk/testutil/retry" ) func noopRegister(*grpc.Server) {} @@ -93,8 +92,6 @@ func TestHandler_EmitsStats(t *testing.T) { assertDeepEqual(t, expectedCounter, sink.incrCounterCalls, cmpMetricCalls) } -var fastRetry = &retry.Timer{Timeout: 7 * time.Second, Wait: 2 * time.Millisecond} - func assertDeepEqual(t *testing.T, x, y interface{}, opts ...cmp.Option) { t.Helper() if diff := cmp.Diff(x, y, opts...); diff != "" {