mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-27 00:23:41 +09:00 
			
		
		
		
	Refactor to use optional.Option for issue index search option (#29739)
Signed-off-by: 6543 <6543@obermui.de>
This commit is contained in:
		| @@ -224,38 +224,41 @@ func (b *Indexer) Search(ctx context.Context, options *internal.SearchOptions) ( | ||||
| 		queries = append(queries, bleve.NewDisjunctionQuery(milestoneQueries...)) | ||||
| 	} | ||||
|  | ||||
| 	if options.ProjectID != nil { | ||||
| 		queries = append(queries, inner_bleve.NumericEqualityQuery(*options.ProjectID, "project_id")) | ||||
| 	if options.ProjectID.Has() { | ||||
| 		queries = append(queries, inner_bleve.NumericEqualityQuery(options.ProjectID.Value(), "project_id")) | ||||
| 	} | ||||
| 	if options.ProjectBoardID != nil { | ||||
| 		queries = append(queries, inner_bleve.NumericEqualityQuery(*options.ProjectBoardID, "project_board_id")) | ||||
| 	if options.ProjectBoardID.Has() { | ||||
| 		queries = append(queries, inner_bleve.NumericEqualityQuery(options.ProjectBoardID.Value(), "project_board_id")) | ||||
| 	} | ||||
|  | ||||
| 	if options.PosterID != nil { | ||||
| 		queries = append(queries, inner_bleve.NumericEqualityQuery(*options.PosterID, "poster_id")) | ||||
| 	if options.PosterID.Has() { | ||||
| 		queries = append(queries, inner_bleve.NumericEqualityQuery(options.PosterID.Value(), "poster_id")) | ||||
| 	} | ||||
|  | ||||
| 	if options.AssigneeID != nil { | ||||
| 		queries = append(queries, inner_bleve.NumericEqualityQuery(*options.AssigneeID, "assignee_id")) | ||||
| 	if options.AssigneeID.Has() { | ||||
| 		queries = append(queries, inner_bleve.NumericEqualityQuery(options.AssigneeID.Value(), "assignee_id")) | ||||
| 	} | ||||
|  | ||||
| 	if options.MentionID != nil { | ||||
| 		queries = append(queries, inner_bleve.NumericEqualityQuery(*options.MentionID, "mention_ids")) | ||||
| 	if options.MentionID.Has() { | ||||
| 		queries = append(queries, inner_bleve.NumericEqualityQuery(options.MentionID.Value(), "mention_ids")) | ||||
| 	} | ||||
|  | ||||
| 	if options.ReviewedID != nil { | ||||
| 		queries = append(queries, inner_bleve.NumericEqualityQuery(*options.ReviewedID, "reviewed_ids")) | ||||
| 	if options.ReviewedID.Has() { | ||||
| 		queries = append(queries, inner_bleve.NumericEqualityQuery(options.ReviewedID.Value(), "reviewed_ids")) | ||||
| 	} | ||||
| 	if options.ReviewRequestedID != nil { | ||||
| 		queries = append(queries, inner_bleve.NumericEqualityQuery(*options.ReviewRequestedID, "review_requested_ids")) | ||||
| 	if options.ReviewRequestedID.Has() { | ||||
| 		queries = append(queries, inner_bleve.NumericEqualityQuery(options.ReviewRequestedID.Value(), "review_requested_ids")) | ||||
| 	} | ||||
|  | ||||
| 	if options.SubscriberID != nil { | ||||
| 		queries = append(queries, inner_bleve.NumericEqualityQuery(*options.SubscriberID, "subscriber_ids")) | ||||
| 	if options.SubscriberID.Has() { | ||||
| 		queries = append(queries, inner_bleve.NumericEqualityQuery(options.SubscriberID.Value(), "subscriber_ids")) | ||||
| 	} | ||||
|  | ||||
| 	if options.UpdatedAfterUnix != nil || options.UpdatedBeforeUnix != nil { | ||||
| 		queries = append(queries, inner_bleve.NumericRangeInclusiveQuery(options.UpdatedAfterUnix, options.UpdatedBeforeUnix, "updated_unix")) | ||||
| 	if options.UpdatedAfterUnix.Has() || options.UpdatedBeforeUnix.Has() { | ||||
| 		queries = append(queries, inner_bleve.NumericRangeInclusiveQuery( | ||||
| 			options.UpdatedAfterUnix, | ||||
| 			options.UpdatedBeforeUnix, | ||||
| 			"updated_unix")) | ||||
| 	} | ||||
|  | ||||
| 	var indexerQuery query.Query = bleve.NewConjunctionQuery(queries...) | ||||
|   | ||||
| @@ -15,22 +15,6 @@ import ( | ||||
| ) | ||||
|  | ||||
| func ToDBOptions(ctx context.Context, options *internal.SearchOptions) (*issue_model.IssuesOptions, error) { | ||||
| 	// See the comment of issues_model.SearchOptions for the reason why we need to convert | ||||
| 	convertID := func(id *int64) int64 { | ||||
| 		if id == nil { | ||||
| 			return 0 | ||||
| 		} | ||||
| 		if *id == 0 { | ||||
| 			return db.NoConditionID | ||||
| 		} | ||||
| 		return *id | ||||
| 	} | ||||
| 	convertInt64 := func(i *int64) int64 { | ||||
| 		if i == nil { | ||||
| 			return 0 | ||||
| 		} | ||||
| 		return *i | ||||
| 	} | ||||
| 	var sortType string | ||||
| 	switch options.SortBy { | ||||
| 	case internal.SortByCreatedAsc: | ||||
| @@ -53,6 +37,18 @@ func ToDBOptions(ctx context.Context, options *internal.SearchOptions) (*issue_m | ||||
| 		sortType = "newest" | ||||
| 	} | ||||
|  | ||||
| 	// See the comment of issues_model.SearchOptions for the reason why we need to convert | ||||
| 	convertID := func(id optional.Option[int64]) int64 { | ||||
| 		if !id.Has() { | ||||
| 			return 0 | ||||
| 		} | ||||
| 		value := id.Value() | ||||
| 		if value == 0 { | ||||
| 			return db.NoConditionID | ||||
| 		} | ||||
| 		return value | ||||
| 	} | ||||
|  | ||||
| 	opts := &issue_model.IssuesOptions{ | ||||
| 		Paginator:          options.Paginator, | ||||
| 		RepoIDs:            options.RepoIDs, | ||||
| @@ -73,8 +69,8 @@ func ToDBOptions(ctx context.Context, options *internal.SearchOptions) (*issue_m | ||||
| 		IncludeMilestones:  nil, | ||||
| 		SortType:           sortType, | ||||
| 		IssueIDs:           nil, | ||||
| 		UpdatedAfterUnix:   convertInt64(options.UpdatedAfterUnix), | ||||
| 		UpdatedBeforeUnix:  convertInt64(options.UpdatedBeforeUnix), | ||||
| 		UpdatedAfterUnix:   options.UpdatedAfterUnix.Value(), | ||||
| 		UpdatedBeforeUnix:  options.UpdatedBeforeUnix.Value(), | ||||
| 		PriorityRepoID:     0, | ||||
| 		IsArchived:         optional.None[bool](), | ||||
| 		Org:                nil, | ||||
|   | ||||
| @@ -6,6 +6,7 @@ package issues | ||||
| import ( | ||||
| 	"code.gitea.io/gitea/models/db" | ||||
| 	issues_model "code.gitea.io/gitea/models/issues" | ||||
| 	"code.gitea.io/gitea/modules/optional" | ||||
| ) | ||||
|  | ||||
| func ToSearchOptions(keyword string, opts *issues_model.IssuesOptions) *SearchOptions { | ||||
| @@ -38,13 +39,12 @@ func ToSearchOptions(keyword string, opts *issues_model.IssuesOptions) *SearchOp | ||||
| 	} | ||||
|  | ||||
| 	// See the comment of issues_model.SearchOptions for the reason why we need to convert | ||||
| 	convertID := func(id int64) *int64 { | ||||
| 	convertID := func(id int64) optional.Option[int64] { | ||||
| 		if id > 0 { | ||||
| 			return &id | ||||
| 			return optional.Some(id) | ||||
| 		} | ||||
| 		if id == db.NoConditionID { | ||||
| 			var zero int64 | ||||
| 			return &zero | ||||
| 			return optional.None[int64]() | ||||
| 		} | ||||
| 		return nil | ||||
| 	} | ||||
| @@ -59,10 +59,10 @@ func ToSearchOptions(keyword string, opts *issues_model.IssuesOptions) *SearchOp | ||||
| 	searchOpt.SubscriberID = convertID(opts.SubscriberID) | ||||
|  | ||||
| 	if opts.UpdatedAfterUnix > 0 { | ||||
| 		searchOpt.UpdatedAfterUnix = &opts.UpdatedAfterUnix | ||||
| 		searchOpt.UpdatedAfterUnix = optional.Some(opts.UpdatedAfterUnix) | ||||
| 	} | ||||
| 	if opts.UpdatedBeforeUnix > 0 { | ||||
| 		searchOpt.UpdatedBeforeUnix = &opts.UpdatedBeforeUnix | ||||
| 		searchOpt.UpdatedBeforeUnix = optional.Some(opts.UpdatedBeforeUnix) | ||||
| 	} | ||||
|  | ||||
| 	searchOpt.Paginator = opts.Paginator | ||||
|   | ||||
| @@ -195,43 +195,43 @@ func (b *Indexer) Search(ctx context.Context, options *internal.SearchOptions) ( | ||||
| 		query.Must(elastic.NewTermsQuery("milestone_id", toAnySlice(options.MilestoneIDs)...)) | ||||
| 	} | ||||
|  | ||||
| 	if options.ProjectID != nil { | ||||
| 		query.Must(elastic.NewTermQuery("project_id", *options.ProjectID)) | ||||
| 	if options.ProjectID.Has() { | ||||
| 		query.Must(elastic.NewTermQuery("project_id", options.ProjectID.Value())) | ||||
| 	} | ||||
| 	if options.ProjectBoardID != nil { | ||||
| 		query.Must(elastic.NewTermQuery("project_board_id", *options.ProjectBoardID)) | ||||
| 	if options.ProjectBoardID.Has() { | ||||
| 		query.Must(elastic.NewTermQuery("project_board_id", options.ProjectBoardID.Value())) | ||||
| 	} | ||||
|  | ||||
| 	if options.PosterID != nil { | ||||
| 		query.Must(elastic.NewTermQuery("poster_id", *options.PosterID)) | ||||
| 	if options.PosterID.Has() { | ||||
| 		query.Must(elastic.NewTermQuery("poster_id", options.PosterID.Value())) | ||||
| 	} | ||||
|  | ||||
| 	if options.AssigneeID != nil { | ||||
| 		query.Must(elastic.NewTermQuery("assignee_id", *options.AssigneeID)) | ||||
| 	if options.AssigneeID.Has() { | ||||
| 		query.Must(elastic.NewTermQuery("assignee_id", options.AssigneeID.Value())) | ||||
| 	} | ||||
|  | ||||
| 	if options.MentionID != nil { | ||||
| 		query.Must(elastic.NewTermQuery("mention_ids", *options.MentionID)) | ||||
| 	if options.MentionID.Has() { | ||||
| 		query.Must(elastic.NewTermQuery("mention_ids", options.MentionID.Value())) | ||||
| 	} | ||||
|  | ||||
| 	if options.ReviewedID != nil { | ||||
| 		query.Must(elastic.NewTermQuery("reviewed_ids", *options.ReviewedID)) | ||||
| 	if options.ReviewedID.Has() { | ||||
| 		query.Must(elastic.NewTermQuery("reviewed_ids", options.ReviewedID.Value())) | ||||
| 	} | ||||
| 	if options.ReviewRequestedID != nil { | ||||
| 		query.Must(elastic.NewTermQuery("review_requested_ids", *options.ReviewRequestedID)) | ||||
| 	if options.ReviewRequestedID.Has() { | ||||
| 		query.Must(elastic.NewTermQuery("review_requested_ids", options.ReviewRequestedID.Value())) | ||||
| 	} | ||||
|  | ||||
| 	if options.SubscriberID != nil { | ||||
| 		query.Must(elastic.NewTermQuery("subscriber_ids", *options.SubscriberID)) | ||||
| 	if options.SubscriberID.Has() { | ||||
| 		query.Must(elastic.NewTermQuery("subscriber_ids", options.SubscriberID.Value())) | ||||
| 	} | ||||
|  | ||||
| 	if options.UpdatedAfterUnix != nil || options.UpdatedBeforeUnix != nil { | ||||
| 	if options.UpdatedAfterUnix.Has() || options.UpdatedBeforeUnix.Has() { | ||||
| 		q := elastic.NewRangeQuery("updated_unix") | ||||
| 		if options.UpdatedAfterUnix != nil { | ||||
| 			q.Gte(*options.UpdatedAfterUnix) | ||||
| 		if options.UpdatedAfterUnix.Has() { | ||||
| 			q.Gte(options.UpdatedAfterUnix.Value()) | ||||
| 		} | ||||
| 		if options.UpdatedBeforeUnix != nil { | ||||
| 			q.Lte(*options.UpdatedBeforeUnix) | ||||
| 		if options.UpdatedBeforeUnix.Has() { | ||||
| 			q.Lte(options.UpdatedBeforeUnix.Value()) | ||||
| 		} | ||||
| 		query.Must(q) | ||||
| 	} | ||||
|   | ||||
| @@ -134,63 +134,60 @@ func searchIssueInRepo(t *testing.T) { | ||||
| } | ||||
|  | ||||
| func searchIssueByID(t *testing.T) { | ||||
| 	int64Pointer := func(x int64) *int64 { | ||||
| 		return &x | ||||
| 	} | ||||
| 	tests := []struct { | ||||
| 		opts        SearchOptions | ||||
| 		expectedIDs []int64 | ||||
| 	}{ | ||||
| 		{ | ||||
| 			SearchOptions{ | ||||
| 				PosterID: int64Pointer(1), | ||||
| 			opts: SearchOptions{ | ||||
| 				PosterID: optional.Some(int64(1)), | ||||
| 			}, | ||||
| 			[]int64{11, 6, 3, 2, 1}, | ||||
| 			expectedIDs: []int64{11, 6, 3, 2, 1}, | ||||
| 		}, | ||||
| 		{ | ||||
| 			SearchOptions{ | ||||
| 				AssigneeID: int64Pointer(1), | ||||
| 			opts: SearchOptions{ | ||||
| 				AssigneeID: optional.Some(int64(1)), | ||||
| 			}, | ||||
| 			[]int64{6, 1}, | ||||
| 			expectedIDs: []int64{6, 1}, | ||||
| 		}, | ||||
| 		{ | ||||
| 			SearchOptions{ | ||||
| 				MentionID: int64Pointer(4), | ||||
| 			opts: SearchOptions{ | ||||
| 				MentionID: optional.Some(int64(4)), | ||||
| 			}, | ||||
| 			[]int64{1}, | ||||
| 			expectedIDs: []int64{1}, | ||||
| 		}, | ||||
| 		{ | ||||
| 			SearchOptions{ | ||||
| 				ReviewedID: int64Pointer(1), | ||||
| 			opts: SearchOptions{ | ||||
| 				ReviewedID: optional.Some(int64(1)), | ||||
| 			}, | ||||
| 			[]int64{}, | ||||
| 			expectedIDs: []int64{}, | ||||
| 		}, | ||||
| 		{ | ||||
| 			SearchOptions{ | ||||
| 				ReviewRequestedID: int64Pointer(1), | ||||
| 			opts: SearchOptions{ | ||||
| 				ReviewRequestedID: optional.Some(int64(1)), | ||||
| 			}, | ||||
| 			[]int64{12}, | ||||
| 			expectedIDs: []int64{12}, | ||||
| 		}, | ||||
| 		{ | ||||
| 			SearchOptions{ | ||||
| 				SubscriberID: int64Pointer(1), | ||||
| 			opts: SearchOptions{ | ||||
| 				SubscriberID: optional.Some(int64(1)), | ||||
| 			}, | ||||
| 			[]int64{11, 6, 5, 3, 2, 1}, | ||||
| 			expectedIDs: []int64{11, 6, 5, 3, 2, 1}, | ||||
| 		}, | ||||
| 		{ | ||||
| 			// issue 20 request user 15 and team 5 which user 15 belongs to | ||||
| 			// the review request number of issue 20 should be 1 | ||||
| 			SearchOptions{ | ||||
| 				ReviewRequestedID: int64Pointer(15), | ||||
| 			opts: SearchOptions{ | ||||
| 				ReviewRequestedID: optional.Some(int64(15)), | ||||
| 			}, | ||||
| 			[]int64{12, 20}, | ||||
| 			expectedIDs: []int64{12, 20}, | ||||
| 		}, | ||||
| 		{ | ||||
| 			// user 20 approved the issue 20, so return nothing | ||||
| 			SearchOptions{ | ||||
| 				ReviewRequestedID: int64Pointer(20), | ||||
| 			opts: SearchOptions{ | ||||
| 				ReviewRequestedID: optional.Some(int64(20)), | ||||
| 			}, | ||||
| 			[]int64{}, | ||||
| 			expectedIDs: []int64{}, | ||||
| 		}, | ||||
| 	} | ||||
|  | ||||
| @@ -318,16 +315,13 @@ func searchIssueByLabelID(t *testing.T) { | ||||
| } | ||||
|  | ||||
| func searchIssueByTime(t *testing.T) { | ||||
| 	int64Pointer := func(i int64) *int64 { | ||||
| 		return &i | ||||
| 	} | ||||
| 	tests := []struct { | ||||
| 		opts        SearchOptions | ||||
| 		expectedIDs []int64 | ||||
| 	}{ | ||||
| 		{ | ||||
| 			SearchOptions{ | ||||
| 				UpdatedAfterUnix: int64Pointer(0), | ||||
| 				UpdatedAfterUnix: optional.Some(int64(0)), | ||||
| 			}, | ||||
| 			[]int64{22, 21, 17, 16, 15, 14, 13, 12, 11, 20, 6, 5, 19, 18, 10, 7, 4, 9, 8, 3, 2, 1}, | ||||
| 		}, | ||||
| @@ -363,28 +357,25 @@ func searchIssueWithOrder(t *testing.T) { | ||||
| } | ||||
|  | ||||
| func searchIssueInProject(t *testing.T) { | ||||
| 	int64Pointer := func(i int64) *int64 { | ||||
| 		return &i | ||||
| 	} | ||||
| 	tests := []struct { | ||||
| 		opts        SearchOptions | ||||
| 		expectedIDs []int64 | ||||
| 	}{ | ||||
| 		{ | ||||
| 			SearchOptions{ | ||||
| 				ProjectID: int64Pointer(1), | ||||
| 				ProjectID: optional.Some(int64(1)), | ||||
| 			}, | ||||
| 			[]int64{5, 3, 2, 1}, | ||||
| 		}, | ||||
| 		{ | ||||
| 			SearchOptions{ | ||||
| 				ProjectBoardID: int64Pointer(1), | ||||
| 				ProjectBoardID: optional.Some(int64(1)), | ||||
| 			}, | ||||
| 			[]int64{1}, | ||||
| 		}, | ||||
| 		{ | ||||
| 			SearchOptions{ | ||||
| 				ProjectBoardID: int64Pointer(0), // issue with in default board | ||||
| 				ProjectBoardID: optional.Some(int64(0)), // issue with in default board | ||||
| 			}, | ||||
| 			[]int64{2}, | ||||
| 		}, | ||||
|   | ||||
| @@ -89,22 +89,22 @@ type SearchOptions struct { | ||||
|  | ||||
| 	MilestoneIDs []int64 // milestones the issues have | ||||
|  | ||||
| 	ProjectID      *int64 // project the issues belong to | ||||
| 	ProjectBoardID *int64 // project board the issues belong to | ||||
| 	ProjectID      optional.Option[int64] // project the issues belong to | ||||
| 	ProjectBoardID optional.Option[int64] // project board the issues belong to | ||||
|  | ||||
| 	PosterID *int64 // poster of the issues | ||||
| 	PosterID optional.Option[int64] // poster of the issues | ||||
|  | ||||
| 	AssigneeID *int64 // assignee of the issues, zero means no assignee | ||||
| 	AssigneeID optional.Option[int64] // assignee of the issues, zero means no assignee | ||||
|  | ||||
| 	MentionID *int64 // mentioned user of the issues | ||||
| 	MentionID optional.Option[int64] // mentioned user of the issues | ||||
|  | ||||
| 	ReviewedID        *int64 // reviewer of the issues | ||||
| 	ReviewRequestedID *int64 // requested reviewer of the issues | ||||
| 	ReviewedID        optional.Option[int64] // reviewer of the issues | ||||
| 	ReviewRequestedID optional.Option[int64] // requested reviewer of the issues | ||||
|  | ||||
| 	SubscriberID *int64 // subscriber of the issues | ||||
| 	SubscriberID optional.Option[int64] // subscriber of the issues | ||||
|  | ||||
| 	UpdatedAfterUnix  *int64 | ||||
| 	UpdatedBeforeUnix *int64 | ||||
| 	UpdatedAfterUnix  optional.Option[int64] | ||||
| 	UpdatedBeforeUnix optional.Option[int64] | ||||
|  | ||||
| 	db.Paginator | ||||
|  | ||||
|   | ||||
| @@ -300,10 +300,7 @@ var cases = []*testIndexerCase{ | ||||
| 			Paginator: &db.ListOptions{ | ||||
| 				PageSize: 5, | ||||
| 			}, | ||||
| 			ProjectID: func() *int64 { | ||||
| 				id := int64(1) | ||||
| 				return &id | ||||
| 			}(), | ||||
| 			ProjectID: optional.Some(int64(1)), | ||||
| 		}, | ||||
| 		Expected: func(t *testing.T, data map[int64]*internal.IndexerData, result *internal.SearchResult) { | ||||
| 			assert.Equal(t, 5, len(result.Hits)) | ||||
| @@ -321,10 +318,7 @@ var cases = []*testIndexerCase{ | ||||
| 			Paginator: &db.ListOptions{ | ||||
| 				PageSize: 5, | ||||
| 			}, | ||||
| 			ProjectID: func() *int64 { | ||||
| 				id := int64(0) | ||||
| 				return &id | ||||
| 			}(), | ||||
| 			ProjectID: optional.Some(int64(0)), | ||||
| 		}, | ||||
| 		Expected: func(t *testing.T, data map[int64]*internal.IndexerData, result *internal.SearchResult) { | ||||
| 			assert.Equal(t, 5, len(result.Hits)) | ||||
| @@ -342,10 +336,7 @@ var cases = []*testIndexerCase{ | ||||
| 			Paginator: &db.ListOptions{ | ||||
| 				PageSize: 5, | ||||
| 			}, | ||||
| 			ProjectBoardID: func() *int64 { | ||||
| 				id := int64(1) | ||||
| 				return &id | ||||
| 			}(), | ||||
| 			ProjectBoardID: optional.Some(int64(1)), | ||||
| 		}, | ||||
| 		Expected: func(t *testing.T, data map[int64]*internal.IndexerData, result *internal.SearchResult) { | ||||
| 			assert.Equal(t, 5, len(result.Hits)) | ||||
| @@ -363,10 +354,7 @@ var cases = []*testIndexerCase{ | ||||
| 			Paginator: &db.ListOptions{ | ||||
| 				PageSize: 5, | ||||
| 			}, | ||||
| 			ProjectBoardID: func() *int64 { | ||||
| 				id := int64(0) | ||||
| 				return &id | ||||
| 			}(), | ||||
| 			ProjectBoardID: optional.Some(int64(0)), | ||||
| 		}, | ||||
| 		Expected: func(t *testing.T, data map[int64]*internal.IndexerData, result *internal.SearchResult) { | ||||
| 			assert.Equal(t, 5, len(result.Hits)) | ||||
| @@ -384,10 +372,7 @@ var cases = []*testIndexerCase{ | ||||
| 			Paginator: &db.ListOptions{ | ||||
| 				PageSize: 5, | ||||
| 			}, | ||||
| 			PosterID: func() *int64 { | ||||
| 				id := int64(1) | ||||
| 				return &id | ||||
| 			}(), | ||||
| 			PosterID: optional.Some(int64(1)), | ||||
| 		}, | ||||
| 		Expected: func(t *testing.T, data map[int64]*internal.IndexerData, result *internal.SearchResult) { | ||||
| 			assert.Equal(t, 5, len(result.Hits)) | ||||
| @@ -405,10 +390,7 @@ var cases = []*testIndexerCase{ | ||||
| 			Paginator: &db.ListOptions{ | ||||
| 				PageSize: 5, | ||||
| 			}, | ||||
| 			AssigneeID: func() *int64 { | ||||
| 				id := int64(1) | ||||
| 				return &id | ||||
| 			}(), | ||||
| 			AssigneeID: optional.Some(int64(1)), | ||||
| 		}, | ||||
| 		Expected: func(t *testing.T, data map[int64]*internal.IndexerData, result *internal.SearchResult) { | ||||
| 			assert.Equal(t, 5, len(result.Hits)) | ||||
| @@ -426,10 +408,7 @@ var cases = []*testIndexerCase{ | ||||
| 			Paginator: &db.ListOptions{ | ||||
| 				PageSize: 5, | ||||
| 			}, | ||||
| 			AssigneeID: func() *int64 { | ||||
| 				id := int64(0) | ||||
| 				return &id | ||||
| 			}(), | ||||
| 			AssigneeID: optional.Some(int64(0)), | ||||
| 		}, | ||||
| 		Expected: func(t *testing.T, data map[int64]*internal.IndexerData, result *internal.SearchResult) { | ||||
| 			assert.Equal(t, 5, len(result.Hits)) | ||||
| @@ -447,10 +426,7 @@ var cases = []*testIndexerCase{ | ||||
| 			Paginator: &db.ListOptions{ | ||||
| 				PageSize: 5, | ||||
| 			}, | ||||
| 			MentionID: func() *int64 { | ||||
| 				id := int64(1) | ||||
| 				return &id | ||||
| 			}(), | ||||
| 			MentionID: optional.Some(int64(1)), | ||||
| 		}, | ||||
| 		Expected: func(t *testing.T, data map[int64]*internal.IndexerData, result *internal.SearchResult) { | ||||
| 			assert.Equal(t, 5, len(result.Hits)) | ||||
| @@ -468,10 +444,7 @@ var cases = []*testIndexerCase{ | ||||
| 			Paginator: &db.ListOptions{ | ||||
| 				PageSize: 5, | ||||
| 			}, | ||||
| 			ReviewedID: func() *int64 { | ||||
| 				id := int64(1) | ||||
| 				return &id | ||||
| 			}(), | ||||
| 			ReviewedID: optional.Some(int64(1)), | ||||
| 		}, | ||||
| 		Expected: func(t *testing.T, data map[int64]*internal.IndexerData, result *internal.SearchResult) { | ||||
| 			assert.Equal(t, 5, len(result.Hits)) | ||||
| @@ -489,10 +462,7 @@ var cases = []*testIndexerCase{ | ||||
| 			Paginator: &db.ListOptions{ | ||||
| 				PageSize: 5, | ||||
| 			}, | ||||
| 			ReviewRequestedID: func() *int64 { | ||||
| 				id := int64(1) | ||||
| 				return &id | ||||
| 			}(), | ||||
| 			ReviewRequestedID: optional.Some(int64(1)), | ||||
| 		}, | ||||
| 		Expected: func(t *testing.T, data map[int64]*internal.IndexerData, result *internal.SearchResult) { | ||||
| 			assert.Equal(t, 5, len(result.Hits)) | ||||
| @@ -510,10 +480,7 @@ var cases = []*testIndexerCase{ | ||||
| 			Paginator: &db.ListOptions{ | ||||
| 				PageSize: 5, | ||||
| 			}, | ||||
| 			SubscriberID: func() *int64 { | ||||
| 				id := int64(1) | ||||
| 				return &id | ||||
| 			}(), | ||||
| 			SubscriberID: optional.Some(int64(1)), | ||||
| 		}, | ||||
| 		Expected: func(t *testing.T, data map[int64]*internal.IndexerData, result *internal.SearchResult) { | ||||
| 			assert.Equal(t, 5, len(result.Hits)) | ||||
| @@ -531,14 +498,8 @@ var cases = []*testIndexerCase{ | ||||
| 			Paginator: &db.ListOptions{ | ||||
| 				PageSize: 5, | ||||
| 			}, | ||||
| 			UpdatedAfterUnix: func() *int64 { | ||||
| 				var t int64 = 20 | ||||
| 				return &t | ||||
| 			}(), | ||||
| 			UpdatedBeforeUnix: func() *int64 { | ||||
| 				var t int64 = 30 | ||||
| 				return &t | ||||
| 			}(), | ||||
| 			UpdatedAfterUnix:  optional.Some(int64(20)), | ||||
| 			UpdatedBeforeUnix: optional.Some(int64(30)), | ||||
| 		}, | ||||
| 		Expected: func(t *testing.T, data map[int64]*internal.IndexerData, result *internal.SearchResult) { | ||||
| 			assert.Equal(t, 5, len(result.Hits)) | ||||
|   | ||||
| @@ -170,41 +170,41 @@ func (b *Indexer) Search(ctx context.Context, options *internal.SearchOptions) ( | ||||
| 		query.And(inner_meilisearch.NewFilterIn("milestone_id", options.MilestoneIDs...)) | ||||
| 	} | ||||
|  | ||||
| 	if options.ProjectID != nil { | ||||
| 		query.And(inner_meilisearch.NewFilterEq("project_id", *options.ProjectID)) | ||||
| 	if options.ProjectID.Has() { | ||||
| 		query.And(inner_meilisearch.NewFilterEq("project_id", options.ProjectID.Value())) | ||||
| 	} | ||||
| 	if options.ProjectBoardID != nil { | ||||
| 		query.And(inner_meilisearch.NewFilterEq("project_board_id", *options.ProjectBoardID)) | ||||
| 	if options.ProjectBoardID.Has() { | ||||
| 		query.And(inner_meilisearch.NewFilterEq("project_board_id", options.ProjectBoardID.Value())) | ||||
| 	} | ||||
|  | ||||
| 	if options.PosterID != nil { | ||||
| 		query.And(inner_meilisearch.NewFilterEq("poster_id", *options.PosterID)) | ||||
| 	if options.PosterID.Has() { | ||||
| 		query.And(inner_meilisearch.NewFilterEq("poster_id", options.PosterID.Value())) | ||||
| 	} | ||||
|  | ||||
| 	if options.AssigneeID != nil { | ||||
| 		query.And(inner_meilisearch.NewFilterEq("assignee_id", *options.AssigneeID)) | ||||
| 	if options.AssigneeID.Has() { | ||||
| 		query.And(inner_meilisearch.NewFilterEq("assignee_id", options.AssigneeID.Value())) | ||||
| 	} | ||||
|  | ||||
| 	if options.MentionID != nil { | ||||
| 		query.And(inner_meilisearch.NewFilterEq("mention_ids", *options.MentionID)) | ||||
| 	if options.MentionID.Has() { | ||||
| 		query.And(inner_meilisearch.NewFilterEq("mention_ids", options.MentionID.Value())) | ||||
| 	} | ||||
|  | ||||
| 	if options.ReviewedID != nil { | ||||
| 		query.And(inner_meilisearch.NewFilterEq("reviewed_ids", *options.ReviewedID)) | ||||
| 	if options.ReviewedID.Has() { | ||||
| 		query.And(inner_meilisearch.NewFilterEq("reviewed_ids", options.ReviewedID.Value())) | ||||
| 	} | ||||
| 	if options.ReviewRequestedID != nil { | ||||
| 		query.And(inner_meilisearch.NewFilterEq("review_requested_ids", *options.ReviewRequestedID)) | ||||
| 	if options.ReviewRequestedID.Has() { | ||||
| 		query.And(inner_meilisearch.NewFilterEq("review_requested_ids", options.ReviewRequestedID.Value())) | ||||
| 	} | ||||
|  | ||||
| 	if options.SubscriberID != nil { | ||||
| 		query.And(inner_meilisearch.NewFilterEq("subscriber_ids", *options.SubscriberID)) | ||||
| 	if options.SubscriberID.Has() { | ||||
| 		query.And(inner_meilisearch.NewFilterEq("subscriber_ids", options.SubscriberID.Value())) | ||||
| 	} | ||||
|  | ||||
| 	if options.UpdatedAfterUnix != nil { | ||||
| 		query.And(inner_meilisearch.NewFilterGte("updated_unix", *options.UpdatedAfterUnix)) | ||||
| 	if options.UpdatedAfterUnix.Has() { | ||||
| 		query.And(inner_meilisearch.NewFilterGte("updated_unix", options.UpdatedAfterUnix.Value())) | ||||
| 	} | ||||
| 	if options.UpdatedBeforeUnix != nil { | ||||
| 		query.And(inner_meilisearch.NewFilterLte("updated_unix", *options.UpdatedBeforeUnix)) | ||||
| 	if options.UpdatedBeforeUnix.Has() { | ||||
| 		query.And(inner_meilisearch.NewFilterLte("updated_unix", options.UpdatedBeforeUnix.Value())) | ||||
| 	} | ||||
|  | ||||
| 	if options.SortBy == "" { | ||||
|   | ||||
		Reference in New Issue
	
	Block a user