From 0b1ff3c1d515e8aae146632eed8c7de37c422458 Mon Sep 17 00:00:00 2001 From: Shan Kiyani Date: Mon, 30 Dec 2024 11:24:02 -0500 Subject: [PATCH] fix: consider the case where deliveries can be an empty list --- pkg/retry/retry.go | 6 ++++++ pkg/retry/retry_test.go | 17 +++++++++++++++++ 2 files changed, 23 insertions(+) diff --git a/pkg/retry/retry.go b/pkg/retry/retry.go index faa2cdf1..b3a2f567 100644 --- a/pkg/retry/retry.go +++ b/pkg/retry/retry.go @@ -125,6 +125,12 @@ func (s *Server) handleRetry() http.Handler { return } + if len(deliveries) == 0 { + logger.InfoContext(ctx, "no deliveries from GitHub", + "cursor", cursor) + break + } + // in anticipation of the happy path, store the first event to advance the // cursor if firstCheckpoint == "" { diff --git a/pkg/retry/retry_test.go b/pkg/retry/retry_test.go index ab6b6d9b..4a599c95 100644 --- a/pkg/retry/retry_test.go +++ b/pkg/retry/retry_test.go @@ -126,6 +126,23 @@ func TestHandleRetry(t *testing.T) { listDeliveries: &listDeliveriesRes{err: errors.New("error")}, }, }, + { + name: "github_list_deliveries_empty", + expStatusCode: http.StatusAccepted, + expRespBody: `{"status":"accepted"}`, + datastoreClientOverride: &MockDatastore{ + retrieveCheckpointID: &retrieveCheckpointIDRes{res: "checkpoint-id"}, + }, + gcsLockClientOverride: &MockLock{ + acquire: &acquireRes{}, + }, + githubOverride: &MockGitHub{ + listDeliveries: &listDeliveriesRes{ + deliveries: []*github.HookDelivery{}, + res: &github.Response{}, + }, + }, + }, { name: "github_redeliver_event_failure_big_query_entry_not_exists", expStatusCode: http.StatusInternalServerError,