Skip to content

Commit 087aed7

Browse files
authored
Fix Add/Remove WIP on pull request title failure (#29999) (#30066)
Fix #29997 Backport #29999
1 parent 78795dd commit 087aed7

File tree

3 files changed

+35
-22
lines changed

3 files changed

+35
-22
lines changed

services/issue/issue.go

Lines changed: 10 additions & 15 deletions
Original file line numberDiff line numberDiff line change
@@ -16,6 +16,7 @@ import (
1616
system_model "code.gitea.io/gitea/models/system"
1717
user_model "code.gitea.io/gitea/models/user"
1818
"code.gitea.io/gitea/modules/git"
19+
"code.gitea.io/gitea/modules/log"
1920
"code.gitea.io/gitea/modules/storage"
2021
notify_service "code.gitea.io/gitea/services/notify"
2122
)
@@ -70,23 +71,17 @@ func ChangeTitle(ctx context.Context, issue *issues_model.Issue, doer *user_mode
7071
return err
7172
}
7273

73-
var reviewNotifers []*ReviewRequestNotifier
74-
75-
if err := db.WithTx(ctx, func(ctx context.Context) error {
76-
if err := issues_model.ChangeIssueTitle(ctx, issue, doer, oldTitle); err != nil {
77-
return err
78-
}
74+
if err := issues_model.ChangeIssueTitle(ctx, issue, doer, oldTitle); err != nil {
75+
return err
76+
}
7977

80-
if issue.IsPull && issues_model.HasWorkInProgressPrefix(oldTitle) && !issues_model.HasWorkInProgressPrefix(title) {
81-
var err error
82-
reviewNotifers, err = PullRequestCodeOwnersReview(ctx, issue, issue.PullRequest)
83-
if err != nil {
84-
return err
85-
}
78+
var reviewNotifers []*ReviewRequestNotifier
79+
if issue.IsPull && issues_model.HasWorkInProgressPrefix(oldTitle) && !issues_model.HasWorkInProgressPrefix(title) {
80+
var err error
81+
reviewNotifers, err = PullRequestCodeOwnersReview(ctx, issue, issue.PullRequest)
82+
if err != nil {
83+
log.Error("PullRequestCodeOwnersReview: %v", err)
8684
}
87-
return nil
88-
}); err != nil {
89-
return err
9085
}
9186

9287
notify_service.IssueChangeTitle(ctx, doer, issue, oldTitle)

services/issue/pull.go

Lines changed: 10 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -39,7 +39,7 @@ type ReviewRequestNotifier struct {
3939
ReviewTeam *org_model.Team
4040
}
4141

42-
func PullRequestCodeOwnersReview(ctx context.Context, pull *issues_model.Issue, pr *issues_model.PullRequest) ([]*ReviewRequestNotifier, error) {
42+
func PullRequestCodeOwnersReview(ctx context.Context, issue *issues_model.Issue, pr *issues_model.PullRequest) ([]*ReviewRequestNotifier, error) {
4343
files := []string{"CODEOWNERS", "docs/CODEOWNERS", ".gitea/CODEOWNERS"}
4444

4545
if pr.IsWorkInProgress(ctx) {
@@ -89,7 +89,7 @@ func PullRequestCodeOwnersReview(ctx context.Context, pull *issues_model.Issue,
8989

9090
// https://github.com/go-gitea/gitea/issues/29763, we need to get the files changed
9191
// between the merge base and the head commit but not the base branch and the head commit
92-
changedFiles, err := repo.GetFilesChangedBetween(mergeBase, pr.HeadCommitID)
92+
changedFiles, err := repo.GetFilesChangedBetween(mergeBase, pr.GetGitRefName())
9393
if err != nil {
9494
return nil, err
9595
}
@@ -111,22 +111,26 @@ func PullRequestCodeOwnersReview(ctx context.Context, pull *issues_model.Issue,
111111

112112
notifiers := make([]*ReviewRequestNotifier, 0, len(uniqUsers)+len(uniqTeams))
113113

114+
if err := issue.LoadPoster(ctx); err != nil {
115+
return nil, err
116+
}
117+
114118
for _, u := range uniqUsers {
115-
if u.ID != pull.Poster.ID {
116-
comment, err := issues_model.AddReviewRequest(ctx, pull, u, pull.Poster)
119+
if u.ID != issue.Poster.ID {
120+
comment, err := issues_model.AddReviewRequest(ctx, issue, u, issue.Poster)
117121
if err != nil {
118122
log.Warn("Failed add assignee user: %s to PR review: %s#%d, error: %s", u.Name, pr.BaseRepo.Name, pr.ID, err)
119123
return nil, err
120124
}
121125
notifiers = append(notifiers, &ReviewRequestNotifier{
122126
Comment: comment,
123127
IsAdd: true,
124-
Reviwer: pull.Poster,
128+
Reviwer: u,
125129
})
126130
}
127131
}
128132
for _, t := range uniqTeams {
129-
comment, err := issues_model.AddTeamReviewRequest(ctx, pull, t, pull.Poster)
133+
comment, err := issues_model.AddTeamReviewRequest(ctx, issue, t, issue.Poster)
130134
if err != nil {
131135
log.Warn("Failed add assignee team: %s to PR review: %s#%d, error: %s", t.Name, pr.BaseRepo.Name, pr.ID, err)
132136
return nil, err

tests/integration/pull_review_test.go

Lines changed: 15 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -14,6 +14,7 @@ import (
1414
"code.gitea.io/gitea/models/unittest"
1515
user_model "code.gitea.io/gitea/models/user"
1616
"code.gitea.io/gitea/modules/test"
17+
issue_service "code.gitea.io/gitea/services/issue"
1718
repo_service "code.gitea.io/gitea/services/repository"
1819
files_service "code.gitea.io/gitea/services/repository/files"
1920
"code.gitea.io/gitea/tests"
@@ -85,8 +86,21 @@ func TestPullView_CodeOwner(t *testing.T) {
8586
session := loginUser(t, "user2")
8687
createPullRequest(t, session, "user2", "test_codeowner", repo.DefaultBranch, "codeowner-basebranch", "Test Pull Request")
8788

88-
pr := unittest.AssertExistsAndLoadBean(t, &issues_model.PullRequest{BaseRepoID: repo.ID, HeadBranch: "codeowner-basebranch"})
89+
pr := unittest.AssertExistsAndLoadBean(t, &issues_model.PullRequest{BaseRepoID: repo.ID, HeadRepoID: repo.ID, HeadBranch: "codeowner-basebranch"})
8990
unittest.AssertExistsIf(t, true, &issues_model.Review{IssueID: pr.IssueID, Type: issues_model.ReviewTypeRequest, ReviewerID: 5})
91+
assert.NoError(t, pr.LoadIssue(db.DefaultContext))
92+
93+
err := issue_service.ChangeTitle(db.DefaultContext, pr.Issue, user2, "[WIP] Test Pull Request")
94+
assert.NoError(t, err)
95+
prUpdated1 := unittest.AssertExistsAndLoadBean(t, &issues_model.PullRequest{ID: pr.ID})
96+
assert.NoError(t, prUpdated1.LoadIssue(db.DefaultContext))
97+
assert.EqualValues(t, "[WIP] Test Pull Request", prUpdated1.Issue.Title)
98+
99+
err = issue_service.ChangeTitle(db.DefaultContext, prUpdated1.Issue, user2, "Test Pull Request2")
100+
assert.NoError(t, err)
101+
prUpdated2 := unittest.AssertExistsAndLoadBean(t, &issues_model.PullRequest{ID: pr.ID})
102+
assert.NoError(t, prUpdated2.LoadIssue(db.DefaultContext))
103+
assert.EqualValues(t, "Test Pull Request2", prUpdated2.Issue.Title)
90104
})
91105

92106
// change the default branch CODEOWNERS file to change README.md's codeowner

0 commit comments

Comments
 (0)