mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-27 00:23:41 +09:00 
			
		
		
		
	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>
		
			
				
	
	
		
			215 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			215 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright 2019 The Gitea Authors. All rights reserved.
 | |
| // SPDX-License-Identifier: MIT
 | |
| 
 | |
| package issues
 | |
| 
 | |
| import (
 | |
| 	"context"
 | |
| 	"fmt"
 | |
| 	"path"
 | |
| 	"path/filepath"
 | |
| 	"testing"
 | |
| 	"time"
 | |
| 
 | |
| 	"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"
 | |
| 	_ "code.gitea.io/gitea/models/activities"
 | |
| 
 | |
| 	"github.com/stretchr/testify/assert"
 | |
| )
 | |
| 
 | |
| func TestMain(m *testing.M) {
 | |
| 	unittest.MainTest(m, &unittest.TestOptions{
 | |
| 		GiteaRootPath: filepath.Join("..", "..", ".."),
 | |
| 	})
 | |
| }
 | |
| 
 | |
| func TestBleveSearchIssues(t *testing.T) {
 | |
| 	assert.NoError(t, unittest.PrepareTestDatabase())
 | |
| 	setting.CfgProvider, _ = setting.NewConfigProviderFromData("")
 | |
| 
 | |
| 	tmpIndexerDir := t.TempDir()
 | |
| 
 | |
| 	setting.CfgProvider.Section("queue.issue_indexer").Key("DATADIR").MustString(path.Join(tmpIndexerDir, "issues.queue"))
 | |
| 
 | |
| 	oldIssuePath := setting.Indexer.IssuePath
 | |
| 	setting.Indexer.IssuePath = path.Join(tmpIndexerDir, "issues.queue")
 | |
| 	defer func() {
 | |
| 		setting.Indexer.IssuePath = oldIssuePath
 | |
| 	}()
 | |
| 
 | |
| 	setting.Indexer.IssueType = "bleve"
 | |
| 	setting.LoadQueueSettings()
 | |
| 	InitIssueIndexer(true)
 | |
| 	defer func() {
 | |
| 		if bleveIndexer, ok := (*globalIndexer.Load()).(*bleve.Indexer); ok {
 | |
| 			bleveIndexer.Close()
 | |
| 		}
 | |
| 	}()
 | |
| 
 | |
| 	time.Sleep(5 * time.Second)
 | |
| 
 | |
| 	t.Run("issue2", func(t *testing.T) {
 | |
| 		ids, _, err := SearchIssues(context.TODO(), &SearchOptions{
 | |
| 			Keyword: "issue2",
 | |
| 			RepoIDs: []int64{1},
 | |
| 		})
 | |
| 		assert.NoError(t, err)
 | |
| 		assert.EqualValues(t, []int64{2}, ids)
 | |
| 	})
 | |
| 
 | |
| 	t.Run("first", func(t *testing.T) {
 | |
| 		ids, _, err := SearchIssues(context.TODO(), &SearchOptions{
 | |
| 			Keyword: "first",
 | |
| 			RepoIDs: []int64{1},
 | |
| 		})
 | |
| 		assert.NoError(t, err)
 | |
| 		assert.EqualValues(t, []int64{1}, ids)
 | |
| 	})
 | |
| 
 | |
| 	t.Run("for", func(t *testing.T) {
 | |
| 		ids, _, err := SearchIssues(context.TODO(), &SearchOptions{
 | |
| 			Keyword: "for",
 | |
| 			RepoIDs: []int64{1},
 | |
| 		})
 | |
| 		assert.NoError(t, err)
 | |
| 		assert.ElementsMatch(t, []int64{1, 2, 3, 5, 11}, ids)
 | |
| 	})
 | |
| 
 | |
| 	t.Run("good", func(t *testing.T) {
 | |
| 		ids, _, err := SearchIssues(context.TODO(), &SearchOptions{
 | |
| 			Keyword: "good",
 | |
| 			RepoIDs: []int64{1},
 | |
| 		})
 | |
| 		assert.NoError(t, err)
 | |
| 		assert.EqualValues(t, []int64{1}, ids)
 | |
| 	})
 | |
| }
 | |
| 
 | |
| func TestDBSearchIssuesWithKeyword(t *testing.T) {
 | |
| 	assert.NoError(t, unittest.PrepareTestDatabase())
 | |
| 
 | |
| 	setting.Indexer.IssueType = "db"
 | |
| 	InitIssueIndexer(true)
 | |
| 
 | |
| 	t.Run("issue2", func(t *testing.T) {
 | |
| 		ids, _, err := SearchIssues(context.TODO(), &SearchOptions{
 | |
| 			Keyword: "issue2",
 | |
| 			RepoIDs: []int64{1},
 | |
| 		})
 | |
| 		assert.NoError(t, err)
 | |
| 		assert.EqualValues(t, []int64{2}, ids)
 | |
| 	})
 | |
| 
 | |
| 	t.Run("first", func(t *testing.T) {
 | |
| 		ids, _, err := SearchIssues(context.TODO(), &SearchOptions{
 | |
| 			Keyword: "first",
 | |
| 			RepoIDs: []int64{1},
 | |
| 		})
 | |
| 		assert.NoError(t, err)
 | |
| 		assert.EqualValues(t, []int64{1}, ids)
 | |
| 	})
 | |
| 
 | |
| 	t.Run("for", func(t *testing.T) {
 | |
| 		ids, _, err := SearchIssues(context.TODO(), &SearchOptions{
 | |
| 			Keyword: "for",
 | |
| 			RepoIDs: []int64{1},
 | |
| 		})
 | |
| 		assert.NoError(t, err)
 | |
| 		assert.ElementsMatch(t, []int64{1, 2, 3, 5, 11}, ids)
 | |
| 	})
 | |
| 
 | |
| 	t.Run("good", func(t *testing.T) {
 | |
| 		ids, _, err := SearchIssues(context.TODO(), &SearchOptions{
 | |
| 			Keyword: "good",
 | |
| 			RepoIDs: []int64{1},
 | |
| 		})
 | |
| 		assert.NoError(t, err)
 | |
| 		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)
 | |
| 		})
 | |
| 	}
 | |
| }
 |