aboutsummaryrefslogtreecommitdiffstats
path: root/modules/indexer/issues
diff options
context:
space:
mode:
authorNanguan Lin <70063547+lng2020@users.noreply.github.com>2023-09-15 00:35:53 +0800
committerGitHub <noreply@github.com>2023-09-14 12:35:53 -0400
commit0de09d3afcb5394cbd97e4a1c5609eb8b2acb6cf (patch)
tree21316949adef302ae72ea7e54d198db15a50022b /modules/indexer/issues
parent8d0343e028cf5b1794ba2bfebf23c863e340d108 (diff)
downloadgitea-0de09d3afcb5394cbd97e4a1c5609eb8b2acb6cf.tar.gz
gitea-0de09d3afcb5394cbd97e4a1c5609eb8b2acb6cf.zip
Remove the useless function `GetUserIssueStats` and move relevant tests to `indexer_test.go` (#27067)
Since the issue indexer has been refactored, the issue overview webpage is built by the `buildIssueOverview` function and underlying `indexer.Search` function and `GetIssueStats` instead of `GetUserIssueStats`. So the function is no longer used. I moved the relevant tests to `indexer_test.go` and since the search option changed from `IssueOptions` to `SearchOptions`, most of the tests are useless now. We need more tests about the db indexer because those tests are highly connected with the issue overview webpage and now this page has several bugs. Any advice about those test cases is appreciated. --------- Co-authored-by: CaiCandong <50507092+CaiCandong@users.noreply.github.com>
Diffstat (limited to 'modules/indexer/issues')
-rw-r--r--modules/indexer/issues/indexer_test.go83
1 files changed, 82 insertions, 1 deletions
diff --git a/modules/indexer/issues/indexer_test.go b/modules/indexer/issues/indexer_test.go
index a4e1c899fc..c3a6d88685 100644
--- a/modules/indexer/issues/indexer_test.go
+++ b/modules/indexer/issues/indexer_test.go
@@ -5,6 +5,7 @@ package issues
import (
"context"
+ "fmt"
"path"
"path/filepath"
"testing"
@@ -13,6 +14,7 @@ import (
"code.gitea.io/gitea/models/unittest"
"code.gitea.io/gitea/modules/indexer/issues/bleve"
"code.gitea.io/gitea/modules/setting"
+ "code.gitea.io/gitea/modules/util"
_ "code.gitea.io/gitea/models"
_ "code.gitea.io/gitea/models/actions"
@@ -89,7 +91,7 @@ func TestBleveSearchIssues(t *testing.T) {
})
}
-func TestDBSearchIssues(t *testing.T) {
+func TestDBSearchIssuesWithKeyword(t *testing.T) {
assert.NoError(t, unittest.PrepareTestDatabase())
setting.Indexer.IssueType = "db"
@@ -131,3 +133,82 @@ func TestDBSearchIssues(t *testing.T) {
assert.EqualValues(t, []int64{1}, ids)
})
}
+
+// TODO: add more tests
+func TestDBSearchIssueWithoutKeyword(t *testing.T) {
+ assert.NoError(t, unittest.PrepareTestDatabase())
+
+ setting.Indexer.IssueType = "db"
+ InitIssueIndexer(true)
+
+ int64Pointer := func(x int64) *int64 {
+ return &x
+ }
+ for _, test := range []struct {
+ opts SearchOptions
+ expectedIDs []int64
+ }{
+ {
+ SearchOptions{
+ RepoIDs: []int64{1},
+ },
+ []int64{11, 5, 3, 2, 1},
+ },
+ {
+ SearchOptions{
+ RepoIDs: []int64{1},
+ AssigneeID: int64Pointer(1),
+ },
+ []int64{1},
+ },
+ {
+ SearchOptions{
+ RepoIDs: []int64{1},
+ PosterID: int64Pointer(1),
+ },
+ []int64{11, 3, 2, 1},
+ },
+ {
+ SearchOptions{
+ RepoIDs: []int64{1},
+ IsClosed: util.OptionalBoolFalse,
+ },
+ []int64{11, 3, 2, 1},
+ },
+ {
+ SearchOptions{
+ RepoIDs: []int64{1},
+ IsClosed: util.OptionalBoolTrue,
+ },
+ []int64{5},
+ },
+ {
+ SearchOptions{
+ RepoIDs: []int64{1},
+ },
+ []int64{11, 5, 3, 2, 1},
+ },
+ {
+ SearchOptions{
+ RepoIDs: []int64{1},
+ AssigneeID: int64Pointer(1),
+ },
+ []int64{1},
+ },
+ {
+ SearchOptions{
+ RepoIDs: []int64{1},
+ PosterID: int64Pointer(1),
+ },
+ []int64{11, 3, 2, 1},
+ },
+ } {
+ t.Run(fmt.Sprintf("%#v", test.opts), func(t *testing.T) {
+ issueIDs, _, err := SearchIssues(context.TODO(), &test.opts)
+ if !assert.NoError(t, err) {
+ return
+ }
+ assert.Equal(t, test.expectedIDs, issueIDs)
+ })
+ }
+}