From 822e78f5cc99e1e17ed6ce4cb0eef2f227a79d88 Mon Sep 17 00:00:00 2001 From: Lucas Hinderberger Date: Thu, 4 Jul 2024 11:09:21 +0200 Subject: [PATCH] HTTP/SMTP: Waiting for port to become connectable before continuing test run --- http_server.go | 3 +++ pkg/lib/util/net.go | 23 +++++++++++++++++++++++ smtp_server.go | 3 +++ 3 files changed, 29 insertions(+) create mode 100644 pkg/lib/util/net.go diff --git a/http_server.go b/http_server.go index c17844e..f4a4411 100644 --- a/http_server.go +++ b/http_server.go @@ -13,6 +13,7 @@ import ( "github.com/pkg/errors" "github.com/programmfabrik/apitest/internal/httpproxy" + "github.com/programmfabrik/apitest/pkg/lib/util" "github.com/programmfabrik/golib" "github.com/sirupsen/logrus" ) @@ -78,6 +79,8 @@ func (ats *Suite) StartHttpServer() { run() } else { go run() + + util.WaitForTCP(ats.HttpServer.Addr) } } diff --git a/pkg/lib/util/net.go b/pkg/lib/util/net.go new file mode 100644 index 0000000..845b05c --- /dev/null +++ b/pkg/lib/util/net.go @@ -0,0 +1,23 @@ +package util + +import ( + "net" + "time" + + "github.com/sirupsen/logrus" +) + +// WaitForTCP polls indefinitely until it can connect to the given TCP address. +func WaitForTCP(addr string) { + logrus.Infof("Waiting for TCP address %q to become connectable...", addr) + + for { + c, err := net.Dial("tcp", addr) + if err == nil { + c.Close() + break + } + + time.Sleep(10 * time.Millisecond) + } +} diff --git a/smtp_server.go b/smtp_server.go index 53ba793..bfb36aa 100644 --- a/smtp_server.go +++ b/smtp_server.go @@ -8,6 +8,7 @@ import ( "github.com/sirupsen/logrus" "github.com/programmfabrik/apitest/internal/smtp" + "github.com/programmfabrik/apitest/pkg/lib/util" ) // StartSmtpServer starts the testing SMTP server, if configured. @@ -29,6 +30,8 @@ func (ats *Suite) StartSmtpServer() { logrus.Fatal("SMTP server ListenAndServe:", err) } }() + + util.WaitForTCP(ats.SmtpServer.Addr) } // StopSmtpServer stops the SMTP server that was started using StartSMTPServer.