From b2999b45a3da08480e25e3979fd47fb18e00e587 Mon Sep 17 00:00:00 2001 From: Dominic Evans <8060970+dnwe@users.noreply.github.com> Date: Wed, 31 Jan 2024 21:09:06 +0000 Subject: [PATCH] fix(test): retry MockBroker Listen for EADDRINUSE (#2721) Some of the FV tests involve shutting down a MockBroker and then re-creating a new one on the same ip:port. Sometimes this fails because the port shows as still being in-use. Add some rudimentary retry attempts for this case to try and close the FV flakiness in that area. Signed-off-by: Dominic Evans --- mockbroker.go | 22 +++++++++++++++++++++- 1 file changed, 21 insertions(+), 1 deletion(-) diff --git a/mockbroker.go b/mockbroker.go index 6e5d90608..2c5e7cadd 100644 --- a/mockbroker.go +++ b/mockbroker.go @@ -10,6 +10,7 @@ import ( "reflect" "strconv" "sync" + "syscall" "time" "github.com/davecgh/go-spew/spew" @@ -410,10 +411,29 @@ func NewMockBroker(t TestReporter, brokerID int32) *MockBroker { // NewMockBrokerAddr behaves like newMockBroker but listens on the address you give // it rather than just some ephemeral port. func NewMockBrokerAddr(t TestReporter, brokerID int32, addr string) *MockBroker { - listener, err := net.Listen("tcp", addr) + var ( + listener net.Listener + err error + ) + + // retry up to 20 times if address already in use (e.g., if replacing broker which hasn't cleanly shutdown) + for i := 0; i < 20; i++ { + listener, err = net.Listen("tcp", addr) + if err != nil { + if errors.Is(err, syscall.EADDRINUSE) { + Logger.Printf("*** mockbroker/%d waiting for %s (address already in use)", brokerID, addr) + time.Sleep(time.Millisecond * 100) + continue + } + t.Fatal(err) + } + break + } + if err != nil { t.Fatal(err) } + return NewMockBrokerListener(t, brokerID, listener) }