From 4935b4733c4e6bb8096d268dd48a9bbad44bd8c9 Mon Sep 17 00:00:00 2001 From: Guillermo Prandi Date: Fri, 10 Jan 2020 15:14:34 -0300 Subject: [PATCH] Don't attempt to close issue if already closed --- modules/repofiles/action.go | 8 +++++--- services/pull/merge.go | 6 ++++-- 2 files changed, 9 insertions(+), 5 deletions(-) diff --git a/modules/repofiles/action.go b/modules/repofiles/action.go index 07bc1b875bde..3be6509bc22d 100644 --- a/modules/repofiles/action.go +++ b/modules/repofiles/action.go @@ -138,9 +138,11 @@ func UpdateIssuesCommit(doer *models.User, repo *models.Repository, commits []*r continue } } - - if err := changeIssueStatus(refRepo, refIssue, doer, ref.Action == references.XRefActionCloses); err != nil { - return err + close := (ref.Action == references.XRefActionCloses) + if close != refIssue.IsClosed { + if err := changeIssueStatus(refRepo, refIssue, doer, close); err != nil { + return err + } } } } diff --git a/services/pull/merge.go b/services/pull/merge.go index b38c2e72f276..7aec7cef3e09 100644 --- a/services/pull/merge.go +++ b/services/pull/merge.go @@ -374,8 +374,10 @@ func Merge(pr *models.PullRequest, doer *models.User, baseGitRepo *git.Repositor return err } close := (ref.RefAction == references.XRefActionCloses) - if err = issue_service.ChangeStatus(ref.Issue, doer, close); err != nil { - return err + if close != ref.Issue.IsClosed { + if err = issue_service.ChangeStatus(ref.Issue, doer, close); err != nil { + return err + } } }