From 3a1c3e72e44ff4c7e56700600d889c0d1d61a9cc Mon Sep 17 00:00:00 2001 From: 6543 <6543@obermui.de> Date: Tue, 29 Oct 2024 06:34:32 +0100 Subject: [PATCH] Don't parse forge config files multiple times if no error occured (#4272) (#4273) Co-authored-by: Patrick Schratz --- server/services/config/forge.go | 7 +++---- server/services/config/forge_test.go | 4 ++-- 2 files changed, 5 insertions(+), 6 deletions(-) diff --git a/server/services/config/forge.go b/server/services/config/forge.go index c88a30ca6cc..e7b87a464e1 100644 --- a/server/services/config/forge.go +++ b/server/services/config/forge.go @@ -59,10 +59,9 @@ func (f *forgeFetcher) Fetch(ctx context.Context, forge forge.Forge, user *model for i := 0; i < int(f.retryCount); i++ { files, err = ffc.fetch(ctx, strings.TrimSpace(repo.Config)) if err != nil { - log.Trace().Err(err).Msgf("%d. try failed", i+1) - } - if errors.Is(err, context.DeadlineExceeded) { - continue + log.Trace().Err(err).Msgf("Fetching config files: Attempt #%d failed", i+1) + } else { + break } } diff --git a/server/services/config/forge_test.go b/server/services/config/forge_test.go index 6a86512031d..05869f24a26 100644 --- a/server/services/config/forge_test.go +++ b/server/services/config/forge_test.go @@ -287,7 +287,7 @@ func TestFetch(t *testing.T) { f := new(mocks.Forge) dirs := map[string][]*forge_types.FileMeta{} for _, file := range tt.files { - f.On("File", mock.Anything, mock.Anything, mock.Anything, mock.Anything, file.name).Return(file.data, nil) + f.On("File", mock.Anything, mock.Anything, mock.Anything, mock.Anything, file.name).Once().Return(file.data, nil) path := filepath.Dir(file.name) if path != "." { dirs[path] = append(dirs[path], &forge_types.FileMeta{ @@ -298,7 +298,7 @@ func TestFetch(t *testing.T) { } for path, files := range dirs { - f.On("Dir", mock.Anything, mock.Anything, mock.Anything, mock.Anything, path).Return(files, nil) + f.On("Dir", mock.Anything, mock.Anything, mock.Anything, mock.Anything, path).Once().Return(files, nil) } // if the previous mocks do not match return not found errors