Skip to content

Commit 2526978

Browse files
committed
Fix deadlock
1 parent 42662eb commit 2526978

File tree

4 files changed

+75
-24
lines changed

4 files changed

+75
-24
lines changed

services/issue/assignee.go

Lines changed: 20 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -226,16 +226,33 @@ func TeamReviewRequest(ctx context.Context, issue *issues_model.Issue, doer *use
226226
return nil, nil
227227
}
228228

229+
return comment, teamReviewRequestNotify(ctx, issue, doer, reviewer, isAdd, comment)
230+
}
231+
232+
func ReviewRequestNotify(ctx context.Context, issue *issues_model.Issue, doer *user_model.User, reviewNotifers []*ReviewRequestNotifier) {
233+
for _, reviewNotifer := range reviewNotifers {
234+
if reviewNotifer.Reviwer != nil {
235+
notify_service.PullRequestReviewRequest(ctx, issue.Poster, issue, reviewNotifer.Reviwer, reviewNotifer.IsAdd, reviewNotifer.Comment)
236+
} else if reviewNotifer.ReviewTeam != nil {
237+
if err := teamReviewRequestNotify(ctx, issue, issue.Poster, reviewNotifer.ReviewTeam, reviewNotifer.IsAdd, reviewNotifer.Comment); err != nil {
238+
log.Error("teamReviewRequestNotify: %v", err)
239+
}
240+
}
241+
}
242+
}
243+
244+
// teamReviewRequestNotify notify all user in this team
245+
func teamReviewRequestNotify(ctx context.Context, issue *issues_model.Issue, doer *user_model.User, reviewer *organization.Team, isAdd bool, comment *issues_model.Comment) error {
229246
// notify all user in this team
230247
if err := comment.LoadIssue(ctx); err != nil {
231-
return nil, err
248+
return err
232249
}
233250

234251
members, err := organization.GetTeamMembers(ctx, &organization.SearchMembersOptions{
235252
TeamID: reviewer.ID,
236253
})
237254
if err != nil {
238-
return nil, err
255+
return err
239256
}
240257

241258
for _, member := range members {
@@ -246,7 +263,7 @@ func TeamReviewRequest(ctx context.Context, issue *issues_model.Issue, doer *use
246263
notify_service.PullRequestReviewRequest(ctx, doer, issue, member, isAdd, comment)
247264
}
248265

249-
return comment, err
266+
return err
250267
}
251268

252269
// CanDoerChangeReviewRequests returns if the doer can add/remove review requests of a PR

services/issue/issue.go

Lines changed: 15 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -85,17 +85,27 @@ func ChangeTitle(ctx context.Context, issue *issues_model.Issue, doer *user_mode
8585
}
8686
}
8787

88-
if err := issues_model.ChangeIssueTitle(ctx, issue, doer, oldTitle); err != nil {
89-
return err
90-
}
88+
var reviewNotifers []*ReviewRequestNotifier
9189

92-
if issue.IsPull && issues_model.HasWorkInProgressPrefix(oldTitle) && !issues_model.HasWorkInProgressPrefix(title) {
93-
if err := PullRequestCodeOwnersReview(ctx, issue, issue.PullRequest); err != nil {
90+
if err := db.WithTx(ctx, func(ctx context.Context) error {
91+
if err := issues_model.ChangeIssueTitle(ctx, issue, doer, oldTitle); err != nil {
9492
return err
9593
}
94+
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+
}
101+
}
102+
return nil
103+
}); err != nil {
104+
return err
96105
}
97106

98107
notify_service.IssueChangeTitle(ctx, doer, issue, oldTitle)
108+
ReviewRequestNotify(ctx, issue, issue.Poster, reviewNotifers)
99109

100110
return nil
101111
}

services/issue/pull.go

Lines changed: 35 additions & 14 deletions
Original file line numberDiff line numberDiff line change
@@ -33,34 +33,41 @@ func getMergeBase(repo *git.Repository, pr *issues_model.PullRequest, baseBranch
3333
return mergeBase, err
3434
}
3535

