Fix branch deletion for squash or rebase merged pull requests (#3425)

This commit is contained in:
Lauris BH 2018-01-30 14:29:39 +02:00 committed by GitHub
parent 5911f98392
commit ca4f5c37e6
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -957,38 +957,22 @@ func CleanUpPullRequest(ctx *context.Context) {
} }
// Check if branch has no new commits // Check if branch has no new commits
if len(pr.MergedCommitID) > 0 { headCommitID, err := gitBaseRepo.GetRefCommitID(pr.GetGitRefName())
if err != nil {
log.Error(4, "GetRefCommitID: %v", err)
ctx.Flash.Error(ctx.Tr("repo.branch.deletion_failed", fullBranchName))
return
}
branchCommitID, err := gitRepo.GetBranchCommitID(pr.HeadBranch) branchCommitID, err := gitRepo.GetBranchCommitID(pr.HeadBranch)
if err != nil { if err != nil {
log.Error(4, "GetBranchCommitID: %v", err) log.Error(4, "GetBranchCommitID: %v", err)
ctx.Flash.Error(ctx.Tr("repo.branch.deletion_failed", fullBranchName)) ctx.Flash.Error(ctx.Tr("repo.branch.deletion_failed", fullBranchName))
return return
} }
if headCommitID != branchCommitID {
commit, err := gitBaseRepo.GetCommit(pr.MergedCommitID)
if err != nil {
log.Error(4, "GetCommit: %v", err)
ctx.Flash.Error(ctx.Tr("repo.branch.deletion_failed", fullBranchName))
return
}
isParent := false
for i := 0; i < commit.ParentCount(); i++ {
if parent, err := commit.Parent(i); err != nil {
log.Error(4, "Parent: %v", err)
ctx.Flash.Error(ctx.Tr("repo.branch.deletion_failed", fullBranchName))
return
} else if parent.ID.String() == branchCommitID {
isParent = true
break
}
}
if !isParent {
ctx.Flash.Error(ctx.Tr("repo.branch.delete_branch_has_new_commits", fullBranchName)) ctx.Flash.Error(ctx.Tr("repo.branch.delete_branch_has_new_commits", fullBranchName))
return return
} }
}
if err := gitRepo.DeleteBranch(pr.HeadBranch, git.DeleteBranchOptions{ if err := gitRepo.DeleteBranch(pr.HeadBranch, git.DeleteBranchOptions{
Force: true, Force: true,