mirror of
https://codeberg.org/forgejo/forgejo.git
synced 2025-06-24 10:00:50 +00:00
An attempt at solving #7956. This (and rebuilding the index) seems enough to ensure the issue *appears* among the results. However, I couldn't figure out from [bleve docs](https://github.com/blevesearch/bleve/blob/master/docs/scoring.md) how to affect the scoring based on specific fields, or whether that is possible at all. Disclaimer: I've never written Go before, sorry 😅 take it as a quick PoC more than anything. ### Tests - I added test coverage for Go changes... - [x] in their respective `*_test.go` for unit tests. - [ ] in the `tests/integration` directory if it involves interactions with a live Forgejo server. - I added test coverage for JavaScript changes... - [ ] in `web_src/js/*.test.js` if it can be unit tested. - [ ] in `tests/e2e/*.test.e2e.js` if it requires interactions with a live Forgejo server (see also the [developer guide for JavaScript testing](https://codeberg.org/forgejo/forgejo/src/branch/forgejo/tests/e2e/README.md#end-to-end-tests)). ### Documentation - [ ] I created a pull request [to the documentation](https://codeberg.org/forgejo/docs) to explain to Forgejo users how to use this change. - [x] I did not document these changes and I do not expect someone else to do it. ### Release notes - [ ] I do not want this change to show in the release notes. - [x] I want the title to show in the release notes with a link to this pull request. - [ ] I want the content of the `release-notes/<pull request number>.md` to be be used for the release notes instead of the title. <!--start release-notes-assistant--> ## Release notes <!--URL:https://codeberg.org/forgejo/forgejo--> - Features - [PR](https://codeberg.org/forgejo/forgejo/pulls/7968): <!--number 7968 --><!--line 0 --><!--description QWRkIGlzc3VlIG51bWJlciB0byB0aGUgc2VhcmNoIGluZGV4LCByYW5rIG51bWJlciBhbmQgdGl0bGUgbWF0Y2hlcyBoaWdoZXIgKCM3OTU2KQ==-->Add issue number to the search index, rank number and title matches higher (#7956)<!--description--> <!--end release-notes-assistant--> Reviewed-on: https://codeberg.org/forgejo/forgejo/pulls/7968 Reviewed-by: Shiny Nematoda <snematoda@noreply.codeberg.org> Co-authored-by: Danko Aleksejevs <danko@very.lv> Co-committed-by: Danko Aleksejevs <danko@very.lv>
This commit is contained in:
parent
2529923dea
commit
905a5748a8
9 changed files with 100 additions and 14 deletions
|
@ -549,6 +549,55 @@ var cases = []*testIndexerCase{
|
|||
}), result.Total)
|
||||
},
|
||||
},
|
||||
{
|
||||
Name: "Index",
|
||||
SearchOptions: &internal.SearchOptions{
|
||||
Keyword: "13",
|
||||
SortBy: internal.SortByScore,
|
||||
RepoIDs: []int64{5},
|
||||
},
|
||||
ExpectedIDs: []int64{93}, // 93 = #13 in repo 5
|
||||
ExpectedTotal: 1,
|
||||
},
|
||||
{
|
||||
Name: "Index with prefix",
|
||||
SearchOptions: &internal.SearchOptions{
|
||||
Keyword: "#13",
|
||||
SortBy: internal.SortByScore,
|
||||
RepoIDs: []int64{5},
|
||||
},
|
||||
ExpectedIDs: []int64{93},
|
||||
ExpectedTotal: 1,
|
||||
},
|
||||
{
|
||||
Name: "Index and title boost",
|
||||
ExtraData: []*internal.IndexerData{
|
||||
{ID: 1001, Title: "re #13", RepoID: 5},
|
||||
{ID: 1002, Title: "re #1001", Content: "leave 13 alone. - 13", RepoID: 5},
|
||||
},
|
||||
SearchOptions: &internal.SearchOptions{
|
||||
Keyword: "!13",
|
||||
SortBy: internal.SortByScore,
|
||||
RepoIDs: []int64{5},
|
||||
},
|
||||
ExpectedIDs: []int64{93, 1001, 1002},
|
||||
ExpectedTotal: 3,
|
||||
},
|
||||
{
|
||||
Name: "Index exclude",
|
||||
ExtraData: []*internal.IndexerData{
|
||||
{ID: 1001, Index: 101, Title: "Brrr", RepoID: 5},
|
||||
{ID: 1002, Index: 102, Title: "Brrr", Content: "Brrr", RepoID: 5},
|
||||
{ID: 1003, Index: 103, Title: "Brrr", RepoID: 5},
|
||||
{ID: 1004, Index: 104, Title: "Brrr", RepoID: 5},
|
||||
},
|
||||
SearchOptions: &internal.SearchOptions{
|
||||
Keyword: "Brrr -101 -103",
|
||||
SortBy: internal.SortByScore,
|
||||
},
|
||||
ExpectedIDs: []int64{1002, 1004},
|
||||
ExpectedTotal: 2,
|
||||
},
|
||||
{
|
||||
Name: "SortByCreatedDesc",
|
||||
SearchOptions: &internal.SearchOptions{
|
||||
|
@ -741,6 +790,7 @@ func generateDefaultIndexerData() []*internal.IndexerData {
|
|||
|
||||
data = append(data, &internal.IndexerData{
|
||||
ID: id,
|
||||
Index: issueIndex,
|
||||
RepoID: repoID,
|
||||
IsPublic: repoID%2 == 0,
|
||||
Title: fmt.Sprintf("issue%d of repo%d", issueIndex, repoID),
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue