Skip to content

Commit

Permalink
[BugFix] remove nil inserts in models (#11096)
Browse files Browse the repository at this point in the history
* Fix InsertReleases Nil Insert on Attachments

* FIX "No element on slice when insert" & smal refactor

* again

* impruve

* rm useles newline

* Apply suggestions from code review

Co-Authored-By: zeripath <art27@cantab.net>

* process insert as a whole

Co-authored-by: zeripath <art27@cantab.net>
  • Loading branch information
6543 and zeripath authored Apr 17, 2020
1 parent 0010fde commit 12960b9
Show file tree
Hide file tree
Showing 2 changed files with 32 additions and 17 deletions.
31 changes: 20 additions & 11 deletions models/migrate.go
Original file line number Diff line number Diff line change
Expand Up @@ -64,15 +64,20 @@ func insertIssue(sess *xorm.Session, issue *Issue) error {
})
labelIDs = append(labelIDs, label.ID)
}
if _, err := sess.Insert(issueLabels); err != nil {
return err
if len(issueLabels) > 0 {
if _, err := sess.Insert(issueLabels); err != nil {
return err
}
}

for _, reaction := range issue.Reactions {
reaction.IssueID = issue.ID
}
if _, err := sess.Insert(issue.Reactions); err != nil {
return err

if len(issue.Reactions) > 0 {
if _, err := sess.Insert(issue.Reactions); err != nil {
return err
}
}

cols := make([]string, 0)
Expand Down Expand Up @@ -151,8 +156,10 @@ func InsertIssueComments(comments []*Comment) error {
reaction.IssueID = comment.IssueID
reaction.CommentID = comment.ID
}
if _, err := sess.Insert(comment.Reactions); err != nil {
return err
if len(comment.Reactions) > 0 {
if _, err := sess.Insert(comment.Reactions); err != nil {
return err
}
}
}

Expand Down Expand Up @@ -196,12 +203,14 @@ func InsertReleases(rels ...*Release) error {
return err
}

for i := 0; i < len(rel.Attachments); i++ {
rel.Attachments[i].ReleaseID = rel.ID
}
if len(rel.Attachments) > 0 {
for i := range rel.Attachments {
rel.Attachments[i].ReleaseID = rel.ID
}

if _, err := sess.NoAutoTime().Insert(rel.Attachments); err != nil {
return err
if _, err := sess.NoAutoTime().Insert(rel.Attachments); err != nil {
return err
}
}
}

Expand Down
18 changes: 12 additions & 6 deletions modules/migrations/gitea.go
Original file line number Diff line number Diff line change
Expand Up @@ -393,13 +393,16 @@ func (g *GiteaLocalUploader) CreateIssues(issues ...*base.Issue) error {
iss = append(iss, &is)
}

err := models.InsertIssues(iss...)
if err != nil {
return err
}
for _, is := range iss {
g.issues.Store(is.Index, is.ID)
if len(iss) > 0 {
if err := models.InsertIssues(iss...); err != nil {
return err
}

for _, is := range iss {
g.issues.Store(is.Index, is.ID)
}
}

return nil
}

Expand Down Expand Up @@ -478,6 +481,9 @@ func (g *GiteaLocalUploader) CreateComments(comments ...*base.Comment) error {
cms = append(cms, &cm)
}

if len(cms) == 0 {
return nil
}
return models.InsertIssueComments(cms)
}

Expand Down

0 comments on commit 12960b9

Please sign in to comment.