Skip to content

Commit 62a3c84

Browse files
authored
Fix migration v111 (#12868)
1 parent 3a02f08 commit 62a3c84

File tree

2 files changed

+43
-17
lines changed

2 files changed

+43
-17
lines changed

models/migrations/v111.go

Lines changed: 34 additions & 15 deletions
Original file line numberDiff line numberDiff line change
@@ -11,7 +11,6 @@ import (
1111
)
1212

1313
func addBranchProtectionCanPushAndEnableWhitelist(x *xorm.Engine) error {
14-
1514
type ProtectedBranch struct {
1615
CanPush bool `xorm:"NOT NULL DEFAULT false"`
1716
EnableApprovalsWhitelist bool `xorm:"NOT NULL DEFAULT false"`
@@ -23,29 +22,26 @@ func addBranchProtectionCanPushAndEnableWhitelist(x *xorm.Engine) error {
2322
Official bool `xorm:"NOT NULL DEFAULT false"`
2423
}
2524

26-
sess := x.NewSession()
27-
defer sess.Close()
28-
29-
if err := sess.Sync2(new(ProtectedBranch)); err != nil {
25+
if err := x.Sync2(new(ProtectedBranch)); err != nil {
3026
return err
3127
}
3228

33-
if err := sess.Sync2(new(Review)); err != nil {
29+
if err := x.Sync2(new(Review)); err != nil {
3430
return err
3531
}
3632

37-
if _, err := sess.Exec("UPDATE `protected_branch` SET `enable_whitelist` = ? WHERE enable_whitelist IS NULL", false); err != nil {
33+
if _, err := x.Exec("UPDATE `protected_branch` SET `enable_whitelist` = ? WHERE enable_whitelist IS NULL", false); err != nil {
3834
return err
3935
}
40-
if _, err := sess.Exec("UPDATE `protected_branch` SET `can_push` = `enable_whitelist`"); err != nil {
36+
if _, err := x.Exec("UPDATE `protected_branch` SET `can_push` = `enable_whitelist`"); err != nil {
4137
return err
4238
}
43-
if _, err := sess.Exec("UPDATE `protected_branch` SET `enable_approvals_whitelist` = ? WHERE `required_approvals` > ?", true, 0); err != nil {
39+
if _, err := x.Exec("UPDATE `protected_branch` SET `enable_approvals_whitelist` = ? WHERE `required_approvals` > ?", true, 0); err != nil {
4440
return err
4541
}
4642

4743
var pageSize int64 = 20
48-
qresult, err := sess.QueryInterface("SELECT max(id) as max_id FROM issue")
44+
qresult, err := x.QueryInterface("SELECT max(id) as max_id FROM issue")
4945
if err != nil {
5046
return err
5147
}
@@ -57,34 +53,57 @@ func addBranchProtectionCanPushAndEnableWhitelist(x *xorm.Engine) error {
5753
}
5854
totalPages := totalIssues / pageSize
5955

56+
sess := x.NewSession()
57+
defer sess.Close()
58+
59+
if err := sess.Begin(); err != nil {
60+
return err
61+
}
62+
6063
// Find latest review of each user in each pull request, and set official field if appropriate
61-
reviews := []*models.Review{}
64+
6265
var page int64
66+
var count int
6367
for page = 0; page <= totalPages; page++ {
68+
reviews := []*models.Review{}
6469
if err := sess.SQL("SELECT * FROM review WHERE id IN (SELECT max(id) as id FROM review WHERE issue_id > ? AND issue_id <= ? AND type in (?, ?) GROUP BY issue_id, reviewer_id)",
6570
page*pageSize, (page+1)*pageSize, models.ReviewTypeApprove, models.ReviewTypeReject).
6671
Find(&reviews); err != nil {
6772
return err
6873
}
6974

7075
for _, review := range reviews {
71-
if err := review.LoadAttributes(); err != nil {
76+
if err := review.LoadAttributesX(sess); err != nil {
7277
// Error might occur if user or issue doesn't exist, ignore it.
7378
continue
7479
}
75-
official, err := models.IsOfficialReviewer(review.Issue, review.Reviewer)
80+
official, err := models.IsOfficialReviewerX(sess, review.Issue, review.Reviewer)
7681
if err != nil {
7782
// Branch might not be proteced or other error, ignore it.
7883
continue
7984
}
8085
review.Official = official
8186

87+
count++
88+
8289
if _, err := sess.ID(review.ID).Cols("official").Update(review); err != nil {
8390
return err
8491
}
85-
}
8692

93+
if count == 100 {
94+
if err := sess.Commit(); err != nil {
95+
return err
96+
}
97+
count = 0
98+
if err := sess.Begin(); err != nil {
99+
return err
100+
}
101+
}
102+
}
87103
}
88104

89-
return sess.Commit()
105+
if count > 0 {
106+
return sess.Commit()
107+
}
108+
return nil
90109
}

models/review.go

Lines changed: 9 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -110,7 +110,8 @@ func (r *Review) LoadReviewer() error {
110110
return r.loadReviewer(x)
111111
}
112112

113-
func (r *Review) loadAttributes(e Engine) (err error) {
113+
// LoadAttributesX loads all attributes except CodeComments with an Engine parameter
114+
func (r *Review) LoadAttributesX(e Engine) (err error) {
114115
if err = r.loadIssue(e); err != nil {
115116
return
116117
}
@@ -125,7 +126,7 @@ func (r *Review) loadAttributes(e Engine) (err error) {
125126

126127
// LoadAttributes loads all attributes except CodeComments
127128
func (r *Review) LoadAttributes() error {
128-
return r.loadAttributes(x)
129+
return r.LoadAttributesX(x)
129130
}
130131

131132
func getReviewByID(e Engine, id int64) (*Review, error) {
@@ -203,6 +204,12 @@ func IsOfficialReviewer(issue *Issue, reviewer *User) (bool, error) {
203204
return isOfficialReviewer(x, issue, reviewer)
204205
}
205206

207+
// IsOfficialReviewerX check if reviewer can make official reviews in issue (counts towards required approvals)
208+
// with an Engine parameter
209+
func IsOfficialReviewerX(e Engine, issue *Issue, reviewer *User) (bool, error) {
210+
return isOfficialReviewer(x, issue, reviewer)
211+
}
212+
206213
func isOfficialReviewer(e Engine, issue *Issue, reviewer *User) (bool, error) {
207214
pr, err := getPullRequestByIssueID(e, issue.ID)
208215
if err != nil {

0 commit comments

Comments
 (0)