From 91ca74d17f058dd8bdb60440267778b7a36cda01 Mon Sep 17 00:00:00 2001 From: "Chris S. Kim" Date: Thu, 5 Oct 2023 16:37:48 -0400 Subject: [PATCH] Retry port grabs --- agent/testagent.go | 18 +++++++++++++++++- 1 file changed, 17 insertions(+), 1 deletion(-) diff --git a/agent/testagent.go b/agent/testagent.go index 8ae2220adc6c..84751ba0f767 100644 --- a/agent/testagent.go +++ b/agent/testagent.go @@ -405,6 +405,19 @@ func (a *TestAgent) consulConfig() *consul.Config { return c } +// Using sdk/freeport with *retry.R is not possible without changing +// function signatures. We use this shim instead to save the headache +// of syncing sdk submodule updates. +type retryShim struct { + *retry.R + + name string +} + +func (r *retryShim) Name() string { + return r.name +} + // pickRandomPorts selects random ports from fixed size random blocks of // ports. This does not eliminate the chance for port conflict but // reduces it significantly with little overhead. Furthermore, asking @@ -414,7 +427,10 @@ func (a *TestAgent) consulConfig() *consul.Config { // Instead of relying on one set of ports to be sufficient we retry // starting the agent with different ports on port conflict. func randomPortsSource(t *testing.T, useHTTPS bool) string { - ports := freeport.GetN(t, 7) + var ports []int + retry.RunWith(retry.TwoSeconds(), t, func(r *retry.R) { + ports = freeport.GetN(&retryShim{r, t.Name()}, 7) + }) var http, https int if useHTTPS {