36-
func PullRequestCodeOwnersReview(ctx context.Context, pull *issues_model.Issue, pr *issues_model.PullRequest) error {
36+
type ReviewRequestNotifier struct {
37+
Comment *issues_model.Comment
38+
IsAdd bool
39+
Reviwer *user_model.User
40+
ReviewTeam *org_model.Team
41+
}
42+
43+
func PullRequestCodeOwnersReview(ctx context.Context, pull *issues_model.Issue, pr *issues_model.PullRequest) ([]*ReviewRequestNotifier, error) {
3744
files := []string{"CODEOWNERS", "docs/CODEOWNERS", ".gitea/CODEOWNERS"}
3845

3946
if pr.IsWorkInProgress(ctx) {
40-
return nil
47+
return nil, nil
4148
}
4249

4350
if err := pr.LoadHeadRepo(ctx); err != nil {
44-
return err
51+
return nil, err
4552
}
4653

4754
if pr.HeadRepo.IsFork {
48-
return nil
55+
return nil, nil
4956
}
5057

5158
if err := pr.LoadBaseRepo(ctx); err != nil {
52-
return err
59+
return nil, err
5360
}
5461

5562
repo, err := gitrepo.OpenRepository(ctx, pr.BaseRepo)
5663
if err != nil {
57-
return err
64+
return nil, err
5865
}
5966
defer repo.Close()
6067

6168
commit, err := repo.GetBranchCommit(pr.BaseRepo.DefaultBranch)
6269
if err != nil {
63-
return err
70+
return nil, err
6471
}
6572

6673
var data string
@@ -78,14 +85,14 @@ func PullRequestCodeOwnersReview(ctx context.Context, pull *issues_model.Issue,
7885
// get the mergebase
7986
mergeBase, err := getMergeBase(repo, pr, git.BranchPrefix+pr.BaseBranch, pr.GetGitRefName())
8087
if err != nil {
81-
return err
88+
return nil, err
8289
}
8390

8491
// https://github.com/go-gitea/gitea/issues/29763, we need to get the files changed
8592
// between the merge base and the head commit but not the base branch and the head commit
8693
changedFiles, err := repo.GetFilesChangedBetween(mergeBase, pr.HeadCommitID)
8794
if err != nil {
88-
return err
95+
return nil, err
8996
}
9097

9198
uniqUsers := make(map[int64]*user_model.User)
@@ -103,20 +110,34 @@ func PullRequestCodeOwnersReview(ctx context.Context, pull *issues_model.Issue,
103110
}
104111
}
105112

113+
notifiers := make([]*ReviewRequestNotifier, 0, len(uniqUsers)+len(uniqTeams))
114+
106115
for _, u := range uniqUsers {
107116
if u.ID != pull.Poster.ID {
108-
if _, err := ReviewRequest(ctx, pull, pull.Poster, u, true); err != nil {
117+
comment, err := issues_model.AddReviewRequest(ctx, pull, pull.Poster, u)
118+
if err != nil {
109119
log.Warn("Failed add assignee user: %s to PR review: %s#%d, error: %s", u.Name, pr.BaseRepo.Name, pr.ID, err)
110-
return err
120+
return nil, err
111121
}
122+
notifiers = append(notifiers, &ReviewRequestNotifier{
123+
Comment: comment,
124+
IsAdd: true,
125+
Reviwer: pull.Poster,
126+
})
112127
}
113128
}
114129
for _, t := range uniqTeams {
115-
if _, err := TeamReviewRequest(ctx, pull, pull.Poster, t, true); err != nil {
130+
comment, err := issues_model.AddTeamReviewRequest(ctx, pull, t, pull.Poster)
131+
if err != nil {
116132
log.Warn("Failed add assignee team: %s to PR review: %s#%d, error: %s", t.Name, pr.BaseRepo.Name, pr.ID, err)
117-
return err
133+
return nil, err
118134
}
135+
notifiers = append(notifiers, &ReviewRequestNotifier{
136+
Comment: comment,
137+
IsAdd: true,
138+
ReviewTeam: t,
139+
})
119140
}
120141

121-
return nil
142+
return notifiers, nil
122143
}

services/pull/pull.go

Lines changed: 5 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -77,6 +77,7 @@ func NewPullRequest(ctx context.Context, repo *repo_model.Repository, issue *iss
7777
}
7878
defer baseGitRepo.Close()
7979

80+
var reviewNotifers []*issue_service.ReviewRequestNotifier
8081
if err := db.WithTx(ctx, func(ctx context.Context) error {
8182
if err := issues_model.NewPullRequest(ctx, repo, issue, labelIDs, uuids, pr); err != nil {
8283
return err
@@ -136,7 +137,8 @@ func NewPullRequest(ctx context.Context, repo *repo_model.Repository, issue *iss
136137
}
137138

138139
if !pr.IsWorkInProgress(ctx) {
139-
if err := issue_service.PullRequestCodeOwnersReview(ctx, issue, pr); err != nil {
140+
reviewNotifers, err = issue_service.PullRequestCodeOwnersReview(ctx, issue, pr)
141+
if err != nil {
140142
return err
141143
}
142144
}
@@ -150,11 +152,12 @@ func NewPullRequest(ctx context.Context, repo *repo_model.Repository, issue *iss
150152
}
151153
baseGitRepo.Close() // close immediately to avoid notifications will open the repository again
152154

155+
issue_service.ReviewRequestNotify(ctx, issue, issue.Poster, reviewNotifers)
156+
153157
mentions, err := issues_model.FindAndUpdateIssueMentions(ctx, issue, issue.Poster, issue.Content)
154158
if err != nil {
155159
return err
156160
}
157-
158161
notify_service.NewPullRequest(ctx, pr, mentions)
159162
if len(issue.Labels) > 0 {
160163
notify_service.IssueChangeLabels(ctx, issue.Poster, issue, issue.Labels, nil)

0 commit comments

Comments
 (0)