Fix some test flakes

- return errors in TestAgent.Start so that the retry works correctly
- remove duplicate logging, the error is returned already
- add a missing t.Helper() to retry.Run
- properly set a.Agent to nil so that subsequent retry attempts will actually try to start
pull/10217/head
Daniel Nephin 2021-05-10 13:20:45 -04:00
parent 219874ecbb
commit 1618912cf6
3 changed files with 8 additions and 18 deletions

View File

@ -16,10 +16,8 @@ import (
"time" "time"
metrics "github.com/armon/go-metrics" metrics "github.com/armon/go-metrics"
"github.com/hashicorp/errwrap"
"github.com/hashicorp/go-hclog" "github.com/hashicorp/go-hclog"
uuid "github.com/hashicorp/go-uuid" uuid "github.com/hashicorp/go-uuid"
"github.com/stretchr/testify/require"
"github.com/hashicorp/consul/acl" "github.com/hashicorp/consul/acl"
"github.com/hashicorp/consul/agent/config" "github.com/hashicorp/consul/agent/config"
@ -99,6 +97,7 @@ func NewTestAgent(t *testing.T, hcl string) *TestAgent {
func StartTestAgent(t *testing.T, a TestAgent) *TestAgent { func StartTestAgent(t *testing.T, a TestAgent) *TestAgent {
t.Helper() t.Helper()
retry.RunWith(retry.ThreeTimes(), t, func(r *retry.R) { retry.RunWith(retry.ThreeTimes(), t, func(r *retry.R) {
t.Helper()
if err := a.Start(t); err != nil { if err := a.Start(t); err != nil {
r.Fatal(err) r.Fatal(err)
} }
@ -130,7 +129,7 @@ func TestConfigHCL(nodeID string) string {
// Start starts a test agent. It returns an error if the agent could not be started. // Start starts a test agent. It returns an error if the agent could not be started.
// If no error is returned, the caller must call Shutdown() when finished. // If no error is returned, the caller must call Shutdown() when finished.
func (a *TestAgent) Start(t *testing.T) (err error) { func (a *TestAgent) Start(t *testing.T) error {
t.Helper() t.Helper()
if a.Agent != nil { if a.Agent != nil {
return fmt.Errorf("TestAgent already started") return fmt.Errorf("TestAgent already started")
@ -187,7 +186,9 @@ func (a *TestAgent) Start(t *testing.T) (err error) {
return result, err return result, err
} }
bd, err := NewBaseDeps(loader, logOutput) bd, err := NewBaseDeps(loader, logOutput)
require.NoError(t, err) if err != nil {
return fmt.Errorf("failed to create base deps: %w", err)
}
bd.Logger = logger bd.Logger = logger
bd.MetricsHandler = metrics.NewInmemSink(1*time.Second, time.Minute) bd.MetricsHandler = metrics.NewInmemSink(1*time.Second, time.Minute)
@ -215,8 +216,8 @@ func (a *TestAgent) Start(t *testing.T) (err error) {
if err := a.waitForUp(); err != nil { if err := a.waitForUp(); err != nil {
a.Shutdown() a.Shutdown()
t.Logf("Error while waiting for test agent to start: %v", err) a.Agent = nil
return errwrap.Wrapf(name+": {{err}}", err) return fmt.Errorf("error waiting for test agent to start: %w", err)
} }
a.dns = a.dnsServers[0] a.dns = a.dnsServers[0]
@ -280,17 +281,6 @@ func (a *TestAgent) waitForUp() error {
// Shutdown stops the agent and removes the data directory if it is // Shutdown stops the agent and removes the data directory if it is
// managed by the test agent. // managed by the test agent.
func (a *TestAgent) Shutdown() error { func (a *TestAgent) Shutdown() error {
/* Removed this because it was breaking persistence tests where we would
persist a service and load it through a new agent with the same data-dir.
Not sure if we still need this for other things, everywhere we manually make
a data dir we already do 'defer os.RemoveAll()'
defer func() {
if a.DataDir != "" {
os.RemoveAll(a.DataDir)
}
}()*/
// already shut down
if a.Agent == nil { if a.Agent == nil {
return nil return nil
} }

1
go.mod
View File

@ -30,7 +30,6 @@ require (
github.com/google/tcpproxy v0.0.0-20180808230851-dfa16c61dad2 github.com/google/tcpproxy v0.0.0-20180808230851-dfa16c61dad2
github.com/hashicorp/consul/api v1.8.0 github.com/hashicorp/consul/api v1.8.0
github.com/hashicorp/consul/sdk v0.7.0 github.com/hashicorp/consul/sdk v0.7.0
github.com/hashicorp/errwrap v1.0.0
github.com/hashicorp/go-bexpr v0.1.2 github.com/hashicorp/go-bexpr v0.1.2
github.com/hashicorp/go-checkpoint v0.5.0 github.com/hashicorp/go-checkpoint v0.5.0
github.com/hashicorp/go-cleanhttp v0.5.1 github.com/hashicorp/go-cleanhttp v0.5.1

View File

@ -99,6 +99,7 @@ func decorate(s string) string {
} }
func Run(t Failer, f func(r *R)) { func Run(t Failer, f func(r *R)) {
t.Helper()
run(DefaultFailer(), t, f) run(DefaultFailer(), t, f)
} }