From 56bebacb7ba3e2c234ddf15a956d512c8680e65d Mon Sep 17 00:00:00 2001 From: Alex Blease Date: Tue, 26 Sep 2023 13:31:05 +0100 Subject: [PATCH 1/2] Add logging unit tests to locator --- pkg/stream/locator_test.go | 82 +++++++++++++++++++++++++-------- pkg/stream/stream_suite_test.go | 10 ++++ 2 files changed, 74 insertions(+), 18 deletions(-) diff --git a/pkg/stream/locator_test.go b/pkg/stream/locator_test.go index f79c176d..c269b021 100644 --- a/pkg/stream/locator_test.go +++ b/pkg/stream/locator_test.go @@ -3,16 +3,19 @@ package stream import ( "context" "errors" + "time" + . "github.com/onsi/ginkgo/v2" . "github.com/onsi/gomega" + "github.com/onsi/gomega/gbytes" "github.com/rabbitmq/rabbitmq-stream-go-client/v2/pkg/raw" "golang.org/x/exp/slog" - "time" ) var _ = Describe("Locator", func() { Describe("Operations", func() { var ( + loc *locator logger *slog.Logger backOffPolicy = func(_ int) time.Duration { return time.Millisecond * 10 @@ -20,7 +23,20 @@ var _ = Describe("Locator", func() { ) BeforeEach(func() { - logger = slog.New(slog.NewTextHandler(GinkgoWriter)) + h := slog.HandlerOptions{ + Level: slog.LevelDebug, + }.NewTextHandler(GinkgoWriter) + logger = slog.New(h) + + loc = &locator{ + log: logger, + shutdownNotification: make(chan struct{}), + rawClientConf: raw.ClientConfiguration{}, + client: nil, + isSet: true, + clientClose: nil, + backOffPolicy: backOffPolicy, + } }) It("reconnects", func() { @@ -28,21 +44,6 @@ var _ = Describe("Locator", func() { }) When("there is an error", func() { - var ( - loc *locator - ) - - BeforeEach(func() { - loc = &locator{ - log: logger, - shutdownNotification: make(chan struct{}), - rawClientConf: raw.ClientConfiguration{}, - client: nil, - isSet: true, - clientClose: nil, - backOffPolicy: backOffPolicy, - } - }) It("retries the operation on retryable errors", func() { var runs int @@ -71,7 +72,52 @@ var _ = Describe("Locator", func() { Expect(r[0]).To(MatchError("oopsie")) }) - // TODO: add a test for logs + }) + + Context("logging", func() { + var logBuffer *gbytes.Buffer + + BeforeEach(func() { + logBuffer = gbytes.NewBuffer() + GinkgoWriter.TeeTo(logBuffer) + }) + + It("emits a log when locator operation starts", func() { + _ = loc.locatorOperation(func(_ *locator, _ ...any) []any { + return []any{errors.New("oopsie")} + }) + + Eventually(logBuffer).Within(time.Second).Should(gbytes.Say("starting locator operation")) + }) + + It("emits a log when locator operation succeeds", func() { + _ = loc.locatorOperation(func(_ *locator, _ ...any) []any { + return []any{nil} + }) + + Eventually(logBuffer).Within(time.Second).Should(gbytes.Say("locator operation succeed")) + }) + + It("emits a log on error", func() { + _ = loc.locatorOperation(func(_ *locator, _ ...any) []any { + return []any{errors.New("oopsie")} + }) + Eventually(logBuffer).Within(time.Second).Should(gbytes.Say("error in locator operation")) + Eventually(logBuffer).Within(time.Second).Should(gbytes.Say("error")) + Eventually(logBuffer).Within(time.Second).Should(gbytes.Say("oopsie")) + }) + + It("emits a log on non-retryable error", func() { + var runs int + _ = loc.locatorOperation(func(_ *locator, _ ...any) []any { + runs += 1 + return []any{context.DeadlineExceeded} + }) + Expect(runs).To(BeNumerically("==", 1)) + Eventually(logBuffer).Within(time.Second).Should(gbytes.Say("locator operation failed with non-retryable error")) + Eventually(logBuffer).Within(time.Second).Should(gbytes.Say("error")) + Eventually(logBuffer).Within(time.Second).Should(gbytes.Say("context deadline exceeded")) + }) }) }) diff --git a/pkg/stream/stream_suite_test.go b/pkg/stream/stream_suite_test.go index 72f8f2c6..0faa05c3 100644 --- a/pkg/stream/stream_suite_test.go +++ b/pkg/stream/stream_suite_test.go @@ -1,13 +1,23 @@ package stream_test import ( + "golang.org/x/exp/slog" "testing" . "github.com/onsi/ginkgo/v2" . "github.com/onsi/gomega" ) +var logger *slog.Logger + func TestStream(t *testing.T) { RegisterFailHandler(Fail) RunSpecs(t, "Stream Suite") } + +var _ = BeforeSuite(func() { + h := slog.HandlerOptions{ + Level: slog.LevelDebug, + }.NewTextHandler(GinkgoWriter) + logger = slog.New(h) +}) From 4a5a2f658f480f0367bafa9aa4d19025145392b8 Mon Sep 17 00:00:00 2001 From: Alex Blease Date: Thu, 28 Sep 2023 09:26:44 +0100 Subject: [PATCH 2/2] Remove duplication in log handler setup --- pkg/stream/stream_suite_test.go | 10 ---------- 1 file changed, 10 deletions(-) diff --git a/pkg/stream/stream_suite_test.go b/pkg/stream/stream_suite_test.go index 0faa05c3..72f8f2c6 100644 --- a/pkg/stream/stream_suite_test.go +++ b/pkg/stream/stream_suite_test.go @@ -1,23 +1,13 @@ package stream_test import ( - "golang.org/x/exp/slog" "testing" . "github.com/onsi/ginkgo/v2" . "github.com/onsi/gomega" ) -var logger *slog.Logger - func TestStream(t *testing.T) { RegisterFailHandler(Fail) RunSpecs(t, "Stream Suite") } - -var _ = BeforeSuite(func() { - h := slog.HandlerOptions{ - Level: slog.LevelDebug, - }.NewTextHandler(GinkgoWriter) - logger = slog.New(h) -})