From: zeripath Date: Sun, 29 Mar 2020 16:47:53 +0000 (+0100) Subject: Convert plumbing.ErrObjectNotFound to git.ErrNotExist in getCommit (#10862) (#10868) X-Git-Tag: v1.11.4~4 X-Git-Url: https://source.dussan.org/?a=commitdiff_plain;h=1d5d7458516a3f04d822cb35875a3050c12760af;p=gitea.git Convert plumbing.ErrObjectNotFound to git.ErrNotExist in getCommit (#10862) (#10868) Backport #10862 Signed-off-by: Andrew Thornton Co-authored-by: Lauris BH Co-authored-by: guillep2k <18600385+guillep2k@users.noreply.github.com> Co-authored-by: Antoine GIRARD --- diff --git a/modules/git/repo_commit.go b/modules/git/repo_commit.go index 52f2d27703..b7532a6db2 100644 --- a/modules/git/repo_commit.go +++ b/modules/git/repo_commit.go @@ -12,9 +12,9 @@ import ( "strconv" "strings" - "github.com/mcuadros/go-version" "github.com/go-git/go-git/v5/plumbing" "github.com/go-git/go-git/v5/plumbing/object" + "github.com/mcuadros/go-version" ) // GetRefCommitID returns the last commit ID string of given reference (branch or tag). @@ -94,9 +94,15 @@ func (repo *Repository) getCommit(id SHA1) (*Commit, error) { gogitCommit, err := repo.gogitRepo.CommitObject(id) if err == plumbing.ErrObjectNotFound { tagObject, err = repo.gogitRepo.TagObject(id) + if err == plumbing.ErrObjectNotFound { + return nil, ErrNotExist{ + ID: id.String(), + } + } if err == nil { gogitCommit, err = repo.gogitRepo.CommitObject(tagObject.Target) } + // if we get a plumbing.ErrObjectNotFound here then the repository is broken and it should be 500 } if err != nil { return nil, err