Skip to content

Commit 475b6e8

Browse files
authored
Fix Add/Remove WIP on pull request title failure (#29999)
Fix #29997
1 parent c6c4d66 commit 475b6e8

File tree

3 files changed

+35
-22
lines changed

3 files changed

+35
-22
lines changed

services/issue/issue.go

+10-15
Original file line numberDiff line numberDiff line change
@@ -17,6 +17,7 @@ import (
1717
user_model "code.gitea.io/gitea/models/user"
1818
"code.gitea.io/gitea/modules/container"
1919
"code.gitea.io/gitea/modules/git"
20+
"code.gitea.io/gitea/modules/log"
2021
"code.gitea.io/gitea/modules/storage"
2122
notify_service "code.gitea.io/gitea/services/notify"
2223
)
@@ -85,23 +86,17 @@ func ChangeTitle(ctx context.Context, issue *issues_model.Issue, doer *user_mode
8586
}
8687
}
8788

88-
var reviewNotifers []*ReviewRequestNotifier
89-
90-
if err := db.WithTx(ctx, func(ctx context.Context) error {
91-
if err := issues_model.ChangeIssueTitle(ctx, issue, doer, oldTitle); err != nil {
92-
return err
93-
}
89+
if err := issues_model.ChangeIssueTitle(ctx, issue, doer, oldTitle); err != nil {
90+
return err
91+
}
9492

95-
if issue.IsPull && issues_model.HasWorkInProgressPrefix(oldTitle) && !issues_model.HasWorkInProgressPrefix(title) {
96-
var err error
97-
reviewNotifers, err = PullRequestCodeOwnersReview(ctx, issue, issue.PullRequest)
98-
if err != nil {
99-
return err
100-
}
93+
var reviewNotifers []*ReviewRequestNotifier
94+
if issue.IsPull && issues_model.HasWorkInProgressPrefix(oldTitle) && !issues_model.HasWorkInProgressPrefix(title) {
95+
var err error
96+
reviewNotifers, err = PullRequestCodeOwnersReview(ctx, issue, issue.PullRequest)
97+
if err != nil {
98+
log.Error("PullRequestCodeOwnersReview: %v", err)
10199
}
102-
return nil
103-
}); err != nil {
104-
return err
105100
}
106101

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

services/issue/pull.go

+10-6
Original file line numberDiff line numberDiff line change
@@ -40,7 +40,7 @@ type ReviewRequestNotifier struct {
4040
ReviewTeam *org_model.Team
4141
}
4242

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

4646
if pr.IsWorkInProgress(ctx) {
@@ -90,7 +90,7 @@ func PullRequestCodeOwnersReview(ctx context.Context, pull *issues_model.Issue,
9090

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

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

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

tests/integration/pull_review_test.go

+15-1
Original file line numberDiff line numberDiff line change
@@ -15,6 +15,7 @@ import (
1515
user_model "code.gitea.io/gitea/models/user"
1616
"code.gitea.io/gitea/modules/git"
1717
"code.gitea.io/gitea/modules/test"
18+
issue_service "code.gitea.io/gitea/services/issue"
1819
repo_service "code.gitea.io/gitea/services/repository"
1920
files_service "code.gitea.io/gitea/services/repository/files"
2021
"code.gitea.io/gitea/tests"
@@ -87,8 +88,21 @@ func TestPullView_CodeOwner(t *testing.T) {
8788
session := loginUser(t, "user2")
8889
testPullCreate(t, session, "user2", "test_codeowner", false, repo.DefaultBranch, "codeowner-basebranch", "Test Pull Request")
8990

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

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

0 commit comments

Comments
 (0)