forked from mirrors/gitea
72f6d5c882
* Restrict repository indexing by file extension * Use REPO_EXTENSIONS_LIST_INCLUDE instead of REPO_EXTENSIONS_LIST_EXCLUDE and have a more flexible extension pattern * Corrected to pass lint gosimple * Add wildcard support to REPO_INDEXER_EXTENSIONS * This reverts commit 72a650c8e42f4abf59d5df7cd5dc27b451494cc6. * Add wildcard support to REPO_INDEXER_EXTENSIONS (no make vendor) * Simplify isIndexable() for better clarity * Add gobwas/glob to vendors * manually set appengine new release * Implement better REPO_INDEXER_INCLUDE and REPO_INDEXER_EXCLUDE * Add unit and integration tests * Update app.ini.sample and reword config-cheat-sheet * Add doc page and correct app.ini.sample * Some polish on the doc * Simplify code as suggested by @lafriks
75 lines
2.3 KiB
Go
75 lines
2.3 KiB
Go
// Copyright 2017 The Gitea Authors. All rights reserved.
|
|
// Use of this source code is governed by a MIT-style
|
|
// license that can be found in the LICENSE file.
|
|
|
|
package integrations
|
|
|
|
import (
|
|
"net/http"
|
|
"testing"
|
|
"time"
|
|
|
|
"code.gitea.io/gitea/models"
|
|
"code.gitea.io/gitea/modules/setting"
|
|
|
|
"github.com/PuerkitoBio/goquery"
|
|
"github.com/stretchr/testify/assert"
|
|
)
|
|
|
|
func resultFilenames(t testing.TB, doc *HTMLDoc) []string {
|
|
resultsSelection := doc.doc.Find(".repository.search")
|
|
assert.EqualValues(t, 1, resultsSelection.Length(),
|
|
"Invalid template (repo search template has changed?)")
|
|
filenameSelections := resultsSelection.Find(".repo-search-result").Find(".header").Find("span.file")
|
|
result := make([]string, filenameSelections.Length())
|
|
filenameSelections.Each(func(i int, selection *goquery.Selection) {
|
|
result[i] = selection.Text()
|
|
})
|
|
return result
|
|
}
|
|
|
|
func TestSearchRepo(t *testing.T) {
|
|
prepareTestEnv(t)
|
|
|
|
repo, err := models.GetRepositoryByOwnerAndName("user2", "repo1")
|
|
assert.NoError(t, err)
|
|
|
|
executeIndexer(t, repo, models.UpdateRepoIndexer)
|
|
|
|
testSearch(t, "/user2/repo1/search?q=Description&page=1", []string{"README.md"})
|
|
|
|
setting.Indexer.IncludePatterns = setting.IndexerGlobFromString("**.txt")
|
|
setting.Indexer.ExcludePatterns = setting.IndexerGlobFromString("**/y/**")
|
|
|
|
repo, err = models.GetRepositoryByOwnerAndName("user2", "glob")
|
|
assert.NoError(t, err)
|
|
|
|
executeIndexer(t, repo, models.DeleteRepoFromIndexer)
|
|
executeIndexer(t, repo, models.UpdateRepoIndexer)
|
|
|
|
testSearch(t, "/user2/glob/search?q=loren&page=1", []string{"a.txt"})
|
|
testSearch(t, "/user2/glob/search?q=file3&page=1", []string{"x/b.txt"})
|
|
testSearch(t, "/user2/glob/search?q=file4&page=1", []string{})
|
|
testSearch(t, "/user2/glob/search?q=file5&page=1", []string{})
|
|
}
|
|
|
|
func testSearch(t *testing.T, url string, expected []string) {
|
|
req := NewRequestf(t, "GET", url)
|
|
resp := MakeRequest(t, req, http.StatusOK)
|
|
|
|
filenames := resultFilenames(t, NewHTMLParser(t, resp.Body))
|
|
assert.EqualValues(t, expected, filenames)
|
|
}
|
|
|
|
func executeIndexer(t *testing.T, repo *models.Repository, op func(*models.Repository, ...chan<- error)) {
|
|
waiter := make(chan error, 1)
|
|
op(repo, waiter)
|
|
|
|
select {
|
|
case err := <-waiter:
|
|
assert.NoError(t, err)
|
|
case <-time.After(1 * time.Minute):
|
|
assert.Fail(t, "Repository indexer took too long")
|
|
}
|
|
}
|