]> source.dussan.org Git - gitea.git/commitdiff
Fix orphaned objects deletion bug (#15657)
authorLunny Xiao <xiaolunwen@gmail.com>
Fri, 30 Apr 2021 18:08:46 +0000 (02:08 +0800)
committerGitHub <noreply@github.com>
Fri, 30 Apr 2021 18:08:46 +0000 (20:08 +0200)
* Fix orphaned objects deletion bug

* extend test

Co-authored-by: 6543 <6543@obermui.de>
models/consistency.go
models/consistency_test.go [new file with mode: 0644]

index a1a2bf7bb5fa6a1ac120324dfd3e26f17b2c0bd3..77a8018266e5121698590bc32e3069cc7c3f5f39 100644 (file)
@@ -296,11 +296,15 @@ func CountOrphanedObjects(subject, refobject, joinCond string) (int64, error) {
 
 // DeleteOrphanedObjects delete subjects with have no existing refobject anymore
 func DeleteOrphanedObjects(subject, refobject, joinCond string) error {
-       _, err := x.In("id", builder.Select("`"+subject+"`.id").
+       subQuery := builder.Select("`"+subject+"`.id").
                From("`"+subject+"`").
                Join("LEFT", "`"+refobject+"`", joinCond).
-               Where(builder.IsNull{"`" + refobject + "`.id"})).
-               Delete("`" + subject + "`")
+               Where(builder.IsNull{"`" + refobject + "`.id"})
+       sql, args, err := builder.Delete(builder.In("id", subQuery)).From("`" + subject + "`").ToSQL()
+       if err != nil {
+               return err
+       }
+       _, err = x.Exec(append([]interface{}{sql}, args...)...)
        return err
 }
 
diff --git a/models/consistency_test.go b/models/consistency_test.go
new file mode 100644 (file)
index 0000000..0a91d9f
--- /dev/null
@@ -0,0 +1,32 @@
+// Copyright 2021 Gitea. All rights reserved.
+// Use of this source code is governed by a MIT-style
+// license that can be found in the LICENSE file.
+
+package models
+
+import (
+       "testing"
+
+       "github.com/stretchr/testify/assert"
+)
+
+func TestDeleteOrphanedObjects(t *testing.T) {
+       assert.NoError(t, PrepareTestDatabase())
+
+       countBefore, err := x.Count(&PullRequest{})
+       assert.NoError(t, err)
+
+       _, err = x.Insert(&PullRequest{IssueID: 1000}, &PullRequest{IssueID: 1001}, &PullRequest{IssueID: 1003})
+       assert.NoError(t, err)
+
+       orphaned, err := CountOrphanedObjects("pull_request", "issue", "pull_request.issue_id=issue.id")
+       assert.NoError(t, err)
+       assert.EqualValues(t, 3, orphaned)
+
+       err = DeleteOrphanedObjects("pull_request", "issue", "pull_request.issue_id=issue.id")
+       assert.NoError(t, err)
+
+       countAfter, err := x.Count(&PullRequest{})
+       assert.NoError(t, err)
+       assert.EqualValues(t, countBefore, countAfter)
+}