Fix milestone completness calculation when migrating (#7725)

This commit is contained in:
Lauris BH 2019-08-03 21:38:42 +03:00 committed by GitHub
parent 4fe490f062
commit 6c0c5c5310
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -62,38 +62,50 @@ func insertIssue(sess *xorm.Session, issue *Issue) error {
if _, err := sess.Insert(issueLabels); err != nil { if _, err := sess.Insert(issueLabels); err != nil {
return err return err
} }
cols := make([]string, 0)
if !issue.IsPull { if !issue.IsPull {
sess.ID(issue.RepoID).Incr("num_issues") sess.ID(issue.RepoID).Incr("num_issues")
cols = append(cols, "num_issues")
if issue.IsClosed { if issue.IsClosed {
sess.Incr("num_closed_issues") sess.Incr("num_closed_issues")
cols = append(cols, "num_closed_issues")
} }
} else { } else {
sess.ID(issue.RepoID).Incr("num_pulls") sess.ID(issue.RepoID).Incr("num_pulls")
cols = append(cols, "num_pulls")
if issue.IsClosed { if issue.IsClosed {
sess.Incr("num_closed_pulls") sess.Incr("num_closed_pulls")
cols = append(cols, "num_closed_pulls")
} }
} }
if _, err := sess.NoAutoTime().Update(issue.Repo); err != nil { if _, err := sess.NoAutoTime().Cols(cols...).Update(issue.Repo); err != nil {
return err return err
} }
cols = []string{"num_issues"}
sess.Incr("num_issues") sess.Incr("num_issues")
if issue.IsClosed { if issue.IsClosed {
sess.Incr("num_closed_issues") sess.Incr("num_closed_issues")
cols = append(cols, "num_closed_issues")
} }
if _, err := sess.In("id", labelIDs).NoAutoTime().Update(new(Label)); err != nil { if _, err := sess.In("id", labelIDs).NoAutoTime().Cols(cols...).Update(new(Label)); err != nil {
return err return err
} }
if issue.MilestoneID > 0 { if issue.MilestoneID > 0 {
cols = []string{"num_issues"}
sess.Incr("num_issues") sess.Incr("num_issues")
cl := "num_closed_issues"
if issue.IsClosed { if issue.IsClosed {
sess.Incr("num_closed_issues") sess.Incr("num_closed_issues")
cols = append(cols, "num_closed_issues")
cl = "(num_closed_issues + 1)"
} }
if _, err := sess.ID(issue.MilestoneID). if _, err := sess.ID(issue.MilestoneID).
SetExpr("completeness", "num_closed_issues * 100 / num_issues"). SetExpr("completeness", cl+" * 100 / (num_issues + 1)").
NoAutoTime(). NoAutoTime().Cols(cols...).
Update(new(Milestone)); err != nil { Update(new(Milestone)); err != nil {
return err return err
} }