mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-26 05:26:27 +00:00 
			
		
		
		
	Test and implement settings opt-out
This commit is contained in:
		| @@ -292,6 +292,8 @@ pub(crate) mod test { | ||||
|             embedders: Setting::NotSet, | ||||
|             search_cutoff_ms: Setting::NotSet, | ||||
|             localized_attributes: Setting::NotSet, | ||||
|             facet_search: Setting::NotSet, | ||||
|             prefix_search: Setting::NotSet, | ||||
|             _kind: std::marker::PhantomData, | ||||
|         }; | ||||
|         settings.check() | ||||
|   | ||||
| @@ -382,6 +382,8 @@ impl<T> From<v5::Settings<T>> for v6::Settings<v6::Unchecked> { | ||||
|             embedders: v6::Setting::NotSet, | ||||
|             localized_attributes: v6::Setting::NotSet, | ||||
|             search_cutoff_ms: v6::Setting::NotSet, | ||||
|             facet_search: v6::Setting::NotSet, | ||||
|             prefix_search: v6::Setting::NotSet, | ||||
|             _kind: std::marker::PhantomData, | ||||
|         } | ||||
|     } | ||||
|   | ||||
| @@ -1,13 +1,12 @@ | ||||
| --- | ||||
| source: crates/index-scheduler/src/lib.rs | ||||
| snapshot_kind: text | ||||
| --- | ||||
| ### Autobatching Enabled = true | ||||
| ### Processing batch None: | ||||
| [] | ||||
| ---------------------------------------------------------------------- | ||||
| ### All Tasks: | ||||
| 0 {uid: 0, batch_uid: 0, status: succeeded, details: { settings: Settings { displayed_attributes: WildcardSetting(NotSet), searchable_attributes: WildcardSetting(NotSet), filterable_attributes: Set({"catto"}), sortable_attributes: NotSet, ranking_rules: NotSet, stop_words: NotSet, non_separator_tokens: NotSet, separator_tokens: NotSet, dictionary: NotSet, synonyms: NotSet, distinct_attribute: NotSet, proximity_precision: NotSet, typo_tolerance: NotSet, faceting: NotSet, pagination: NotSet, embedders: NotSet, search_cutoff_ms: NotSet, localized_attributes: NotSet, _kind: PhantomData<meilisearch_types::settings::Unchecked> } }, kind: SettingsUpdate { index_uid: "doggos", new_settings: Settings { displayed_attributes: WildcardSetting(NotSet), searchable_attributes: WildcardSetting(NotSet), filterable_attributes: Set({"catto"}), sortable_attributes: NotSet, ranking_rules: NotSet, stop_words: NotSet, non_separator_tokens: NotSet, separator_tokens: NotSet, dictionary: NotSet, synonyms: NotSet, distinct_attribute: NotSet, proximity_precision: NotSet, typo_tolerance: NotSet, faceting: NotSet, pagination: NotSet, embedders: NotSet, search_cutoff_ms: NotSet, localized_attributes: NotSet, _kind: PhantomData<meilisearch_types::settings::Unchecked> }, is_deletion: false, allow_index_creation: true }} | ||||
| 0 {uid: 0, batch_uid: 0, status: succeeded, details: { settings: Settings { displayed_attributes: WildcardSetting(NotSet), searchable_attributes: WildcardSetting(NotSet), filterable_attributes: Set({"catto"}), sortable_attributes: NotSet, ranking_rules: NotSet, stop_words: NotSet, non_separator_tokens: NotSet, separator_tokens: NotSet, dictionary: NotSet, synonyms: NotSet, distinct_attribute: NotSet, proximity_precision: NotSet, typo_tolerance: NotSet, faceting: NotSet, pagination: NotSet, embedders: NotSet, search_cutoff_ms: NotSet, localized_attributes: NotSet, facet_search: NotSet, prefix_search: NotSet, _kind: PhantomData<meilisearch_types::settings::Unchecked> } }, kind: SettingsUpdate { index_uid: "doggos", new_settings: Settings { displayed_attributes: WildcardSetting(NotSet), searchable_attributes: WildcardSetting(NotSet), filterable_attributes: Set({"catto"}), sortable_attributes: NotSet, ranking_rules: NotSet, stop_words: NotSet, non_separator_tokens: NotSet, separator_tokens: NotSet, dictionary: NotSet, synonyms: NotSet, distinct_attribute: NotSet, proximity_precision: NotSet, typo_tolerance: NotSet, faceting: NotSet, pagination: NotSet, embedders: NotSet, search_cutoff_ms: NotSet, localized_attributes: NotSet, facet_search: NotSet, prefix_search: NotSet, _kind: PhantomData<meilisearch_types::settings::Unchecked> }, is_deletion: false, allow_index_creation: true }} | ||||
| 1 {uid: 1, batch_uid: 1, status: succeeded, details: { received_documents: 3, indexed_documents: Some(3) }, kind: DocumentAdditionOrUpdate { index_uid: "doggos", primary_key: Some("id"), method: ReplaceDocuments, content_file: 00000000-0000-0000-0000-000000000000, documents_count: 3, allow_index_creation: true }} | ||||
| ---------------------------------------------------------------------- | ||||
| ### Status: | ||||
|   | ||||
| @@ -1,13 +1,12 @@ | ||||
| --- | ||||
| source: crates/index-scheduler/src/lib.rs | ||||
| snapshot_kind: text | ||||
| --- | ||||
| ### Autobatching Enabled = true | ||||
| ### Processing batch None: | ||||
| [] | ||||
| ---------------------------------------------------------------------- | ||||
| ### All Tasks: | ||||
| 0 {uid: 0, batch_uid: 0, status: succeeded, details: { settings: Settings { displayed_attributes: WildcardSetting(NotSet), searchable_attributes: WildcardSetting(NotSet), filterable_attributes: Set({"catto"}), sortable_attributes: NotSet, ranking_rules: NotSet, stop_words: NotSet, non_separator_tokens: NotSet, separator_tokens: NotSet, dictionary: NotSet, synonyms: NotSet, distinct_attribute: NotSet, proximity_precision: NotSet, typo_tolerance: NotSet, faceting: NotSet, pagination: NotSet, embedders: NotSet, search_cutoff_ms: NotSet, localized_attributes: NotSet, _kind: PhantomData<meilisearch_types::settings::Unchecked> } }, kind: SettingsUpdate { index_uid: "doggos", new_settings: Settings { displayed_attributes: WildcardSetting(NotSet), searchable_attributes: WildcardSetting(NotSet), filterable_attributes: Set({"catto"}), sortable_attributes: NotSet, ranking_rules: NotSet, stop_words: NotSet, non_separator_tokens: NotSet, separator_tokens: NotSet, dictionary: NotSet, synonyms: NotSet, distinct_attribute: NotSet, proximity_precision: NotSet, typo_tolerance: NotSet, faceting: NotSet, pagination: NotSet, embedders: NotSet, search_cutoff_ms: NotSet, localized_attributes: NotSet, _kind: PhantomData<meilisearch_types::settings::Unchecked> }, is_deletion: false, allow_index_creation: true }} | ||||
| 0 {uid: 0, batch_uid: 0, status: succeeded, details: { settings: Settings { displayed_attributes: WildcardSetting(NotSet), searchable_attributes: WildcardSetting(NotSet), filterable_attributes: Set({"catto"}), sortable_attributes: NotSet, ranking_rules: NotSet, stop_words: NotSet, non_separator_tokens: NotSet, separator_tokens: NotSet, dictionary: NotSet, synonyms: NotSet, distinct_attribute: NotSet, proximity_precision: NotSet, typo_tolerance: NotSet, faceting: NotSet, pagination: NotSet, embedders: NotSet, search_cutoff_ms: NotSet, localized_attributes: NotSet, facet_search: NotSet, prefix_search: NotSet, _kind: PhantomData<meilisearch_types::settings::Unchecked> } }, kind: SettingsUpdate { index_uid: "doggos", new_settings: Settings { displayed_attributes: WildcardSetting(NotSet), searchable_attributes: WildcardSetting(NotSet), filterable_attributes: Set({"catto"}), sortable_attributes: NotSet, ranking_rules: NotSet, stop_words: NotSet, non_separator_tokens: NotSet, separator_tokens: NotSet, dictionary: NotSet, synonyms: NotSet, distinct_attribute: NotSet, proximity_precision: NotSet, typo_tolerance: NotSet, faceting: NotSet, pagination: NotSet, embedders: NotSet, search_cutoff_ms: NotSet, localized_attributes: NotSet, facet_search: NotSet, prefix_search: NotSet, _kind: PhantomData<meilisearch_types::settings::Unchecked> }, is_deletion: false, allow_index_creation: true }} | ||||
| 1 {uid: 1, status: enqueued, details: { received_documents: 3, indexed_documents: None }, kind: DocumentAdditionOrUpdate { index_uid: "doggos", primary_key: Some("id"), method: ReplaceDocuments, content_file: 00000000-0000-0000-0000-000000000000, documents_count: 3, allow_index_creation: true }} | ||||
| ---------------------------------------------------------------------- | ||||
| ### Status: | ||||
|   | ||||
| @@ -1,13 +1,12 @@ | ||||
| --- | ||||
| source: crates/index-scheduler/src/lib.rs | ||||
| snapshot_kind: text | ||||
| --- | ||||
| ### Autobatching Enabled = true | ||||
| ### Processing batch None: | ||||
| [] | ||||
| ---------------------------------------------------------------------- | ||||
| ### All Tasks: | ||||
| 0 {uid: 0, batch_uid: 0, status: succeeded, details: { settings: Settings { displayed_attributes: WildcardSetting(NotSet), searchable_attributes: WildcardSetting(NotSet), filterable_attributes: Set({"catto"}), sortable_attributes: NotSet, ranking_rules: NotSet, stop_words: NotSet, non_separator_tokens: NotSet, separator_tokens: NotSet, dictionary: NotSet, synonyms: NotSet, distinct_attribute: NotSet, proximity_precision: NotSet, typo_tolerance: NotSet, faceting: NotSet, pagination: NotSet, embedders: NotSet, search_cutoff_ms: NotSet, localized_attributes: NotSet, _kind: PhantomData<meilisearch_types::settings::Unchecked> } }, kind: SettingsUpdate { index_uid: "doggos", new_settings: Settings { displayed_attributes: WildcardSetting(NotSet), searchable_attributes: WildcardSetting(NotSet), filterable_attributes: Set({"catto"}), sortable_attributes: NotSet, ranking_rules: NotSet, stop_words: NotSet, non_separator_tokens: NotSet, separator_tokens: NotSet, dictionary: NotSet, synonyms: NotSet, distinct_attribute: NotSet, proximity_precision: NotSet, typo_tolerance: NotSet, faceting: NotSet, pagination: NotSet, embedders: NotSet, search_cutoff_ms: NotSet, localized_attributes: NotSet, _kind: PhantomData<meilisearch_types::settings::Unchecked> }, is_deletion: false, allow_index_creation: true }} | ||||
| 0 {uid: 0, batch_uid: 0, status: succeeded, details: { settings: Settings { displayed_attributes: WildcardSetting(NotSet), searchable_attributes: WildcardSetting(NotSet), filterable_attributes: Set({"catto"}), sortable_attributes: NotSet, ranking_rules: NotSet, stop_words: NotSet, non_separator_tokens: NotSet, separator_tokens: NotSet, dictionary: NotSet, synonyms: NotSet, distinct_attribute: NotSet, proximity_precision: NotSet, typo_tolerance: NotSet, faceting: NotSet, pagination: NotSet, embedders: NotSet, search_cutoff_ms: NotSet, localized_attributes: NotSet, facet_search: NotSet, prefix_search: NotSet, _kind: PhantomData<meilisearch_types::settings::Unchecked> } }, kind: SettingsUpdate { index_uid: "doggos", new_settings: Settings { displayed_attributes: WildcardSetting(NotSet), searchable_attributes: WildcardSetting(NotSet), filterable_attributes: Set({"catto"}), sortable_attributes: NotSet, ranking_rules: NotSet, stop_words: NotSet, non_separator_tokens: NotSet, separator_tokens: NotSet, dictionary: NotSet, synonyms: NotSet, distinct_attribute: NotSet, proximity_precision: NotSet, typo_tolerance: NotSet, faceting: NotSet, pagination: NotSet, embedders: NotSet, search_cutoff_ms: NotSet, localized_attributes: NotSet, facet_search: NotSet, prefix_search: NotSet, _kind: PhantomData<meilisearch_types::settings::Unchecked> }, is_deletion: false, allow_index_creation: true }} | ||||
| 1 {uid: 1, batch_uid: 1, status: succeeded, details: { received_documents: 3, indexed_documents: Some(3) }, kind: DocumentAdditionOrUpdate { index_uid: "doggos", primary_key: Some("id"), method: ReplaceDocuments, content_file: 00000000-0000-0000-0000-000000000000, documents_count: 3, allow_index_creation: true }} | ||||
| 2 {uid: 2, batch_uid: 2, status: succeeded, details: { received_document_ids: 1, deleted_documents: Some(1) }, kind: DocumentDeletion { index_uid: "doggos", documents_ids: ["1"] }} | ||||
| 3 {uid: 3, batch_uid: 2, status: failed, error: ResponseError { code: 200, message: "Invalid type for filter subexpression: expected: String, Array, found: true.", error_code: "invalid_document_filter", error_type: "invalid_request", error_link: "https://docs.meilisearch.com/errors#invalid_document_filter" }, details: { original_filter: true, deleted_documents: Some(0) }, kind: DocumentDeletionByFilter { index_uid: "doggos", filter_expr: Bool(true) }} | ||||
|   | ||||
| @@ -1,13 +1,12 @@ | ||||
| --- | ||||
| source: crates/index-scheduler/src/lib.rs | ||||
| snapshot_kind: text | ||||
| --- | ||||
| ### Autobatching Enabled = true | ||||
| ### Processing batch None: | ||||
| [] | ||||
| ---------------------------------------------------------------------- | ||||
| ### All Tasks: | ||||
| 0 {uid: 0, batch_uid: 0, status: succeeded, details: { settings: Settings { displayed_attributes: WildcardSetting(NotSet), searchable_attributes: WildcardSetting(NotSet), filterable_attributes: Set({"catto"}), sortable_attributes: NotSet, ranking_rules: NotSet, stop_words: NotSet, non_separator_tokens: NotSet, separator_tokens: NotSet, dictionary: NotSet, synonyms: NotSet, distinct_attribute: NotSet, proximity_precision: NotSet, typo_tolerance: NotSet, faceting: NotSet, pagination: NotSet, embedders: NotSet, search_cutoff_ms: NotSet, localized_attributes: NotSet, _kind: PhantomData<meilisearch_types::settings::Unchecked> } }, kind: SettingsUpdate { index_uid: "doggos", new_settings: Settings { displayed_attributes: WildcardSetting(NotSet), searchable_attributes: WildcardSetting(NotSet), filterable_attributes: Set({"catto"}), sortable_attributes: NotSet, ranking_rules: NotSet, stop_words: NotSet, non_separator_tokens: NotSet, separator_tokens: NotSet, dictionary: NotSet, synonyms: NotSet, distinct_attribute: NotSet, proximity_precision: NotSet, typo_tolerance: NotSet, faceting: NotSet, pagination: NotSet, embedders: NotSet, search_cutoff_ms: NotSet, localized_attributes: NotSet, _kind: PhantomData<meilisearch_types::settings::Unchecked> }, is_deletion: false, allow_index_creation: true }} | ||||
| 0 {uid: 0, batch_uid: 0, status: succeeded, details: { settings: Settings { displayed_attributes: WildcardSetting(NotSet), searchable_attributes: WildcardSetting(NotSet), filterable_attributes: Set({"catto"}), sortable_attributes: NotSet, ranking_rules: NotSet, stop_words: NotSet, non_separator_tokens: NotSet, separator_tokens: NotSet, dictionary: NotSet, synonyms: NotSet, distinct_attribute: NotSet, proximity_precision: NotSet, typo_tolerance: NotSet, faceting: NotSet, pagination: NotSet, embedders: NotSet, search_cutoff_ms: NotSet, localized_attributes: NotSet, facet_search: NotSet, prefix_search: NotSet, _kind: PhantomData<meilisearch_types::settings::Unchecked> } }, kind: SettingsUpdate { index_uid: "doggos", new_settings: Settings { displayed_attributes: WildcardSetting(NotSet), searchable_attributes: WildcardSetting(NotSet), filterable_attributes: Set({"catto"}), sortable_attributes: NotSet, ranking_rules: NotSet, stop_words: NotSet, non_separator_tokens: NotSet, separator_tokens: NotSet, dictionary: NotSet, synonyms: NotSet, distinct_attribute: NotSet, proximity_precision: NotSet, typo_tolerance: NotSet, faceting: NotSet, pagination: NotSet, embedders: NotSet, search_cutoff_ms: NotSet, localized_attributes: NotSet, facet_search: NotSet, prefix_search: NotSet, _kind: PhantomData<meilisearch_types::settings::Unchecked> }, is_deletion: false, allow_index_creation: true }} | ||||
| 1 {uid: 1, batch_uid: 1, status: succeeded, details: { received_documents: 3, indexed_documents: Some(3) }, kind: DocumentAdditionOrUpdate { index_uid: "doggos", primary_key: Some("id"), method: ReplaceDocuments, content_file: 00000000-0000-0000-0000-000000000000, documents_count: 3, allow_index_creation: true }} | ||||
| 2 {uid: 2, status: enqueued, details: { received_document_ids: 1, deleted_documents: None }, kind: DocumentDeletion { index_uid: "doggos", documents_ids: ["1"] }} | ||||
| 3 {uid: 3, status: enqueued, details: { original_filter: true, deleted_documents: None }, kind: DocumentDeletionByFilter { index_uid: "doggos", filter_expr: Bool(true) }} | ||||
|   | ||||
| @@ -1,13 +1,12 @@ | ||||
| --- | ||||
| source: crates/index-scheduler/src/lib.rs | ||||
| snapshot_kind: text | ||||
| --- | ||||
| ### Autobatching Enabled = true | ||||
| ### Processing batch None: | ||||
| [] | ||||
| ---------------------------------------------------------------------- | ||||
| ### All Tasks: | ||||
| 0 {uid: 0, status: enqueued, details: { settings: Settings { displayed_attributes: WildcardSetting(NotSet), searchable_attributes: WildcardSetting(NotSet), filterable_attributes: Set({"catto"}), sortable_attributes: NotSet, ranking_rules: NotSet, stop_words: NotSet, non_separator_tokens: NotSet, separator_tokens: NotSet, dictionary: NotSet, synonyms: NotSet, distinct_attribute: NotSet, proximity_precision: NotSet, typo_tolerance: NotSet, faceting: NotSet, pagination: NotSet, embedders: NotSet, search_cutoff_ms: NotSet, localized_attributes: NotSet, _kind: PhantomData<meilisearch_types::settings::Unchecked> } }, kind: SettingsUpdate { index_uid: "doggos", new_settings: Settings { displayed_attributes: WildcardSetting(NotSet), searchable_attributes: WildcardSetting(NotSet), filterable_attributes: Set({"catto"}), sortable_attributes: NotSet, ranking_rules: NotSet, stop_words: NotSet, non_separator_tokens: NotSet, separator_tokens: NotSet, dictionary: NotSet, synonyms: NotSet, distinct_attribute: NotSet, proximity_precision: NotSet, typo_tolerance: NotSet, faceting: NotSet, pagination: NotSet, embedders: NotSet, search_cutoff_ms: NotSet, localized_attributes: NotSet, _kind: PhantomData<meilisearch_types::settings::Unchecked> }, is_deletion: false, allow_index_creation: true }} | ||||
| 0 {uid: 0, status: enqueued, details: { settings: Settings { displayed_attributes: WildcardSetting(NotSet), searchable_attributes: WildcardSetting(NotSet), filterable_attributes: Set({"catto"}), sortable_attributes: NotSet, ranking_rules: NotSet, stop_words: NotSet, non_separator_tokens: NotSet, separator_tokens: NotSet, dictionary: NotSet, synonyms: NotSet, distinct_attribute: NotSet, proximity_precision: NotSet, typo_tolerance: NotSet, faceting: NotSet, pagination: NotSet, embedders: NotSet, search_cutoff_ms: NotSet, localized_attributes: NotSet, facet_search: NotSet, prefix_search: NotSet, _kind: PhantomData<meilisearch_types::settings::Unchecked> } }, kind: SettingsUpdate { index_uid: "doggos", new_settings: Settings { displayed_attributes: WildcardSetting(NotSet), searchable_attributes: WildcardSetting(NotSet), filterable_attributes: Set({"catto"}), sortable_attributes: NotSet, ranking_rules: NotSet, stop_words: NotSet, non_separator_tokens: NotSet, separator_tokens: NotSet, dictionary: NotSet, synonyms: NotSet, distinct_attribute: NotSet, proximity_precision: NotSet, typo_tolerance: NotSet, faceting: NotSet, pagination: NotSet, embedders: NotSet, search_cutoff_ms: NotSet, localized_attributes: NotSet, facet_search: NotSet, prefix_search: NotSet, _kind: PhantomData<meilisearch_types::settings::Unchecked> }, is_deletion: false, allow_index_creation: true }} | ||||
| 1 {uid: 1, status: enqueued, details: { received_documents: 3, indexed_documents: None }, kind: DocumentAdditionOrUpdate { index_uid: "doggos", primary_key: Some("id"), method: ReplaceDocuments, content_file: 00000000-0000-0000-0000-000000000000, documents_count: 3, allow_index_creation: true }} | ||||
| ---------------------------------------------------------------------- | ||||
| ### Status: | ||||
|   | ||||
| @@ -1,13 +1,12 @@ | ||||
| --- | ||||
| source: crates/crates/index-scheduler/src/lib.rs | ||||
| snapshot_kind: text | ||||
| source: crates/index-scheduler/src/lib.rs | ||||
| --- | ||||
| ### Autobatching Enabled = true | ||||
| ### Processing batch None: | ||||
| [] | ||||
| ---------------------------------------------------------------------- | ||||
| ### All Tasks: | ||||
| 0 {uid: 0, batch_uid: 0, status: succeeded, details: { settings: Settings { displayed_attributes: WildcardSetting(NotSet), searchable_attributes: WildcardSetting(NotSet), filterable_attributes: NotSet, sortable_attributes: NotSet, ranking_rules: NotSet, stop_words: NotSet, non_separator_tokens: NotSet, separator_tokens: NotSet, dictionary: NotSet, synonyms: NotSet, distinct_attribute: NotSet, proximity_precision: NotSet, typo_tolerance: NotSet, faceting: NotSet, pagination: NotSet, embedders: Set({"A_fakerest": Set(EmbeddingSettings { source: Set(Rest), model: NotSet, revision: NotSet, api_key: Set("My super secret"), dimensions: Set(384), binary_quantized: NotSet, document_template: NotSet, document_template_max_bytes: NotSet, url: Set("http://localhost:7777"), request: Set(String("{{text}}")), response: Set(String("{{embedding}}")), headers: NotSet, distribution: NotSet }), "B_small_hf": Set(EmbeddingSettings { source: Set(HuggingFace), model: Set("sentence-transformers/all-MiniLM-L6-v2"), revision: Set("e4ce9877abf3edfe10b0d82785e83bdcb973e22e"), api_key: NotSet, dimensions: NotSet, binary_quantized: NotSet, document_template: Set("{{doc.doggo}} the {{doc.breed}} best doggo"), document_template_max_bytes: NotSet, url: NotSet, request: NotSet, response: NotSet, headers: NotSet, distribution: NotSet })}), search_cutoff_ms: NotSet, localized_attributes: NotSet, _kind: PhantomData<meilisearch_types::settings::Unchecked> } }, kind: SettingsUpdate { index_uid: "doggos", new_settings: Settings { displayed_attributes: WildcardSetting(NotSet), searchable_attributes: WildcardSetting(NotSet), filterable_attributes: NotSet, sortable_attributes: NotSet, ranking_rules: NotSet, stop_words: NotSet, non_separator_tokens: NotSet, separator_tokens: NotSet, dictionary: NotSet, synonyms: NotSet, distinct_attribute: NotSet, proximity_precision: NotSet, typo_tolerance: NotSet, faceting: NotSet, pagination: NotSet, embedders: Set({"A_fakerest": Set(EmbeddingSettings { source: Set(Rest), model: NotSet, revision: NotSet, api_key: Set("My super secret"), dimensions: Set(384), binary_quantized: NotSet, document_template: NotSet, document_template_max_bytes: NotSet, url: Set("http://localhost:7777"), request: Set(String("{{text}}")), response: Set(String("{{embedding}}")), headers: NotSet, distribution: NotSet }), "B_small_hf": Set(EmbeddingSettings { source: Set(HuggingFace), model: Set("sentence-transformers/all-MiniLM-L6-v2"), revision: Set("e4ce9877abf3edfe10b0d82785e83bdcb973e22e"), api_key: NotSet, dimensions: NotSet, binary_quantized: NotSet, document_template: Set("{{doc.doggo}} the {{doc.breed}} best doggo"), document_template_max_bytes: NotSet, url: NotSet, request: NotSet, response: NotSet, headers: NotSet, distribution: NotSet })}), search_cutoff_ms: NotSet, localized_attributes: NotSet, _kind: PhantomData<meilisearch_types::settings::Unchecked> }, is_deletion: false, allow_index_creation: true }} | ||||
| 0 {uid: 0, batch_uid: 0, status: succeeded, details: { settings: Settings { displayed_attributes: WildcardSetting(NotSet), searchable_attributes: WildcardSetting(NotSet), filterable_attributes: NotSet, sortable_attributes: NotSet, ranking_rules: NotSet, stop_words: NotSet, non_separator_tokens: NotSet, separator_tokens: NotSet, dictionary: NotSet, synonyms: NotSet, distinct_attribute: NotSet, proximity_precision: NotSet, typo_tolerance: NotSet, faceting: NotSet, pagination: NotSet, embedders: Set({"A_fakerest": Set(EmbeddingSettings { source: Set(Rest), model: NotSet, revision: NotSet, api_key: Set("My super secret"), dimensions: Set(384), binary_quantized: NotSet, document_template: NotSet, document_template_max_bytes: NotSet, url: Set("http://localhost:7777"), request: Set(String("{{text}}")), response: Set(String("{{embedding}}")), headers: NotSet, distribution: NotSet }), "B_small_hf": Set(EmbeddingSettings { source: Set(HuggingFace), model: Set("sentence-transformers/all-MiniLM-L6-v2"), revision: Set("e4ce9877abf3edfe10b0d82785e83bdcb973e22e"), api_key: NotSet, dimensions: NotSet, binary_quantized: NotSet, document_template: Set("{{doc.doggo}} the {{doc.breed}} best doggo"), document_template_max_bytes: NotSet, url: NotSet, request: NotSet, response: NotSet, headers: NotSet, distribution: NotSet })}), search_cutoff_ms: NotSet, localized_attributes: NotSet, facet_search: NotSet, prefix_search: NotSet, _kind: PhantomData<meilisearch_types::settings::Unchecked> } }, kind: SettingsUpdate { index_uid: "doggos", new_settings: Settings { displayed_attributes: WildcardSetting(NotSet), searchable_attributes: WildcardSetting(NotSet), filterable_attributes: NotSet, sortable_attributes: NotSet, ranking_rules: NotSet, stop_words: NotSet, non_separator_tokens: NotSet, separator_tokens: NotSet, dictionary: NotSet, synonyms: NotSet, distinct_attribute: NotSet, proximity_precision: NotSet, typo_tolerance: NotSet, faceting: NotSet, pagination: NotSet, embedders: Set({"A_fakerest": Set(EmbeddingSettings { source: Set(Rest), model: NotSet, revision: NotSet, api_key: Set("My super secret"), dimensions: Set(384), binary_quantized: NotSet, document_template: NotSet, document_template_max_bytes: NotSet, url: Set("http://localhost:7777"), request: Set(String("{{text}}")), response: Set(String("{{embedding}}")), headers: NotSet, distribution: NotSet }), "B_small_hf": Set(EmbeddingSettings { source: Set(HuggingFace), model: Set("sentence-transformers/all-MiniLM-L6-v2"), revision: Set("e4ce9877abf3edfe10b0d82785e83bdcb973e22e"), api_key: NotSet, dimensions: NotSet, binary_quantized: NotSet, document_template: Set("{{doc.doggo}} the {{doc.breed}} best doggo"), document_template_max_bytes: NotSet, url: NotSet, request: NotSet, response: NotSet, headers: NotSet, distribution: NotSet })}), search_cutoff_ms: NotSet, localized_attributes: NotSet, facet_search: NotSet, prefix_search: NotSet, _kind: PhantomData<meilisearch_types::settings::Unchecked> }, is_deletion: false, allow_index_creation: true }} | ||||
| 1 {uid: 1, batch_uid: 1, status: succeeded, details: { received_documents: 1, indexed_documents: Some(1) }, kind: DocumentAdditionOrUpdate { index_uid: "doggos", primary_key: Some("id"), method: UpdateDocuments, content_file: 00000000-0000-0000-0000-000000000000, documents_count: 1, allow_index_creation: true }} | ||||
| 2 {uid: 2, batch_uid: 2, status: succeeded, details: { received_documents: 1, indexed_documents: Some(1) }, kind: DocumentAdditionOrUpdate { index_uid: "doggos", primary_key: None, method: UpdateDocuments, content_file: 00000000-0000-0000-0000-000000000001, documents_count: 1, allow_index_creation: true }} | ||||
| ---------------------------------------------------------------------- | ||||
|   | ||||
| @@ -1,13 +1,12 @@ | ||||
| --- | ||||
| source: crates/crates/index-scheduler/src/lib.rs | ||||
| snapshot_kind: text | ||||
| source: crates/index-scheduler/src/lib.rs | ||||
| --- | ||||
| ### Autobatching Enabled = true | ||||
| ### Processing batch None: | ||||
| [] | ||||
| ---------------------------------------------------------------------- | ||||
| ### All Tasks: | ||||
| 0 {uid: 0, batch_uid: 0, status: succeeded, details: { settings: Settings { displayed_attributes: WildcardSetting(NotSet), searchable_attributes: WildcardSetting(NotSet), filterable_attributes: NotSet, sortable_attributes: NotSet, ranking_rules: NotSet, stop_words: NotSet, non_separator_tokens: NotSet, separator_tokens: NotSet, dictionary: NotSet, synonyms: NotSet, distinct_attribute: NotSet, proximity_precision: NotSet, typo_tolerance: NotSet, faceting: NotSet, pagination: NotSet, embedders: Set({"A_fakerest": Set(EmbeddingSettings { source: Set(Rest), model: NotSet, revision: NotSet, api_key: Set("My super secret"), dimensions: Set(384), binary_quantized: NotSet, document_template: NotSet, document_template_max_bytes: NotSet, url: Set("http://localhost:7777"), request: Set(String("{{text}}")), response: Set(String("{{embedding}}")), headers: NotSet, distribution: NotSet }), "B_small_hf": Set(EmbeddingSettings { source: Set(HuggingFace), model: Set("sentence-transformers/all-MiniLM-L6-v2"), revision: Set("e4ce9877abf3edfe10b0d82785e83bdcb973e22e"), api_key: NotSet, dimensions: NotSet, binary_quantized: NotSet, document_template: Set("{{doc.doggo}} the {{doc.breed}} best doggo"), document_template_max_bytes: NotSet, url: NotSet, request: NotSet, response: NotSet, headers: NotSet, distribution: NotSet })}), search_cutoff_ms: NotSet, localized_attributes: NotSet, _kind: PhantomData<meilisearch_types::settings::Unchecked> } }, kind: SettingsUpdate { index_uid: "doggos", new_settings: Settings { displayed_attributes: WildcardSetting(NotSet), searchable_attributes: WildcardSetting(NotSet), filterable_attributes: NotSet, sortable_attributes: NotSet, ranking_rules: NotSet, stop_words: NotSet, non_separator_tokens: NotSet, separator_tokens: NotSet, dictionary: NotSet, synonyms: NotSet, distinct_attribute: NotSet, proximity_precision: NotSet, typo_tolerance: NotSet, faceting: NotSet, pagination: NotSet, embedders: Set({"A_fakerest": Set(EmbeddingSettings { source: Set(Rest), model: NotSet, revision: NotSet, api_key: Set("My super secret"), dimensions: Set(384), binary_quantized: NotSet, document_template: NotSet, document_template_max_bytes: NotSet, url: Set("http://localhost:7777"), request: Set(String("{{text}}")), response: Set(String("{{embedding}}")), headers: NotSet, distribution: NotSet }), "B_small_hf": Set(EmbeddingSettings { source: Set(HuggingFace), model: Set("sentence-transformers/all-MiniLM-L6-v2"), revision: Set("e4ce9877abf3edfe10b0d82785e83bdcb973e22e"), api_key: NotSet, dimensions: NotSet, binary_quantized: NotSet, document_template: Set("{{doc.doggo}} the {{doc.breed}} best doggo"), document_template_max_bytes: NotSet, url: NotSet, request: NotSet, response: NotSet, headers: NotSet, distribution: NotSet })}), search_cutoff_ms: NotSet, localized_attributes: NotSet, _kind: PhantomData<meilisearch_types::settings::Unchecked> }, is_deletion: false, allow_index_creation: true }} | ||||
| 0 {uid: 0, batch_uid: 0, status: succeeded, details: { settings: Settings { displayed_attributes: WildcardSetting(NotSet), searchable_attributes: WildcardSetting(NotSet), filterable_attributes: NotSet, sortable_attributes: NotSet, ranking_rules: NotSet, stop_words: NotSet, non_separator_tokens: NotSet, separator_tokens: NotSet, dictionary: NotSet, synonyms: NotSet, distinct_attribute: NotSet, proximity_precision: NotSet, typo_tolerance: NotSet, faceting: NotSet, pagination: NotSet, embedders: Set({"A_fakerest": Set(EmbeddingSettings { source: Set(Rest), model: NotSet, revision: NotSet, api_key: Set("My super secret"), dimensions: Set(384), binary_quantized: NotSet, document_template: NotSet, document_template_max_bytes: NotSet, url: Set("http://localhost:7777"), request: Set(String("{{text}}")), response: Set(String("{{embedding}}")), headers: NotSet, distribution: NotSet }), "B_small_hf": Set(EmbeddingSettings { source: Set(HuggingFace), model: Set("sentence-transformers/all-MiniLM-L6-v2"), revision: Set("e4ce9877abf3edfe10b0d82785e83bdcb973e22e"), api_key: NotSet, dimensions: NotSet, binary_quantized: NotSet, document_template: Set("{{doc.doggo}} the {{doc.breed}} best doggo"), document_template_max_bytes: NotSet, url: NotSet, request: NotSet, response: NotSet, headers: NotSet, distribution: NotSet })}), search_cutoff_ms: NotSet, localized_attributes: NotSet, facet_search: NotSet, prefix_search: NotSet, _kind: PhantomData<meilisearch_types::settings::Unchecked> } }, kind: SettingsUpdate { index_uid: "doggos", new_settings: Settings { displayed_attributes: WildcardSetting(NotSet), searchable_attributes: WildcardSetting(NotSet), filterable_attributes: NotSet, sortable_attributes: NotSet, ranking_rules: NotSet, stop_words: NotSet, non_separator_tokens: NotSet, separator_tokens: NotSet, dictionary: NotSet, synonyms: NotSet, distinct_attribute: NotSet, proximity_precision: NotSet, typo_tolerance: NotSet, faceting: NotSet, pagination: NotSet, embedders: Set({"A_fakerest": Set(EmbeddingSettings { source: Set(Rest), model: NotSet, revision: NotSet, api_key: Set("My super secret"), dimensions: Set(384), binary_quantized: NotSet, document_template: NotSet, document_template_max_bytes: NotSet, url: Set("http://localhost:7777"), request: Set(String("{{text}}")), response: Set(String("{{embedding}}")), headers: NotSet, distribution: NotSet }), "B_small_hf": Set(EmbeddingSettings { source: Set(HuggingFace), model: Set("sentence-transformers/all-MiniLM-L6-v2"), revision: Set("e4ce9877abf3edfe10b0d82785e83bdcb973e22e"), api_key: NotSet, dimensions: NotSet, binary_quantized: NotSet, document_template: Set("{{doc.doggo}} the {{doc.breed}} best doggo"), document_template_max_bytes: NotSet, url: NotSet, request: NotSet, response: NotSet, headers: NotSet, distribution: NotSet })}), search_cutoff_ms: NotSet, localized_attributes: NotSet, facet_search: NotSet, prefix_search: NotSet, _kind: PhantomData<meilisearch_types::settings::Unchecked> }, is_deletion: false, allow_index_creation: true }} | ||||
| 1 {uid: 1, batch_uid: 1, status: succeeded, details: { received_documents: 1, indexed_documents: Some(1) }, kind: DocumentAdditionOrUpdate { index_uid: "doggos", primary_key: Some("id"), method: UpdateDocuments, content_file: 00000000-0000-0000-0000-000000000000, documents_count: 1, allow_index_creation: true }} | ||||
| 2 {uid: 2, status: enqueued, details: { received_documents: 1, indexed_documents: None }, kind: DocumentAdditionOrUpdate { index_uid: "doggos", primary_key: None, method: UpdateDocuments, content_file: 00000000-0000-0000-0000-000000000001, documents_count: 1, allow_index_creation: true }} | ||||
| ---------------------------------------------------------------------- | ||||
|   | ||||
| @@ -1,13 +1,12 @@ | ||||
| --- | ||||
| source: crates/crates/index-scheduler/src/lib.rs | ||||
| snapshot_kind: text | ||||
| source: crates/index-scheduler/src/lib.rs | ||||
| --- | ||||
| ### Autobatching Enabled = true | ||||
| ### Processing batch None: | ||||
| [] | ||||
| ---------------------------------------------------------------------- | ||||
| ### All Tasks: | ||||
| 0 {uid: 0, batch_uid: 0, status: succeeded, details: { settings: Settings { displayed_attributes: WildcardSetting(NotSet), searchable_attributes: WildcardSetting(NotSet), filterable_attributes: NotSet, sortable_attributes: NotSet, ranking_rules: NotSet, stop_words: NotSet, non_separator_tokens: NotSet, separator_tokens: NotSet, dictionary: NotSet, synonyms: NotSet, distinct_attribute: NotSet, proximity_precision: NotSet, typo_tolerance: NotSet, faceting: NotSet, pagination: NotSet, embedders: Set({"A_fakerest": Set(EmbeddingSettings { source: Set(Rest), model: NotSet, revision: NotSet, api_key: Set("My super secret"), dimensions: Set(384), binary_quantized: NotSet, document_template: NotSet, document_template_max_bytes: NotSet, url: Set("http://localhost:7777"), request: Set(String("{{text}}")), response: Set(String("{{embedding}}")), headers: NotSet, distribution: NotSet }), "B_small_hf": Set(EmbeddingSettings { source: Set(HuggingFace), model: Set("sentence-transformers/all-MiniLM-L6-v2"), revision: Set("e4ce9877abf3edfe10b0d82785e83bdcb973e22e"), api_key: NotSet, dimensions: NotSet, binary_quantized: NotSet, document_template: Set("{{doc.doggo}} the {{doc.breed}} best doggo"), document_template_max_bytes: NotSet, url: NotSet, request: NotSet, response: NotSet, headers: NotSet, distribution: NotSet })}), search_cutoff_ms: NotSet, localized_attributes: NotSet, _kind: PhantomData<meilisearch_types::settings::Unchecked> } }, kind: SettingsUpdate { index_uid: "doggos", new_settings: Settings { displayed_attributes: WildcardSetting(NotSet), searchable_attributes: WildcardSetting(NotSet), filterable_attributes: NotSet, sortable_attributes: NotSet, ranking_rules: NotSet, stop_words: NotSet, non_separator_tokens: NotSet, separator_tokens: NotSet, dictionary: NotSet, synonyms: NotSet, distinct_attribute: NotSet, proximity_precision: NotSet, typo_tolerance: NotSet, faceting: NotSet, pagination: NotSet, embedders: Set({"A_fakerest": Set(EmbeddingSettings { source: Set(Rest), model: NotSet, revision: NotSet, api_key: Set("My super secret"), dimensions: Set(384), binary_quantized: NotSet, document_template: NotSet, document_template_max_bytes: NotSet, url: Set("http://localhost:7777"), request: Set(String("{{text}}")), response: Set(String("{{embedding}}")), headers: NotSet, distribution: NotSet }), "B_small_hf": Set(EmbeddingSettings { source: Set(HuggingFace), model: Set("sentence-transformers/all-MiniLM-L6-v2"), revision: Set("e4ce9877abf3edfe10b0d82785e83bdcb973e22e"), api_key: NotSet, dimensions: NotSet, binary_quantized: NotSet, document_template: Set("{{doc.doggo}} the {{doc.breed}} best doggo"), document_template_max_bytes: NotSet, url: NotSet, request: NotSet, response: NotSet, headers: NotSet, distribution: NotSet })}), search_cutoff_ms: NotSet, localized_attributes: NotSet, _kind: PhantomData<meilisearch_types::settings::Unchecked> }, is_deletion: false, allow_index_creation: true }} | ||||
| 0 {uid: 0, batch_uid: 0, status: succeeded, details: { settings: Settings { displayed_attributes: WildcardSetting(NotSet), searchable_attributes: WildcardSetting(NotSet), filterable_attributes: NotSet, sortable_attributes: NotSet, ranking_rules: NotSet, stop_words: NotSet, non_separator_tokens: NotSet, separator_tokens: NotSet, dictionary: NotSet, synonyms: NotSet, distinct_attribute: NotSet, proximity_precision: NotSet, typo_tolerance: NotSet, faceting: NotSet, pagination: NotSet, embedders: Set({"A_fakerest": Set(EmbeddingSettings { source: Set(Rest), model: NotSet, revision: NotSet, api_key: Set("My super secret"), dimensions: Set(384), binary_quantized: NotSet, document_template: NotSet, document_template_max_bytes: NotSet, url: Set("http://localhost:7777"), request: Set(String("{{text}}")), response: Set(String("{{embedding}}")), headers: NotSet, distribution: NotSet }), "B_small_hf": Set(EmbeddingSettings { source: Set(HuggingFace), model: Set("sentence-transformers/all-MiniLM-L6-v2"), revision: Set("e4ce9877abf3edfe10b0d82785e83bdcb973e22e"), api_key: NotSet, dimensions: NotSet, binary_quantized: NotSet, document_template: Set("{{doc.doggo}} the {{doc.breed}} best doggo"), document_template_max_bytes: NotSet, url: NotSet, request: NotSet, response: NotSet, headers: NotSet, distribution: NotSet })}), search_cutoff_ms: NotSet, localized_attributes: NotSet, facet_search: NotSet, prefix_search: NotSet, _kind: PhantomData<meilisearch_types::settings::Unchecked> } }, kind: SettingsUpdate { index_uid: "doggos", new_settings: Settings { displayed_attributes: WildcardSetting(NotSet), searchable_attributes: WildcardSetting(NotSet), filterable_attributes: NotSet, sortable_attributes: NotSet, ranking_rules: NotSet, stop_words: NotSet, non_separator_tokens: NotSet, separator_tokens: NotSet, dictionary: NotSet, synonyms: NotSet, distinct_attribute: NotSet, proximity_precision: NotSet, typo_tolerance: NotSet, faceting: NotSet, pagination: NotSet, embedders: Set({"A_fakerest": Set(EmbeddingSettings { source: Set(Rest), model: NotSet, revision: NotSet, api_key: Set("My super secret"), dimensions: Set(384), binary_quantized: NotSet, document_template: NotSet, document_template_max_bytes: NotSet, url: Set("http://localhost:7777"), request: Set(String("{{text}}")), response: Set(String("{{embedding}}")), headers: NotSet, distribution: NotSet }), "B_small_hf": Set(EmbeddingSettings { source: Set(HuggingFace), model: Set("sentence-transformers/all-MiniLM-L6-v2"), revision: Set("e4ce9877abf3edfe10b0d82785e83bdcb973e22e"), api_key: NotSet, dimensions: NotSet, binary_quantized: NotSet, document_template: Set("{{doc.doggo}} the {{doc.breed}} best doggo"), document_template_max_bytes: NotSet, url: NotSet, request: NotSet, response: NotSet, headers: NotSet, distribution: NotSet })}), search_cutoff_ms: NotSet, localized_attributes: NotSet, facet_search: NotSet, prefix_search: NotSet, _kind: PhantomData<meilisearch_types::settings::Unchecked> }, is_deletion: false, allow_index_creation: true }} | ||||
| 1 {uid: 1, batch_uid: 1, status: succeeded, details: { received_documents: 1, indexed_documents: Some(1) }, kind: DocumentAdditionOrUpdate { index_uid: "doggos", primary_key: Some("id"), method: UpdateDocuments, content_file: 00000000-0000-0000-0000-000000000000, documents_count: 1, allow_index_creation: true }} | ||||
| ---------------------------------------------------------------------- | ||||
| ### Status: | ||||
|   | ||||
| @@ -1,13 +1,12 @@ | ||||
| --- | ||||
| source: crates/index-scheduler/src/lib.rs | ||||
| snapshot_kind: text | ||||
| --- | ||||
| ### Autobatching Enabled = true | ||||
| ### Processing batch None: | ||||
| [] | ||||
| ---------------------------------------------------------------------- | ||||
| ### All Tasks: | ||||
| 0 {uid: 0, batch_uid: 0, status: succeeded, details: { settings: Settings { displayed_attributes: WildcardSetting(NotSet), searchable_attributes: WildcardSetting(NotSet), filterable_attributes: NotSet, sortable_attributes: NotSet, ranking_rules: NotSet, stop_words: NotSet, non_separator_tokens: NotSet, separator_tokens: NotSet, dictionary: NotSet, synonyms: NotSet, distinct_attribute: NotSet, proximity_precision: NotSet, typo_tolerance: NotSet, faceting: NotSet, pagination: NotSet, embedders: Set({"A_fakerest": Set(EmbeddingSettings { source: Set(Rest), model: NotSet, revision: NotSet, api_key: Set("My super secret"), dimensions: Set(384), binary_quantized: NotSet, document_template: NotSet, document_template_max_bytes: NotSet, url: Set("http://localhost:7777"), request: Set(String("{{text}}")), response: Set(String("{{embedding}}")), headers: NotSet, distribution: NotSet }), "B_small_hf": Set(EmbeddingSettings { source: Set(HuggingFace), model: Set("sentence-transformers/all-MiniLM-L6-v2"), revision: Set("e4ce9877abf3edfe10b0d82785e83bdcb973e22e"), api_key: NotSet, dimensions: NotSet, binary_quantized: NotSet, document_template: Set("{{doc.doggo}} the {{doc.breed}} best doggo"), document_template_max_bytes: NotSet, url: NotSet, request: NotSet, response: NotSet, headers: NotSet, distribution: NotSet })}), search_cutoff_ms: NotSet, localized_attributes: NotSet, _kind: PhantomData<meilisearch_types::settings::Unchecked> } }, kind: SettingsUpdate { index_uid: "doggos", new_settings: Settings { displayed_attributes: WildcardSetting(NotSet), searchable_attributes: WildcardSetting(NotSet), filterable_attributes: NotSet, sortable_attributes: NotSet, ranking_rules: NotSet, stop_words: NotSet, non_separator_tokens: NotSet, separator_tokens: NotSet, dictionary: NotSet, synonyms: NotSet, distinct_attribute: NotSet, proximity_precision: NotSet, typo_tolerance: NotSet, faceting: NotSet, pagination: NotSet, embedders: Set({"A_fakerest": Set(EmbeddingSettings { source: Set(Rest), model: NotSet, revision: NotSet, api_key: Set("My super secret"), dimensions: Set(384), binary_quantized: NotSet, document_template: NotSet, document_template_max_bytes: NotSet, url: Set("http://localhost:7777"), request: Set(String("{{text}}")), response: Set(String("{{embedding}}")), headers: NotSet, distribution: NotSet }), "B_small_hf": Set(EmbeddingSettings { source: Set(HuggingFace), model: Set("sentence-transformers/all-MiniLM-L6-v2"), revision: Set("e4ce9877abf3edfe10b0d82785e83bdcb973e22e"), api_key: NotSet, dimensions: NotSet, binary_quantized: NotSet, document_template: Set("{{doc.doggo}} the {{doc.breed}} best doggo"), document_template_max_bytes: NotSet, url: NotSet, request: NotSet, response: NotSet, headers: NotSet, distribution: NotSet })}), search_cutoff_ms: NotSet, localized_attributes: NotSet, _kind: PhantomData<meilisearch_types::settings::Unchecked> }, is_deletion: false, allow_index_creation: true }} | ||||
| 0 {uid: 0, batch_uid: 0, status: succeeded, details: { settings: Settings { displayed_attributes: WildcardSetting(NotSet), searchable_attributes: WildcardSetting(NotSet), filterable_attributes: NotSet, sortable_attributes: NotSet, ranking_rules: NotSet, stop_words: NotSet, non_separator_tokens: NotSet, separator_tokens: NotSet, dictionary: NotSet, synonyms: NotSet, distinct_attribute: NotSet, proximity_precision: NotSet, typo_tolerance: NotSet, faceting: NotSet, pagination: NotSet, embedders: Set({"A_fakerest": Set(EmbeddingSettings { source: Set(Rest), model: NotSet, revision: NotSet, api_key: Set("My super secret"), dimensions: Set(384), binary_quantized: NotSet, document_template: NotSet, document_template_max_bytes: NotSet, url: Set("http://localhost:7777"), request: Set(String("{{text}}")), response: Set(String("{{embedding}}")), headers: NotSet, distribution: NotSet }), "B_small_hf": Set(EmbeddingSettings { source: Set(HuggingFace), model: Set("sentence-transformers/all-MiniLM-L6-v2"), revision: Set("e4ce9877abf3edfe10b0d82785e83bdcb973e22e"), api_key: NotSet, dimensions: NotSet, binary_quantized: NotSet, document_template: Set("{{doc.doggo}} the {{doc.breed}} best doggo"), document_template_max_bytes: NotSet, url: NotSet, request: NotSet, response: NotSet, headers: NotSet, distribution: NotSet })}), search_cutoff_ms: NotSet, localized_attributes: NotSet, facet_search: NotSet, prefix_search: NotSet, _kind: PhantomData<meilisearch_types::settings::Unchecked> } }, kind: SettingsUpdate { index_uid: "doggos", new_settings: Settings { displayed_attributes: WildcardSetting(NotSet), searchable_attributes: WildcardSetting(NotSet), filterable_attributes: NotSet, sortable_attributes: NotSet, ranking_rules: NotSet, stop_words: NotSet, non_separator_tokens: NotSet, separator_tokens: NotSet, dictionary: NotSet, synonyms: NotSet, distinct_attribute: NotSet, proximity_precision: NotSet, typo_tolerance: NotSet, faceting: NotSet, pagination: NotSet, embedders: Set({"A_fakerest": Set(EmbeddingSettings { source: Set(Rest), model: NotSet, revision: NotSet, api_key: Set("My super secret"), dimensions: Set(384), binary_quantized: NotSet, document_template: NotSet, document_template_max_bytes: NotSet, url: Set("http://localhost:7777"), request: Set(String("{{text}}")), response: Set(String("{{embedding}}")), headers: NotSet, distribution: NotSet }), "B_small_hf": Set(EmbeddingSettings { source: Set(HuggingFace), model: Set("sentence-transformers/all-MiniLM-L6-v2"), revision: Set("e4ce9877abf3edfe10b0d82785e83bdcb973e22e"), api_key: NotSet, dimensions: NotSet, binary_quantized: NotSet, document_template: Set("{{doc.doggo}} the {{doc.breed}} best doggo"), document_template_max_bytes: NotSet, url: NotSet, request: NotSet, response: NotSet, headers: NotSet, distribution: NotSet })}), search_cutoff_ms: NotSet, localized_attributes: NotSet, facet_search: NotSet, prefix_search: NotSet, _kind: PhantomData<meilisearch_types::settings::Unchecked> }, is_deletion: false, allow_index_creation: true }} | ||||
| 1 {uid: 1, status: enqueued, details: { received_documents: 1, indexed_documents: None }, kind: DocumentAdditionOrUpdate { index_uid: "doggos", primary_key: Some("id"), method: UpdateDocuments, content_file: 00000000-0000-0000-0000-000000000000, documents_count: 1, allow_index_creation: true }} | ||||
| ---------------------------------------------------------------------- | ||||
| ### Status: | ||||
|   | ||||
| @@ -1,13 +1,12 @@ | ||||
| --- | ||||
| source: crates/index-scheduler/src/lib.rs | ||||
| snapshot_kind: text | ||||
| --- | ||||
| ### Autobatching Enabled = true | ||||
| ### Processing batch None: | ||||
| [] | ||||
| ---------------------------------------------------------------------- | ||||
| ### All Tasks: | ||||
| 0 {uid: 0, status: enqueued, details: { settings: Settings { displayed_attributes: WildcardSetting(NotSet), searchable_attributes: WildcardSetting(NotSet), filterable_attributes: NotSet, sortable_attributes: NotSet, ranking_rules: NotSet, stop_words: NotSet, non_separator_tokens: NotSet, separator_tokens: NotSet, dictionary: NotSet, synonyms: NotSet, distinct_attribute: NotSet, proximity_precision: NotSet, typo_tolerance: NotSet, faceting: NotSet, pagination: NotSet, embedders: Set({"A_fakerest": Set(EmbeddingSettings { source: Set(Rest), model: NotSet, revision: NotSet, api_key: Set("My super secret"), dimensions: Set(384), binary_quantized: NotSet, document_template: NotSet, document_template_max_bytes: NotSet, url: Set("http://localhost:7777"), request: Set(String("{{text}}")), response: Set(String("{{embedding}}")), headers: NotSet, distribution: NotSet }), "B_small_hf": Set(EmbeddingSettings { source: Set(HuggingFace), model: Set("sentence-transformers/all-MiniLM-L6-v2"), revision: Set("e4ce9877abf3edfe10b0d82785e83bdcb973e22e"), api_key: NotSet, dimensions: NotSet, binary_quantized: NotSet, document_template: Set("{{doc.doggo}} the {{doc.breed}} best doggo"), document_template_max_bytes: NotSet, url: NotSet, request: NotSet, response: NotSet, headers: NotSet, distribution: NotSet })}), search_cutoff_ms: NotSet, localized_attributes: NotSet, _kind: PhantomData<meilisearch_types::settings::Unchecked> } }, kind: SettingsUpdate { index_uid: "doggos", new_settings: Settings { displayed_attributes: WildcardSetting(NotSet), searchable_attributes: WildcardSetting(NotSet), filterable_attributes: NotSet, sortable_attributes: NotSet, ranking_rules: NotSet, stop_words: NotSet, non_separator_tokens: NotSet, separator_tokens: NotSet, dictionary: NotSet, synonyms: NotSet, distinct_attribute: NotSet, proximity_precision: NotSet, typo_tolerance: NotSet, faceting: NotSet, pagination: NotSet, embedders: Set({"A_fakerest": Set(EmbeddingSettings { source: Set(Rest), model: NotSet, revision: NotSet, api_key: Set("My super secret"), dimensions: Set(384), binary_quantized: NotSet, document_template: NotSet, document_template_max_bytes: NotSet, url: Set("http://localhost:7777"), request: Set(String("{{text}}")), response: Set(String("{{embedding}}")), headers: NotSet, distribution: NotSet }), "B_small_hf": Set(EmbeddingSettings { source: Set(HuggingFace), model: Set("sentence-transformers/all-MiniLM-L6-v2"), revision: Set("e4ce9877abf3edfe10b0d82785e83bdcb973e22e"), api_key: NotSet, dimensions: NotSet, binary_quantized: NotSet, document_template: Set("{{doc.doggo}} the {{doc.breed}} best doggo"), document_template_max_bytes: NotSet, url: NotSet, request: NotSet, response: NotSet, headers: NotSet, distribution: NotSet })}), search_cutoff_ms: NotSet, localized_attributes: NotSet, _kind: PhantomData<meilisearch_types::settings::Unchecked> }, is_deletion: false, allow_index_creation: true }} | ||||
| 0 {uid: 0, status: enqueued, details: { settings: Settings { displayed_attributes: WildcardSetting(NotSet), searchable_attributes: WildcardSetting(NotSet), filterable_attributes: NotSet, sortable_attributes: NotSet, ranking_rules: NotSet, stop_words: NotSet, non_separator_tokens: NotSet, separator_tokens: NotSet, dictionary: NotSet, synonyms: NotSet, distinct_attribute: NotSet, proximity_precision: NotSet, typo_tolerance: NotSet, faceting: NotSet, pagination: NotSet, embedders: Set({"A_fakerest": Set(EmbeddingSettings { source: Set(Rest), model: NotSet, revision: NotSet, api_key: Set("My super secret"), dimensions: Set(384), binary_quantized: NotSet, document_template: NotSet, document_template_max_bytes: NotSet, url: Set("http://localhost:7777"), request: Set(String("{{text}}")), response: Set(String("{{embedding}}")), headers: NotSet, distribution: NotSet }), "B_small_hf": Set(EmbeddingSettings { source: Set(HuggingFace), model: Set("sentence-transformers/all-MiniLM-L6-v2"), revision: Set("e4ce9877abf3edfe10b0d82785e83bdcb973e22e"), api_key: NotSet, dimensions: NotSet, binary_quantized: NotSet, document_template: Set("{{doc.doggo}} the {{doc.breed}} best doggo"), document_template_max_bytes: NotSet, url: NotSet, request: NotSet, response: NotSet, headers: NotSet, distribution: NotSet })}), search_cutoff_ms: NotSet, localized_attributes: NotSet, facet_search: NotSet, prefix_search: NotSet, _kind: PhantomData<meilisearch_types::settings::Unchecked> } }, kind: SettingsUpdate { index_uid: "doggos", new_settings: Settings { displayed_attributes: WildcardSetting(NotSet), searchable_attributes: WildcardSetting(NotSet), filterable_attributes: NotSet, sortable_attributes: NotSet, ranking_rules: NotSet, stop_words: NotSet, non_separator_tokens: NotSet, separator_tokens: NotSet, dictionary: NotSet, synonyms: NotSet, distinct_attribute: NotSet, proximity_precision: NotSet, typo_tolerance: NotSet, faceting: NotSet, pagination: NotSet, embedders: Set({"A_fakerest": Set(EmbeddingSettings { source: Set(Rest), model: NotSet, revision: NotSet, api_key: Set("My super secret"), dimensions: Set(384), binary_quantized: NotSet, document_template: NotSet, document_template_max_bytes: NotSet, url: Set("http://localhost:7777"), request: Set(String("{{text}}")), response: Set(String("{{embedding}}")), headers: NotSet, distribution: NotSet }), "B_small_hf": Set(EmbeddingSettings { source: Set(HuggingFace), model: Set("sentence-transformers/all-MiniLM-L6-v2"), revision: Set("e4ce9877abf3edfe10b0d82785e83bdcb973e22e"), api_key: NotSet, dimensions: NotSet, binary_quantized: NotSet, document_template: Set("{{doc.doggo}} the {{doc.breed}} best doggo"), document_template_max_bytes: NotSet, url: NotSet, request: NotSet, response: NotSet, headers: NotSet, distribution: NotSet })}), search_cutoff_ms: NotSet, localized_attributes: NotSet, facet_search: NotSet, prefix_search: NotSet, _kind: PhantomData<meilisearch_types::settings::Unchecked> }, is_deletion: false, allow_index_creation: true }} | ||||
| ---------------------------------------------------------------------- | ||||
| ### Status: | ||||
| enqueued [0,] | ||||
|   | ||||
| @@ -1,13 +1,12 @@ | ||||
| --- | ||||
| source: crates/index-scheduler/src/lib.rs | ||||
| snapshot_kind: text | ||||
| --- | ||||
| ### Autobatching Enabled = true | ||||
| ### Processing batch None: | ||||
| [] | ||||
| ---------------------------------------------------------------------- | ||||
| ### All Tasks: | ||||
| 0 {uid: 0, batch_uid: 0, status: succeeded, details: { settings: Settings { displayed_attributes: WildcardSetting(NotSet), searchable_attributes: WildcardSetting(NotSet), filterable_attributes: NotSet, sortable_attributes: NotSet, ranking_rules: NotSet, stop_words: NotSet, non_separator_tokens: NotSet, separator_tokens: NotSet, dictionary: NotSet, synonyms: NotSet, distinct_attribute: NotSet, proximity_precision: NotSet, typo_tolerance: NotSet, faceting: NotSet, pagination: NotSet, embedders: Set({"A_fakerest": Set(EmbeddingSettings { source: Set(Rest), model: NotSet, revision: NotSet, api_key: Set("My super secret"), dimensions: Set(384), binary_quantized: NotSet, document_template: NotSet, document_template_max_bytes: NotSet, url: Set("http://localhost:7777"), request: Set(String("{{text}}")), response: Set(String("{{embedding}}")), headers: NotSet, distribution: NotSet }), "B_small_hf": Set(EmbeddingSettings { source: Set(HuggingFace), model: Set("sentence-transformers/all-MiniLM-L6-v2"), revision: Set("e4ce9877abf3edfe10b0d82785e83bdcb973e22e"), api_key: NotSet, dimensions: NotSet, binary_quantized: NotSet, document_template: Set("{{doc.doggo}} the {{doc.breed}} best doggo"), document_template_max_bytes: NotSet, url: NotSet, request: NotSet, response: NotSet, headers: NotSet, distribution: NotSet })}), search_cutoff_ms: NotSet, localized_attributes: NotSet, _kind: PhantomData<meilisearch_types::settings::Unchecked> } }, kind: SettingsUpdate { index_uid: "doggos", new_settings: Settings { displayed_attributes: WildcardSetting(NotSet), searchable_attributes: WildcardSetting(NotSet), filterable_attributes: NotSet, sortable_attributes: NotSet, ranking_rules: NotSet, stop_words: NotSet, non_separator_tokens: NotSet, separator_tokens: NotSet, dictionary: NotSet, synonyms: NotSet, distinct_attribute: NotSet, proximity_precision: NotSet, typo_tolerance: NotSet, faceting: NotSet, pagination: NotSet, embedders: Set({"A_fakerest": Set(EmbeddingSettings { source: Set(Rest), model: NotSet, revision: NotSet, api_key: Set("My super secret"), dimensions: Set(384), binary_quantized: NotSet, document_template: NotSet, document_template_max_bytes: NotSet, url: Set("http://localhost:7777"), request: Set(String("{{text}}")), response: Set(String("{{embedding}}")), headers: NotSet, distribution: NotSet }), "B_small_hf": Set(EmbeddingSettings { source: Set(HuggingFace), model: Set("sentence-transformers/all-MiniLM-L6-v2"), revision: Set("e4ce9877abf3edfe10b0d82785e83bdcb973e22e"), api_key: NotSet, dimensions: NotSet, binary_quantized: NotSet, document_template: Set("{{doc.doggo}} the {{doc.breed}} best doggo"), document_template_max_bytes: NotSet, url: NotSet, request: NotSet, response: NotSet, headers: NotSet, distribution: NotSet })}), search_cutoff_ms: NotSet, localized_attributes: NotSet, _kind: PhantomData<meilisearch_types::settings::Unchecked> }, is_deletion: false, allow_index_creation: true }} | ||||
| 0 {uid: 0, batch_uid: 0, status: succeeded, details: { settings: Settings { displayed_attributes: WildcardSetting(NotSet), searchable_attributes: WildcardSetting(NotSet), filterable_attributes: NotSet, sortable_attributes: NotSet, ranking_rules: NotSet, stop_words: NotSet, non_separator_tokens: NotSet, separator_tokens: NotSet, dictionary: NotSet, synonyms: NotSet, distinct_attribute: NotSet, proximity_precision: NotSet, typo_tolerance: NotSet, faceting: NotSet, pagination: NotSet, embedders: Set({"A_fakerest": Set(EmbeddingSettings { source: Set(Rest), model: NotSet, revision: NotSet, api_key: Set("My super secret"), dimensions: Set(384), binary_quantized: NotSet, document_template: NotSet, document_template_max_bytes: NotSet, url: Set("http://localhost:7777"), request: Set(String("{{text}}")), response: Set(String("{{embedding}}")), headers: NotSet, distribution: NotSet }), "B_small_hf": Set(EmbeddingSettings { source: Set(HuggingFace), model: Set("sentence-transformers/all-MiniLM-L6-v2"), revision: Set("e4ce9877abf3edfe10b0d82785e83bdcb973e22e"), api_key: NotSet, dimensions: NotSet, binary_quantized: NotSet, document_template: Set("{{doc.doggo}} the {{doc.breed}} best doggo"), document_template_max_bytes: NotSet, url: NotSet, request: NotSet, response: NotSet, headers: NotSet, distribution: NotSet })}), search_cutoff_ms: NotSet, localized_attributes: NotSet, facet_search: NotSet, prefix_search: NotSet, _kind: PhantomData<meilisearch_types::settings::Unchecked> } }, kind: SettingsUpdate { index_uid: "doggos", new_settings: Settings { displayed_attributes: WildcardSetting(NotSet), searchable_attributes: WildcardSetting(NotSet), filterable_attributes: NotSet, sortable_attributes: NotSet, ranking_rules: NotSet, stop_words: NotSet, non_separator_tokens: NotSet, separator_tokens: NotSet, dictionary: NotSet, synonyms: NotSet, distinct_attribute: NotSet, proximity_precision: NotSet, typo_tolerance: NotSet, faceting: NotSet, pagination: NotSet, embedders: Set({"A_fakerest": Set(EmbeddingSettings { source: Set(Rest), model: NotSet, revision: NotSet, api_key: Set("My super secret"), dimensions: Set(384), binary_quantized: NotSet, document_template: NotSet, document_template_max_bytes: NotSet, url: Set("http://localhost:7777"), request: Set(String("{{text}}")), response: Set(String("{{embedding}}")), headers: NotSet, distribution: NotSet }), "B_small_hf": Set(EmbeddingSettings { source: Set(HuggingFace), model: Set("sentence-transformers/all-MiniLM-L6-v2"), revision: Set("e4ce9877abf3edfe10b0d82785e83bdcb973e22e"), api_key: NotSet, dimensions: NotSet, binary_quantized: NotSet, document_template: Set("{{doc.doggo}} the {{doc.breed}} best doggo"), document_template_max_bytes: NotSet, url: NotSet, request: NotSet, response: NotSet, headers: NotSet, distribution: NotSet })}), search_cutoff_ms: NotSet, localized_attributes: NotSet, facet_search: NotSet, prefix_search: NotSet, _kind: PhantomData<meilisearch_types::settings::Unchecked> }, is_deletion: false, allow_index_creation: true }} | ||||
| ---------------------------------------------------------------------- | ||||
| ### Status: | ||||
| enqueued [] | ||||
|   | ||||
| @@ -1,13 +1,12 @@ | ||||
| --- | ||||
| source: crates/index-scheduler/src/lib.rs | ||||
| snapshot_kind: text | ||||
| --- | ||||
| ### Autobatching Enabled = true | ||||
| ### Processing batch None: | ||||
| [] | ||||
| ---------------------------------------------------------------------- | ||||
| ### All Tasks: | ||||
| 0 {uid: 0, status: enqueued, details: { settings: Settings { displayed_attributes: WildcardSetting(NotSet), searchable_attributes: WildcardSetting(NotSet), filterable_attributes: NotSet, sortable_attributes: NotSet, ranking_rules: NotSet, stop_words: NotSet, non_separator_tokens: NotSet, separator_tokens: NotSet, dictionary: NotSet, synonyms: NotSet, distinct_attribute: NotSet, proximity_precision: NotSet, typo_tolerance: NotSet, faceting: NotSet, pagination: NotSet, embedders: Set({"default": Set(EmbeddingSettings { source: Set(Rest), model: NotSet, revision: NotSet, api_key: Set("My super secret"), dimensions: Set(4), binary_quantized: NotSet, document_template: NotSet, document_template_max_bytes: NotSet, url: Set("http://localhost:7777"), request: Set(String("{{text}}")), response: Set(String("{{embedding}}")), headers: NotSet, distribution: NotSet })}), search_cutoff_ms: NotSet, localized_attributes: NotSet, _kind: PhantomData<meilisearch_types::settings::Unchecked> } }, kind: SettingsUpdate { index_uid: "doggos", new_settings: Settings { displayed_attributes: WildcardSetting(NotSet), searchable_attributes: WildcardSetting(NotSet), filterable_attributes: NotSet, sortable_attributes: NotSet, ranking_rules: NotSet, stop_words: NotSet, non_separator_tokens: NotSet, separator_tokens: NotSet, dictionary: NotSet, synonyms: NotSet, distinct_attribute: NotSet, proximity_precision: NotSet, typo_tolerance: NotSet, faceting: NotSet, pagination: NotSet, embedders: Set({"default": Set(EmbeddingSettings { source: Set(Rest), model: NotSet, revision: NotSet, api_key: Set("My super secret"), dimensions: Set(4), binary_quantized: NotSet, document_template: NotSet, document_template_max_bytes: NotSet, url: Set("http://localhost:7777"), request: Set(String("{{text}}")), response: Set(String("{{embedding}}")), headers: NotSet, distribution: NotSet })}), search_cutoff_ms: NotSet, localized_attributes: NotSet, _kind: PhantomData<meilisearch_types::settings::Unchecked> }, is_deletion: false, allow_index_creation: true }} | ||||
| 0 {uid: 0, status: enqueued, details: { settings: Settings { displayed_attributes: WildcardSetting(NotSet), searchable_attributes: WildcardSetting(NotSet), filterable_attributes: NotSet, sortable_attributes: NotSet, ranking_rules: NotSet, stop_words: NotSet, non_separator_tokens: NotSet, separator_tokens: NotSet, dictionary: NotSet, synonyms: NotSet, distinct_attribute: NotSet, proximity_precision: NotSet, typo_tolerance: NotSet, faceting: NotSet, pagination: NotSet, embedders: Set({"default": Set(EmbeddingSettings { source: Set(Rest), model: NotSet, revision: NotSet, api_key: Set("My super secret"), dimensions: Set(4), binary_quantized: NotSet, document_template: NotSet, document_template_max_bytes: NotSet, url: Set("http://localhost:7777"), request: Set(String("{{text}}")), response: Set(String("{{embedding}}")), headers: NotSet, distribution: NotSet })}), search_cutoff_ms: NotSet, localized_attributes: NotSet, facet_search: NotSet, prefix_search: NotSet, _kind: PhantomData<meilisearch_types::settings::Unchecked> } }, kind: SettingsUpdate { index_uid: "doggos", new_settings: Settings { displayed_attributes: WildcardSetting(NotSet), searchable_attributes: WildcardSetting(NotSet), filterable_attributes: NotSet, sortable_attributes: NotSet, ranking_rules: NotSet, stop_words: NotSet, non_separator_tokens: NotSet, separator_tokens: NotSet, dictionary: NotSet, synonyms: NotSet, distinct_attribute: NotSet, proximity_precision: NotSet, typo_tolerance: NotSet, faceting: NotSet, pagination: NotSet, embedders: Set({"default": Set(EmbeddingSettings { source: Set(Rest), model: NotSet, revision: NotSet, api_key: Set("My super secret"), dimensions: Set(4), binary_quantized: NotSet, document_template: NotSet, document_template_max_bytes: NotSet, url: Set("http://localhost:7777"), request: Set(String("{{text}}")), response: Set(String("{{embedding}}")), headers: NotSet, distribution: NotSet })}), search_cutoff_ms: NotSet, localized_attributes: NotSet, facet_search: NotSet, prefix_search: NotSet, _kind: PhantomData<meilisearch_types::settings::Unchecked> }, is_deletion: false, allow_index_creation: true }} | ||||
| ---------------------------------------------------------------------- | ||||
| ### Status: | ||||
| enqueued [0,] | ||||
|   | ||||
| @@ -1,13 +1,12 @@ | ||||
| --- | ||||
| source: crates/index-scheduler/src/lib.rs | ||||
| snapshot_kind: text | ||||
| --- | ||||
| ### Autobatching Enabled = true | ||||
| ### Processing batch None: | ||||
| [] | ||||
| ---------------------------------------------------------------------- | ||||
| ### All Tasks: | ||||
| 0 {uid: 0, batch_uid: 0, status: succeeded, details: { settings: Settings { displayed_attributes: WildcardSetting(NotSet), searchable_attributes: WildcardSetting(NotSet), filterable_attributes: NotSet, sortable_attributes: NotSet, ranking_rules: NotSet, stop_words: NotSet, non_separator_tokens: NotSet, separator_tokens: NotSet, dictionary: NotSet, synonyms: NotSet, distinct_attribute: NotSet, proximity_precision: NotSet, typo_tolerance: NotSet, faceting: NotSet, pagination: NotSet, embedders: Set({"default": Set(EmbeddingSettings { source: Set(Rest), model: NotSet, revision: NotSet, api_key: Set("My super secret"), dimensions: Set(4), binary_quantized: NotSet, document_template: NotSet, document_template_max_bytes: NotSet, url: Set("http://localhost:7777"), request: Set(String("{{text}}")), response: Set(String("{{embedding}}")), headers: NotSet, distribution: NotSet })}), search_cutoff_ms: NotSet, localized_attributes: NotSet, _kind: PhantomData<meilisearch_types::settings::Unchecked> } }, kind: SettingsUpdate { index_uid: "doggos", new_settings: Settings { displayed_attributes: WildcardSetting(NotSet), searchable_attributes: WildcardSetting(NotSet), filterable_attributes: NotSet, sortable_attributes: NotSet, ranking_rules: NotSet, stop_words: NotSet, non_separator_tokens: NotSet, separator_tokens: NotSet, dictionary: NotSet, synonyms: NotSet, distinct_attribute: NotSet, proximity_precision: NotSet, typo_tolerance: NotSet, faceting: NotSet, pagination: NotSet, embedders: Set({"default": Set(EmbeddingSettings { source: Set(Rest), model: NotSet, revision: NotSet, api_key: Set("My super secret"), dimensions: Set(4), binary_quantized: NotSet, document_template: NotSet, document_template_max_bytes: NotSet, url: Set("http://localhost:7777"), request: Set(String("{{text}}")), response: Set(String("{{embedding}}")), headers: NotSet, distribution: NotSet })}), search_cutoff_ms: NotSet, localized_attributes: NotSet, _kind: PhantomData<meilisearch_types::settings::Unchecked> }, is_deletion: false, allow_index_creation: true }} | ||||
| 0 {uid: 0, batch_uid: 0, status: succeeded, details: { settings: Settings { displayed_attributes: WildcardSetting(NotSet), searchable_attributes: WildcardSetting(NotSet), filterable_attributes: NotSet, sortable_attributes: NotSet, ranking_rules: NotSet, stop_words: NotSet, non_separator_tokens: NotSet, separator_tokens: NotSet, dictionary: NotSet, synonyms: NotSet, distinct_attribute: NotSet, proximity_precision: NotSet, typo_tolerance: NotSet, faceting: NotSet, pagination: NotSet, embedders: Set({"default": Set(EmbeddingSettings { source: Set(Rest), model: NotSet, revision: NotSet, api_key: Set("My super secret"), dimensions: Set(4), binary_quantized: NotSet, document_template: NotSet, document_template_max_bytes: NotSet, url: Set("http://localhost:7777"), request: Set(String("{{text}}")), response: Set(String("{{embedding}}")), headers: NotSet, distribution: NotSet })}), search_cutoff_ms: NotSet, localized_attributes: NotSet, facet_search: NotSet, prefix_search: NotSet, _kind: PhantomData<meilisearch_types::settings::Unchecked> } }, kind: SettingsUpdate { index_uid: "doggos", new_settings: Settings { displayed_attributes: WildcardSetting(NotSet), searchable_attributes: WildcardSetting(NotSet), filterable_attributes: NotSet, sortable_attributes: NotSet, ranking_rules: NotSet, stop_words: NotSet, non_separator_tokens: NotSet, separator_tokens: NotSet, dictionary: NotSet, synonyms: NotSet, distinct_attribute: NotSet, proximity_precision: NotSet, typo_tolerance: NotSet, faceting: NotSet, pagination: NotSet, embedders: Set({"default": Set(EmbeddingSettings { source: Set(Rest), model: NotSet, revision: NotSet, api_key: Set("My super secret"), dimensions: Set(4), binary_quantized: NotSet, document_template: NotSet, document_template_max_bytes: NotSet, url: Set("http://localhost:7777"), request: Set(String("{{text}}")), response: Set(String("{{embedding}}")), headers: NotSet, distribution: NotSet })}), search_cutoff_ms: NotSet, localized_attributes: NotSet, facet_search: NotSet, prefix_search: NotSet, _kind: PhantomData<meilisearch_types::settings::Unchecked> }, is_deletion: false, allow_index_creation: true }} | ||||
| ---------------------------------------------------------------------- | ||||
| ### Status: | ||||
| enqueued [] | ||||
|   | ||||
| @@ -290,6 +290,8 @@ InvalidSearchDistinct                 , InvalidRequest       , BAD_REQUEST ; | ||||
| InvalidSettingsDisplayedAttributes    , InvalidRequest       , BAD_REQUEST ; | ||||
| InvalidSettingsDistinctAttribute      , InvalidRequest       , BAD_REQUEST ; | ||||
| InvalidSettingsProximityPrecision     , InvalidRequest       , BAD_REQUEST ; | ||||
| InvalidSettingsFacetSearch            , InvalidRequest       , BAD_REQUEST ; | ||||
| InvalidSettingsPrefixSearch           , InvalidRequest       , BAD_REQUEST ; | ||||
| InvalidSettingsFaceting               , InvalidRequest       , BAD_REQUEST ; | ||||
| InvalidSettingsFilterableAttributes   , InvalidRequest       , BAD_REQUEST ; | ||||
| InvalidSettingsPagination             , InvalidRequest       , BAD_REQUEST ; | ||||
|   | ||||
| @@ -8,7 +8,7 @@ use std::str::FromStr; | ||||
|  | ||||
| use deserr::{DeserializeError, Deserr, ErrorKind, MergeWithError, ValuePointerRef}; | ||||
| use fst::IntoStreamer; | ||||
| use milli::index::IndexEmbeddingConfig; | ||||
| use milli::index::{IndexEmbeddingConfig, PrefixSearch}; | ||||
| use milli::proximity::ProximityPrecision; | ||||
| use milli::update::Setting; | ||||
| use milli::{Criterion, CriterionError, Index, DEFAULT_VALUES_PER_FACET}; | ||||
| @@ -202,6 +202,12 @@ pub struct Settings<T> { | ||||
|     #[serde(default, skip_serializing_if = "Setting::is_not_set")] | ||||
|     #[deserr(default, error = DeserrJsonError<InvalidSettingsLocalizedAttributes>)] | ||||
|     pub localized_attributes: Setting<Vec<LocalizedAttributesRuleView>>, | ||||
|     #[serde(default, skip_serializing_if = "Setting::is_not_set")] | ||||
|     #[deserr(default, error = DeserrJsonError<InvalidSettingsFacetSearch>)] | ||||
|     pub facet_search: Setting<bool>, | ||||
|     #[serde(default, skip_serializing_if = "Setting::is_not_set")] | ||||
|     #[deserr(default, error = DeserrJsonError<InvalidSettingsPrefixSearch>)] | ||||
|     pub prefix_search: Setting<PrefixSearchSettings>, | ||||
|  | ||||
|     #[serde(skip)] | ||||
|     #[deserr(skip)] | ||||
| @@ -266,6 +272,8 @@ impl Settings<Checked> { | ||||
|             embedders: Setting::Reset, | ||||
|             search_cutoff_ms: Setting::Reset, | ||||
|             localized_attributes: Setting::Reset, | ||||
|             facet_search: Setting::NotSet, | ||||
|             prefix_search: Setting::NotSet, | ||||
|             _kind: PhantomData, | ||||
|         } | ||||
|     } | ||||
| @@ -290,6 +298,8 @@ impl Settings<Checked> { | ||||
|             embedders, | ||||
|             search_cutoff_ms, | ||||
|             localized_attributes: localized_attributes_rules, | ||||
|             facet_search, | ||||
|             prefix_search, | ||||
|             _kind, | ||||
|         } = self; | ||||
|  | ||||
| @@ -312,6 +322,8 @@ impl Settings<Checked> { | ||||
|             embedders, | ||||
|             search_cutoff_ms, | ||||
|             localized_attributes: localized_attributes_rules, | ||||
|             facet_search, | ||||
|             prefix_search, | ||||
|             _kind: PhantomData, | ||||
|         } | ||||
|     } | ||||
| @@ -360,6 +372,8 @@ impl Settings<Unchecked> { | ||||
|             embedders: self.embedders, | ||||
|             search_cutoff_ms: self.search_cutoff_ms, | ||||
|             localized_attributes: self.localized_attributes, | ||||
|             facet_search: self.facet_search, | ||||
|             prefix_search: self.prefix_search, | ||||
|             _kind: PhantomData, | ||||
|         } | ||||
|     } | ||||
| @@ -433,6 +447,8 @@ impl Settings<Unchecked> { | ||||
|                     Setting::Set(this) | ||||
|                 } | ||||
|             }, | ||||
|             prefix_search: other.prefix_search.or(self.prefix_search), | ||||
|             facet_search: other.facet_search.or(self.facet_search), | ||||
|             _kind: PhantomData, | ||||
|         } | ||||
|     } | ||||
| @@ -469,6 +485,8 @@ pub fn apply_settings_to_builder( | ||||
|         embedders, | ||||
|         search_cutoff_ms, | ||||
|         localized_attributes: localized_attributes_rules, | ||||
|         facet_search, | ||||
|         prefix_search, | ||||
|         _kind, | ||||
|     } = settings; | ||||
|  | ||||
| @@ -657,6 +675,20 @@ pub fn apply_settings_to_builder( | ||||
|         Setting::Reset => builder.reset_search_cutoff(), | ||||
|         Setting::NotSet => (), | ||||
|     } | ||||
|  | ||||
|     match prefix_search { | ||||
|         Setting::Set(prefix_search) => { | ||||
|             builder.set_prefix_search(PrefixSearch::from(*prefix_search)) | ||||
|         } | ||||
|         Setting::Reset => builder.reset_prefix_search(), | ||||
|         Setting::NotSet => (), | ||||
|     } | ||||
|  | ||||
|     match facet_search { | ||||
|         Setting::Set(facet_search) => builder.set_facet_search(*facet_search), | ||||
|         Setting::Reset => builder.reset_facet_search(), | ||||
|         Setting::NotSet => (), | ||||
|     } | ||||
| } | ||||
|  | ||||
| pub enum SecretPolicy { | ||||
| @@ -755,6 +787,10 @@ pub fn settings( | ||||
|  | ||||
|     let localized_attributes_rules = index.localized_attributes_rules(rtxn)?; | ||||
|  | ||||
|     let prefix_search = index.prefix_search(rtxn)?.map(PrefixSearchSettings::from); | ||||
|  | ||||
|     let facet_search = index.facet_search(rtxn)?; | ||||
|  | ||||
|     let mut settings = Settings { | ||||
|         displayed_attributes: match displayed_attributes { | ||||
|             Some(attrs) => Setting::Set(attrs), | ||||
| @@ -791,13 +827,14 @@ pub fn settings( | ||||
|             Some(rules) => Setting::Set(rules.into_iter().map(|r| r.into()).collect()), | ||||
|             None => Setting::Reset, | ||||
|         }, | ||||
|         prefix_search: Setting::Set(prefix_search.unwrap_or_default()), | ||||
|         facet_search: Setting::Set(facet_search), | ||||
|         _kind: PhantomData, | ||||
|     }; | ||||
|  | ||||
|     if let SecretPolicy::HideSecrets = secret_policy { | ||||
|         settings.hide_secrets() | ||||
|     } | ||||
|  | ||||
|     Ok(settings) | ||||
| } | ||||
|  | ||||
| @@ -964,6 +1001,32 @@ impl std::ops::Deref for WildcardSetting { | ||||
|     } | ||||
| } | ||||
|  | ||||
| #[derive(Default, Debug, Clone, Copy, PartialEq, Eq, Deserr, Serialize, Deserialize)] | ||||
| #[serde(deny_unknown_fields, rename_all = "camelCase")] | ||||
| #[deserr(error = DeserrJsonError<InvalidSettingsPrefixSearch>, rename_all = camelCase, deny_unknown_fields)] | ||||
| pub enum PrefixSearchSettings { | ||||
|     #[default] | ||||
|     IndexingTime, | ||||
|     Disabled, | ||||
| } | ||||
|  | ||||
| impl From<PrefixSearch> for PrefixSearchSettings { | ||||
|     fn from(value: PrefixSearch) -> Self { | ||||
|         match value { | ||||
|             PrefixSearch::IndexingTime => PrefixSearchSettings::IndexingTime, | ||||
|             PrefixSearch::Disabled => PrefixSearchSettings::Disabled, | ||||
|         } | ||||
|     } | ||||
| } | ||||
| impl From<PrefixSearchSettings> for PrefixSearch { | ||||
|     fn from(value: PrefixSearchSettings) -> Self { | ||||
|         match value { | ||||
|             PrefixSearchSettings::IndexingTime => PrefixSearch::IndexingTime, | ||||
|             PrefixSearchSettings::Disabled => PrefixSearch::Disabled, | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| #[cfg(test)] | ||||
| pub(crate) mod test { | ||||
|     use super::*; | ||||
| @@ -990,6 +1053,8 @@ pub(crate) mod test { | ||||
|             embedders: Setting::NotSet, | ||||
|             localized_attributes: Setting::NotSet, | ||||
|             search_cutoff_ms: Setting::NotSet, | ||||
|             facet_search: Setting::NotSet, | ||||
|             prefix_search: Setting::NotSet, | ||||
|             _kind: PhantomData::<Unchecked>, | ||||
|         }; | ||||
|  | ||||
| @@ -1019,6 +1084,8 @@ pub(crate) mod test { | ||||
|             embedders: Setting::NotSet, | ||||
|             localized_attributes: Setting::NotSet, | ||||
|             search_cutoff_ms: Setting::NotSet, | ||||
|             facet_search: Setting::NotSet, | ||||
|             prefix_search: Setting::NotSet, | ||||
|             _kind: PhantomData::<Unchecked>, | ||||
|         }; | ||||
|  | ||||
|   | ||||
| @@ -369,6 +369,30 @@ make_setting_route!( | ||||
|     SearchCutoffMsAnalytics | ||||
| ); | ||||
|  | ||||
| make_setting_route!( | ||||
|     "/facet-search", | ||||
|     put, | ||||
|     bool, | ||||
|     meilisearch_types::deserr::DeserrJsonError< | ||||
|         meilisearch_types::error::deserr_codes::InvalidSettingsFacetSearch, | ||||
|     >, | ||||
|     facet_search, | ||||
|     "facetSearch", | ||||
|     FacetSearchAnalytics | ||||
| ); | ||||
|  | ||||
| make_setting_route!( | ||||
|     "/prefix-search", | ||||
|     put, | ||||
|     meilisearch_types::settings::PrefixSearchSettings, | ||||
|     meilisearch_types::deserr::DeserrJsonError< | ||||
|         meilisearch_types::error::deserr_codes::InvalidSettingsPrefixSearch, | ||||
|     >, | ||||
|     prefix_search, | ||||
|     "prefixSearch", | ||||
|     PrefixSearchAnalytics | ||||
| ); | ||||
|  | ||||
| macro_rules! generate_configure { | ||||
|     ($($mod:ident),*) => { | ||||
|         pub fn configure(cfg: &mut web::ServiceConfig) { | ||||
| @@ -456,6 +480,8 @@ pub async fn update_all( | ||||
|             non_separator_tokens: NonSeparatorTokensAnalytics::new( | ||||
|                 new_settings.non_separator_tokens.as_ref().set(), | ||||
|             ), | ||||
|             facet_search: FacetSearchAnalytics::new(new_settings.facet_search.as_ref().set()), | ||||
|             prefix_search: PrefixSearchAnalytics::new(new_settings.prefix_search.as_ref().set()), | ||||
|         }, | ||||
|         &req, | ||||
|     ); | ||||
|   | ||||
| @@ -10,7 +10,8 @@ use meilisearch_types::locales::{Locale, LocalizedAttributesRuleView}; | ||||
| use meilisearch_types::milli::update::Setting; | ||||
| use meilisearch_types::milli::vector::settings::EmbeddingSettings; | ||||
| use meilisearch_types::settings::{ | ||||
|     FacetingSettings, PaginationSettings, ProximityPrecisionView, RankingRuleView, TypoSettings, | ||||
|     FacetingSettings, PaginationSettings, PrefixSearchSettings, ProximityPrecisionView, | ||||
|     RankingRuleView, TypoSettings, | ||||
| }; | ||||
| use serde::Serialize; | ||||
|  | ||||
| @@ -36,6 +37,8 @@ pub struct SettingsAnalytics { | ||||
|     pub dictionary: DictionaryAnalytics, | ||||
|     pub separator_tokens: SeparatorTokensAnalytics, | ||||
|     pub non_separator_tokens: NonSeparatorTokensAnalytics, | ||||
|     pub facet_search: FacetSearchAnalytics, | ||||
|     pub prefix_search: PrefixSearchAnalytics, | ||||
| } | ||||
|  | ||||
| impl Aggregate for SettingsAnalytics { | ||||
| @@ -183,6 +186,14 @@ impl Aggregate for SettingsAnalytics { | ||||
|             non_separator_tokens: NonSeparatorTokensAnalytics { | ||||
|                 total: new.non_separator_tokens.total.or(self.non_separator_tokens.total), | ||||
|             }, | ||||
|             facet_search: FacetSearchAnalytics { | ||||
|                 set: new.facet_search.set | self.facet_search.set, | ||||
|                 value: new.facet_search.value.or(self.facet_search.value), | ||||
|             }, | ||||
|             prefix_search: PrefixSearchAnalytics { | ||||
|                 set: new.prefix_search.set | self.prefix_search.set, | ||||
|                 value: new.prefix_search.value.or(self.prefix_search.value), | ||||
|             }, | ||||
|         }) | ||||
|     } | ||||
|  | ||||
| @@ -620,3 +631,35 @@ impl NonSeparatorTokensAnalytics { | ||||
|         SettingsAnalytics { non_separator_tokens: self, ..Default::default() } | ||||
|     } | ||||
| } | ||||
|  | ||||
| #[derive(Serialize, Default)] | ||||
| pub struct FacetSearchAnalytics { | ||||
|     pub set: bool, | ||||
|     pub value: Option<bool>, | ||||
| } | ||||
|  | ||||
| impl FacetSearchAnalytics { | ||||
|     pub fn new(settings: Option<&bool>) -> Self { | ||||
|         Self { set: settings.is_some(), value: settings.copied() } | ||||
|     } | ||||
|  | ||||
|     pub fn into_settings(self) -> SettingsAnalytics { | ||||
|         SettingsAnalytics { facet_search: self, ..Default::default() } | ||||
|     } | ||||
| } | ||||
|  | ||||
| #[derive(Serialize, Default)] | ||||
| pub struct PrefixSearchAnalytics { | ||||
|     pub set: bool, | ||||
|     pub value: Option<PrefixSearchSettings>, | ||||
| } | ||||
|  | ||||
| impl PrefixSearchAnalytics { | ||||
|     pub fn new(settings: Option<&PrefixSearchSettings>) -> Self { | ||||
|         Self { set: settings.is_some(), value: settings.cloned() } | ||||
|     } | ||||
|  | ||||
|     pub fn into_settings(self) -> SettingsAnalytics { | ||||
|         SettingsAnalytics { prefix_search: self, ..Default::default() } | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -79,7 +79,9 @@ async fn import_dump_v1_movie_raw() { | ||||
|         "maxTotalHits": 1000 | ||||
|       }, | ||||
|       "searchCutoffMs": null, | ||||
|       "localizedAttributes": null | ||||
|       "localizedAttributes": null, | ||||
|       "facetSearch": true, | ||||
|       "prefixSearch": "indexingTime" | ||||
|     } | ||||
|     "### | ||||
|     ); | ||||
| @@ -242,7 +244,9 @@ async fn import_dump_v1_movie_with_settings() { | ||||
|         "maxTotalHits": 1000 | ||||
|       }, | ||||
|       "searchCutoffMs": null, | ||||
|       "localizedAttributes": null | ||||
|       "localizedAttributes": null, | ||||
|       "facetSearch": true, | ||||
|       "prefixSearch": "indexingTime" | ||||
|     } | ||||
|     "### | ||||
|     ); | ||||
| @@ -391,7 +395,9 @@ async fn import_dump_v1_rubygems_with_settings() { | ||||
|         "maxTotalHits": 1000 | ||||
|       }, | ||||
|       "searchCutoffMs": null, | ||||
|       "localizedAttributes": null | ||||
|       "localizedAttributes": null, | ||||
|       "facetSearch": true, | ||||
|       "prefixSearch": "indexingTime" | ||||
|     } | ||||
|     "### | ||||
|     ); | ||||
| @@ -526,7 +532,9 @@ async fn import_dump_v2_movie_raw() { | ||||
|         "maxTotalHits": 1000 | ||||
|       }, | ||||
|       "searchCutoffMs": null, | ||||
|       "localizedAttributes": null | ||||
|       "localizedAttributes": null, | ||||
|       "facetSearch": true, | ||||
|       "prefixSearch": "indexingTime" | ||||
|     } | ||||
|     "### | ||||
|     ); | ||||
| @@ -673,7 +681,9 @@ async fn import_dump_v2_movie_with_settings() { | ||||
|         "maxTotalHits": 1000 | ||||
|       }, | ||||
|       "searchCutoffMs": null, | ||||
|       "localizedAttributes": null | ||||
|       "localizedAttributes": null, | ||||
|       "facetSearch": true, | ||||
|       "prefixSearch": "indexingTime" | ||||
|     } | ||||
|     "### | ||||
|     ); | ||||
| @@ -819,7 +829,9 @@ async fn import_dump_v2_rubygems_with_settings() { | ||||
|         "maxTotalHits": 1000 | ||||
|       }, | ||||
|       "searchCutoffMs": null, | ||||
|       "localizedAttributes": null | ||||
|       "localizedAttributes": null, | ||||
|       "facetSearch": true, | ||||
|       "prefixSearch": "indexingTime" | ||||
|     } | ||||
|     "### | ||||
|     ); | ||||
| @@ -954,7 +966,9 @@ async fn import_dump_v3_movie_raw() { | ||||
|         "maxTotalHits": 1000 | ||||
|       }, | ||||
|       "searchCutoffMs": null, | ||||
|       "localizedAttributes": null | ||||
|       "localizedAttributes": null, | ||||
|       "facetSearch": true, | ||||
|       "prefixSearch": "indexingTime" | ||||
|     } | ||||
|     "### | ||||
|     ); | ||||
| @@ -1101,7 +1115,9 @@ async fn import_dump_v3_movie_with_settings() { | ||||
|         "maxTotalHits": 1000 | ||||
|       }, | ||||
|       "searchCutoffMs": null, | ||||
|       "localizedAttributes": null | ||||
|       "localizedAttributes": null, | ||||
|       "facetSearch": true, | ||||
|       "prefixSearch": "indexingTime" | ||||
|     } | ||||
|     "### | ||||
|     ); | ||||
| @@ -1247,7 +1263,9 @@ async fn import_dump_v3_rubygems_with_settings() { | ||||
|         "maxTotalHits": 1000 | ||||
|       }, | ||||
|       "searchCutoffMs": null, | ||||
|       "localizedAttributes": null | ||||
|       "localizedAttributes": null, | ||||
|       "facetSearch": true, | ||||
|       "prefixSearch": "indexingTime" | ||||
|     } | ||||
|     "### | ||||
|     ); | ||||
| @@ -1382,7 +1400,9 @@ async fn import_dump_v4_movie_raw() { | ||||
|         "maxTotalHits": 1000 | ||||
|       }, | ||||
|       "searchCutoffMs": null, | ||||
|       "localizedAttributes": null | ||||
|       "localizedAttributes": null, | ||||
|       "facetSearch": true, | ||||
|       "prefixSearch": "indexingTime" | ||||
|     } | ||||
|     "### | ||||
|     ); | ||||
| @@ -1529,7 +1549,9 @@ async fn import_dump_v4_movie_with_settings() { | ||||
|         "maxTotalHits": 1000 | ||||
|       }, | ||||
|       "searchCutoffMs": null, | ||||
|       "localizedAttributes": null | ||||
|       "localizedAttributes": null, | ||||
|       "facetSearch": true, | ||||
|       "prefixSearch": "indexingTime" | ||||
|     } | ||||
|     "### | ||||
|     ); | ||||
| @@ -1675,7 +1697,9 @@ async fn import_dump_v4_rubygems_with_settings() { | ||||
|         "maxTotalHits": 1000 | ||||
|       }, | ||||
|       "searchCutoffMs": null, | ||||
|       "localizedAttributes": null | ||||
|       "localizedAttributes": null, | ||||
|       "facetSearch": true, | ||||
|       "prefixSearch": "indexingTime" | ||||
|     } | ||||
|     "### | ||||
|     ); | ||||
| @@ -1922,7 +1946,9 @@ async fn import_dump_v6_containing_experimental_features() { | ||||
|         "maxTotalHits": 1000 | ||||
|       }, | ||||
|       "searchCutoffMs": null, | ||||
|       "localizedAttributes": null | ||||
|       "localizedAttributes": null, | ||||
|       "facetSearch": true, | ||||
|       "prefixSearch": "indexingTime" | ||||
|     } | ||||
|     "###); | ||||
|  | ||||
| @@ -2102,7 +2128,9 @@ async fn generate_and_import_dump_containing_vectors() { | ||||
|         } | ||||
|       }, | ||||
|       "searchCutoffMs": null, | ||||
|       "localizedAttributes": null | ||||
|       "localizedAttributes": null, | ||||
|       "facetSearch": true, | ||||
|       "prefixSearch": "indexingTime" | ||||
|     } | ||||
|     "###); | ||||
|  | ||||
|   | ||||
| @@ -200,3 +200,115 @@ async fn simple_facet_search_with_sort_by_count() { | ||||
|     assert_eq!(hits[0], json!({ "value": "Action", "count": 3 })); | ||||
|     assert_eq!(hits[1], json!({ "value": "Adventure", "count": 2 })); | ||||
| } | ||||
|  | ||||
| #[actix_rt::test] | ||||
| async fn add_documents_and_deactivate_facet_search() { | ||||
|     let server = Server::new().await; | ||||
|     let index = server.index("test"); | ||||
|  | ||||
|     let documents = DOCUMENTS.clone(); | ||||
|     index.add_documents(documents, None).await; | ||||
|     index.wait_task(0).await; | ||||
|     let (response, code) = index | ||||
|         .update_settings(json!({ | ||||
|             "facetSearch": false, | ||||
|             "filterableAttributes": ["genres"], | ||||
|         })) | ||||
|         .await; | ||||
|     assert_eq!("202", code.as_str(), "{:?}", response); | ||||
|     index.wait_task(1).await; | ||||
|  | ||||
|     let (response, code) = | ||||
|         index.facet_search(json!({"facetName": "genres", "facetQuery": "a"})).await; | ||||
|  | ||||
|     assert_eq!(code, 200, "{}", response); | ||||
|     assert_eq!(dbg!(response)["facetHits"].as_array().unwrap().len(), 0); | ||||
| } | ||||
|  | ||||
| #[actix_rt::test] | ||||
| async fn deactivate_facet_search_and_add_documents() { | ||||
|     let server = Server::new().await; | ||||
|     let index = server.index("test"); | ||||
|  | ||||
|     let (response, code) = index | ||||
|         .update_settings(json!({ | ||||
|             "facetSearch": false, | ||||
|             "filterableAttributes": ["genres"], | ||||
|         })) | ||||
|         .await; | ||||
|     assert_eq!("202", code.as_str(), "{:?}", response); | ||||
|     index.wait_task(0).await; | ||||
|     let documents = DOCUMENTS.clone(); | ||||
|     index.add_documents(documents, None).await; | ||||
|     index.wait_task(1).await; | ||||
|  | ||||
|     let (response, code) = | ||||
|         index.facet_search(json!({"facetName": "genres", "facetQuery": "a"})).await; | ||||
|  | ||||
|     assert_eq!(code, 200, "{}", response); | ||||
|     assert_eq!(dbg!(response)["facetHits"].as_array().unwrap().len(), 0); | ||||
| } | ||||
|  | ||||
| #[actix_rt::test] | ||||
| async fn deactivate_facet_search_add_documents_and_activate_facet_search() { | ||||
|     let server = Server::new().await; | ||||
|     let index = server.index("test"); | ||||
|  | ||||
|     let (response, code) = index | ||||
|         .update_settings(json!({ | ||||
|             "facetSearch": false, | ||||
|             "filterableAttributes": ["genres"], | ||||
|         })) | ||||
|         .await; | ||||
|     assert_eq!("202", code.as_str(), "{:?}", response); | ||||
|     index.wait_task(0).await; | ||||
|     let documents = DOCUMENTS.clone(); | ||||
|     index.add_documents(documents, None).await; | ||||
|     index.wait_task(1).await; | ||||
|  | ||||
|     let (response, code) = index | ||||
|         .update_settings(json!({ | ||||
|             "facetSearch": true, | ||||
|         })) | ||||
|         .await; | ||||
|     assert_eq!("202", code.as_str(), "{:?}", response); | ||||
|     index.wait_task(2).await; | ||||
|  | ||||
|     let (response, code) = | ||||
|         index.facet_search(json!({"facetName": "genres", "facetQuery": "a"})).await; | ||||
|  | ||||
|     assert_eq!(code, 200, "{}", response); | ||||
|     assert_eq!(dbg!(response)["facetHits"].as_array().unwrap().len(), 2); | ||||
| } | ||||
|  | ||||
| #[actix_rt::test] | ||||
| async fn deactivate_facet_search_add_documents_and_reset_facet_search() { | ||||
|     let server = Server::new().await; | ||||
|     let index = server.index("test"); | ||||
|  | ||||
|     let (response, code) = index | ||||
|         .update_settings(json!({ | ||||
|             "facetSearch": false, | ||||
|             "filterableAttributes": ["genres"], | ||||
|         })) | ||||
|         .await; | ||||
|     assert_eq!("202", code.as_str(), "{:?}", response); | ||||
|     index.wait_task(0).await; | ||||
|     let documents = DOCUMENTS.clone(); | ||||
|     index.add_documents(documents, None).await; | ||||
|     index.wait_task(1).await; | ||||
|  | ||||
|     let (response, code) = index | ||||
|         .update_settings(json!({ | ||||
|             "facetSearch": serde_json::Value::Null, | ||||
|         })) | ||||
|         .await; | ||||
|     assert_eq!("202", code.as_str(), "{:?}", response); | ||||
|     index.wait_task(2).await; | ||||
|  | ||||
|     let (response, code) = | ||||
|         index.facet_search(json!({"facetName": "genres", "facetQuery": "a"})).await; | ||||
|  | ||||
|     assert_eq!(code, 200, "{}", response); | ||||
|     assert_eq!(dbg!(response)["facetHits"].as_array().unwrap().len(), 2); | ||||
| } | ||||
|   | ||||
| @@ -56,7 +56,7 @@ async fn get_settings() { | ||||
|     let (response, code) = index.settings().await; | ||||
|     assert_eq!(code, 200); | ||||
|     let settings = response.as_object().unwrap(); | ||||
|     assert_eq!(settings.keys().len(), 17); | ||||
|     assert_eq!(settings.keys().len(), 19); | ||||
|     assert_eq!(settings["displayedAttributes"], json!(["*"])); | ||||
|     assert_eq!(settings["searchableAttributes"], json!(["*"])); | ||||
|     assert_eq!(settings["filterableAttributes"], json!([])); | ||||
| @@ -87,6 +87,8 @@ async fn get_settings() { | ||||
|     ); | ||||
|     assert_eq!(settings["proximityPrecision"], json!("byWord")); | ||||
|     assert_eq!(settings["searchCutoffMs"], json!(null)); | ||||
|     assert_eq!(settings["prefixSearch"], json!("indexingTime")); | ||||
|     assert_eq!(settings["facetSearch"], json!(true)); | ||||
| } | ||||
|  | ||||
| #[actix_rt::test] | ||||
| @@ -199,7 +201,9 @@ async fn secrets_are_hidden_in_settings() { | ||||
|         } | ||||
|       }, | ||||
|       "searchCutoffMs": null, | ||||
|       "localizedAttributes": null | ||||
|       "localizedAttributes": null, | ||||
|       "facetSearch": true, | ||||
|       "prefixSearch": "indexingTime" | ||||
|     } | ||||
|     "###); | ||||
|  | ||||
|   | ||||
| @@ -1,5 +1,6 @@ | ||||
| mod distinct; | ||||
| mod errors; | ||||
| mod get_settings; | ||||
| mod prefix_search_settings; | ||||
| mod proximity_settings; | ||||
| mod tokenizer_customization; | ||||
|   | ||||
							
								
								
									
										458
									
								
								crates/meilisearch/tests/settings/prefix_search_settings.rs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										458
									
								
								crates/meilisearch/tests/settings/prefix_search_settings.rs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,458 @@ | ||||
| use meili_snap::{json_string, snapshot}; | ||||
| use once_cell::sync::Lazy; | ||||
|  | ||||
| use crate::common::Server; | ||||
| use crate::json; | ||||
|  | ||||
| static DOCUMENTS: Lazy<crate::common::Value> = Lazy::new(|| { | ||||
|     json!([ | ||||
|         { | ||||
|             "id": 1, | ||||
|             "a": "Soup of the day", | ||||
|             "b": "manythefishou", | ||||
|         }, | ||||
|         { | ||||
|             "id": 2, | ||||
|             "a": "Soup of day so", | ||||
|             "b": "manythe manythelazyfish", | ||||
|         }, | ||||
|         { | ||||
|             "id": 3, | ||||
|             "a": "the Soup of day", | ||||
|             "b": "manythelazyfish", | ||||
|         }, | ||||
|     ]) | ||||
| }); | ||||
|  | ||||
| #[actix_rt::test] | ||||
| async fn add_docs_and_disable() { | ||||
|     let server = Server::new().await; | ||||
|     let index = server.index("test"); | ||||
|  | ||||
|     index.add_documents(DOCUMENTS.clone(), None).await; | ||||
|     index.wait_task(0).await; | ||||
|  | ||||
|     let (response, code) = index | ||||
|         .update_settings(json!({ | ||||
|             "prefixSearch": "disabled", | ||||
|             "rankingRules": ["words", "typo", "proximity"], | ||||
|         })) | ||||
|         .await; | ||||
|     assert_eq!("202", code.as_str(), "{:?}", response); | ||||
|     index.wait_task(1).await; | ||||
|  | ||||
|     // only 1 document should match | ||||
|     index | ||||
|         .search(json!({"q": "so", "attributesToHighlight": ["a", "b"]}), |response, code| { | ||||
|             snapshot!(code, @"200 OK"); | ||||
|             snapshot!(json_string!(response["hits"]), @r###" | ||||
|             [ | ||||
|               { | ||||
|                 "id": 2, | ||||
|                 "a": "Soup of day so", | ||||
|                 "b": "manythe manythelazyfish", | ||||
|                 "_formatted": { | ||||
|                   "id": "2", | ||||
|                   "a": "Soup of day <em>so</em>", | ||||
|                   "b": "manythe manythelazyfish" | ||||
|                 } | ||||
|               } | ||||
|             ] | ||||
|             "###); | ||||
|         }) | ||||
|         .await; | ||||
|  | ||||
|     // only 1 document should match | ||||
|     index | ||||
|         .search(json!({"q": "manythe", "attributesToHighlight": ["a", "b"]}), |response, code| { | ||||
|             snapshot!(code, @"200 OK"); | ||||
|             snapshot!(json_string!(response["hits"]), @r###" | ||||
|             [ | ||||
|               { | ||||
|                 "id": 2, | ||||
|                 "a": "Soup of day so", | ||||
|                 "b": "manythe manythelazyfish", | ||||
|                 "_formatted": { | ||||
|                   "id": "2", | ||||
|                   "a": "Soup of day so", | ||||
|                   "b": "<em>manythe</em> manythelazyfish" | ||||
|                 } | ||||
|               } | ||||
|             ] | ||||
|             "###); | ||||
|         }) | ||||
|         .await; | ||||
| } | ||||
|  | ||||
| #[actix_rt::test] | ||||
| async fn disable_and_add_docs() { | ||||
|     let server = Server::new().await; | ||||
|     let index = server.index("test"); | ||||
|  | ||||
|     let (response, code) = index | ||||
|         .update_settings(json!({ | ||||
|             "prefixSearch": "disabled", | ||||
|             "rankingRules": ["words", "typo", "proximity"], | ||||
|         })) | ||||
|         .await; | ||||
|     assert_eq!("202", code.as_str(), "{:?}", response); | ||||
|     index.wait_task(0).await; | ||||
|  | ||||
|     index.add_documents(DOCUMENTS.clone(), None).await; | ||||
|     index.wait_task(1).await; | ||||
|  | ||||
|     // only 1 document should match | ||||
|     index | ||||
|         .search(json!({"q": "so", "attributesToHighlight": ["a", "b"]}), |response, code| { | ||||
|             snapshot!(code, @"200 OK"); | ||||
|             snapshot!(json_string!(response["hits"]), @r###" | ||||
|             [ | ||||
|               { | ||||
|                 "id": 2, | ||||
|                 "a": "Soup of day so", | ||||
|                 "b": "manythe manythelazyfish", | ||||
|                 "_formatted": { | ||||
|                   "id": "2", | ||||
|                   "a": "Soup of day <em>so</em>", | ||||
|                   "b": "manythe manythelazyfish" | ||||
|                 } | ||||
|               } | ||||
|             ] | ||||
|             "###); | ||||
|         }) | ||||
|         .await; | ||||
|  | ||||
|     index | ||||
|         .search(json!({"q": "manythe", "attributesToHighlight": ["a", "b"]}), |response, code| { | ||||
|             snapshot!(code, @"200 OK"); | ||||
|             snapshot!(json_string!(response["hits"]), @r###" | ||||
|             [ | ||||
|               { | ||||
|                 "id": 2, | ||||
|                 "a": "Soup of day so", | ||||
|                 "b": "manythe manythelazyfish", | ||||
|                 "_formatted": { | ||||
|                   "id": "2", | ||||
|                   "a": "Soup of day so", | ||||
|                   "b": "<em>manythe</em> manythelazyfish" | ||||
|                 } | ||||
|               } | ||||
|             ] | ||||
|             "###); | ||||
|         }) | ||||
|         .await; | ||||
| } | ||||
|  | ||||
| #[actix_rt::test] | ||||
| async fn disable_add_docs_and_enable() { | ||||
|     let server = Server::new().await; | ||||
|     let index = server.index("test"); | ||||
|  | ||||
|     let (response, code) = index | ||||
|         .update_settings(json!({ | ||||
|             "prefixSearch": "disabled", | ||||
|             "rankingRules": ["words", "typo", "proximity"], | ||||
|         })) | ||||
|         .await; | ||||
|     assert_eq!("202", code.as_str(), "{:?}", response); | ||||
|     index.wait_task(0).await; | ||||
|  | ||||
|     index.add_documents(DOCUMENTS.clone(), None).await; | ||||
|     index.wait_task(1).await; | ||||
|  | ||||
|     let (response, code) = index | ||||
|         .update_settings(json!({ | ||||
|             "prefixSearch": "indexingTime", | ||||
|             "rankingRules": ["words", "typo", "proximity"], | ||||
|         })) | ||||
|         .await; | ||||
|     assert_eq!("202", code.as_str(), "{:?}", response); | ||||
|     index.wait_task(2).await; | ||||
|  | ||||
|     // all documents should match | ||||
|     index | ||||
|         .search(json!({"q": "so", "attributesToHighlight": ["a", "b"]}), |response, code| { | ||||
|             snapshot!(code, @"200 OK"); | ||||
|             snapshot!(json_string!(response["hits"]), @r###" | ||||
|             [ | ||||
|               { | ||||
|                 "id": 1, | ||||
|                 "a": "Soup of the day", | ||||
|                 "b": "manythefishou", | ||||
|                 "_formatted": { | ||||
|                   "id": "1", | ||||
|                   "a": "<em>So</em>up of the day", | ||||
|                   "b": "manythefishou" | ||||
|                 } | ||||
|               }, | ||||
|               { | ||||
|                 "id": 2, | ||||
|                 "a": "Soup of day so", | ||||
|                 "b": "manythe manythelazyfish", | ||||
|                 "_formatted": { | ||||
|                   "id": "2", | ||||
|                   "a": "<em>So</em>up of day <em>so</em>", | ||||
|                   "b": "manythe manythelazyfish" | ||||
|                 } | ||||
|               }, | ||||
|               { | ||||
|                 "id": 3, | ||||
|                 "a": "the Soup of day", | ||||
|                 "b": "manythelazyfish", | ||||
|                 "_formatted": { | ||||
|                   "id": "3", | ||||
|                   "a": "the <em>So</em>up of day", | ||||
|                   "b": "manythelazyfish" | ||||
|                 } | ||||
|               } | ||||
|             ] | ||||
|             "###); | ||||
|         }) | ||||
|         .await; | ||||
|  | ||||
|     index | ||||
|         .search(json!({"q": "manythe", "attributesToHighlight": ["a", "b"]}), |response, code| { | ||||
|             snapshot!(code, @"200 OK"); | ||||
|             snapshot!(json_string!(response["hits"]), @r###" | ||||
|             [ | ||||
|               { | ||||
|                 "id": 1, | ||||
|                 "a": "Soup of the day", | ||||
|                 "b": "manythefishou", | ||||
|                 "_formatted": { | ||||
|                   "id": "1", | ||||
|                   "a": "Soup of the day", | ||||
|                   "b": "<em>manythe</em>fishou" | ||||
|                 } | ||||
|               }, | ||||
|               { | ||||
|                 "id": 2, | ||||
|                 "a": "Soup of day so", | ||||
|                 "b": "manythe manythelazyfish", | ||||
|                 "_formatted": { | ||||
|                   "id": "2", | ||||
|                   "a": "Soup of day so", | ||||
|                   "b": "<em>manythe</em> <em>manythe</em>lazyfish" | ||||
|                 } | ||||
|               }, | ||||
|               { | ||||
|                 "id": 3, | ||||
|                 "a": "the Soup of day", | ||||
|                 "b": "manythelazyfish", | ||||
|                 "_formatted": { | ||||
|                   "id": "3", | ||||
|                   "a": "the Soup of day", | ||||
|                   "b": "<em>manythe</em>lazyfish" | ||||
|                 } | ||||
|               } | ||||
|             ] | ||||
|             "###); | ||||
|         }) | ||||
|         .await; | ||||
| } | ||||
|  | ||||
| #[actix_rt::test] | ||||
| async fn disable_add_docs_and_reset() { | ||||
|     let server = Server::new().await; | ||||
|     let index = server.index("test"); | ||||
|  | ||||
|     let (response, code) = index | ||||
|         .update_settings(json!({ | ||||
|             "prefixSearch": "disabled", | ||||
|             "rankingRules": ["words", "typo", "proximity"], | ||||
|         })) | ||||
|         .await; | ||||
|     assert_eq!("202", code.as_str(), "{:?}", response); | ||||
|     index.wait_task(0).await; | ||||
|  | ||||
|     index.add_documents(DOCUMENTS.clone(), None).await; | ||||
|     index.wait_task(1).await; | ||||
|  | ||||
|     let (response, code) = index | ||||
|         .update_settings(json!({ | ||||
|             "prefixSearch": serde_json::Value::Null, | ||||
|             "rankingRules": ["words", "typo", "proximity"], | ||||
|         })) | ||||
|         .await; | ||||
|     assert_eq!("202", code.as_str(), "{:?}", response); | ||||
|     index.wait_task(2).await; | ||||
|  | ||||
|     // all documents should match | ||||
|     index | ||||
|         .search(json!({"q": "so", "attributesToHighlight": ["a", "b"]}), |response, code| { | ||||
|             snapshot!(code, @"200 OK"); | ||||
|             snapshot!(json_string!(response["hits"]), @r###" | ||||
|             [ | ||||
|               { | ||||
|                 "id": 1, | ||||
|                 "a": "Soup of the day", | ||||
|                 "b": "manythefishou", | ||||
|                 "_formatted": { | ||||
|                   "id": "1", | ||||
|                   "a": "<em>So</em>up of the day", | ||||
|                   "b": "manythefishou" | ||||
|                 } | ||||
|               }, | ||||
|               { | ||||
|                 "id": 2, | ||||
|                 "a": "Soup of day so", | ||||
|                 "b": "manythe manythelazyfish", | ||||
|                 "_formatted": { | ||||
|                   "id": "2", | ||||
|                   "a": "<em>So</em>up of day <em>so</em>", | ||||
|                   "b": "manythe manythelazyfish" | ||||
|                 } | ||||
|               }, | ||||
|               { | ||||
|                 "id": 3, | ||||
|                 "a": "the Soup of day", | ||||
|                 "b": "manythelazyfish", | ||||
|                 "_formatted": { | ||||
|                   "id": "3", | ||||
|                   "a": "the <em>So</em>up of day", | ||||
|                   "b": "manythelazyfish" | ||||
|                 } | ||||
|               } | ||||
|             ] | ||||
|             "###); | ||||
|         }) | ||||
|         .await; | ||||
|  | ||||
|     index | ||||
|         .search(json!({"q": "manythe", "attributesToHighlight": ["a", "b"]}), |response, code| { | ||||
|             snapshot!(code, @"200 OK"); | ||||
|             snapshot!(json_string!(response["hits"]), @r###" | ||||
|             [ | ||||
|               { | ||||
|                 "id": 1, | ||||
|                 "a": "Soup of the day", | ||||
|                 "b": "manythefishou", | ||||
|                 "_formatted": { | ||||
|                   "id": "1", | ||||
|                   "a": "Soup of the day", | ||||
|                   "b": "<em>manythe</em>fishou" | ||||
|                 } | ||||
|               }, | ||||
|               { | ||||
|                 "id": 2, | ||||
|                 "a": "Soup of day so", | ||||
|                 "b": "manythe manythelazyfish", | ||||
|                 "_formatted": { | ||||
|                   "id": "2", | ||||
|                   "a": "Soup of day so", | ||||
|                   "b": "<em>manythe</em> <em>manythe</em>lazyfish" | ||||
|                 } | ||||
|               }, | ||||
|               { | ||||
|                 "id": 3, | ||||
|                 "a": "the Soup of day", | ||||
|                 "b": "manythelazyfish", | ||||
|                 "_formatted": { | ||||
|                   "id": "3", | ||||
|                   "a": "the Soup of day", | ||||
|                   "b": "<em>manythe</em>lazyfish" | ||||
|                 } | ||||
|               } | ||||
|             ] | ||||
|             "###); | ||||
|         }) | ||||
|         .await; | ||||
| } | ||||
|  | ||||
| #[actix_rt::test] | ||||
| async fn default_behavior() { | ||||
|     let server = Server::new().await; | ||||
|     let index = server.index("test"); | ||||
|  | ||||
|     let (response, code) = index | ||||
|         .update_settings(json!({ | ||||
|             "rankingRules": ["words", "typo", "proximity"], | ||||
|         })) | ||||
|         .await; | ||||
|     assert_eq!("202", code.as_str(), "{:?}", response); | ||||
|     index.wait_task(0).await; | ||||
|  | ||||
|     index.add_documents(DOCUMENTS.clone(), None).await; | ||||
|     index.wait_task(1).await; | ||||
|  | ||||
|     // all documents should match | ||||
|     index | ||||
|         .search(json!({"q": "so", "attributesToHighlight": ["a", "b"]}), |response, code| { | ||||
|             snapshot!(code, @"200 OK"); | ||||
|             snapshot!(json_string!(response["hits"]), @r###" | ||||
|             [ | ||||
|               { | ||||
|                 "id": 1, | ||||
|                 "a": "Soup of the day", | ||||
|                 "b": "manythefishou", | ||||
|                 "_formatted": { | ||||
|                   "id": "1", | ||||
|                   "a": "<em>So</em>up of the day", | ||||
|                   "b": "manythefishou" | ||||
|                 } | ||||
|               }, | ||||
|               { | ||||
|                 "id": 2, | ||||
|                 "a": "Soup of day so", | ||||
|                 "b": "manythe manythelazyfish", | ||||
|                 "_formatted": { | ||||
|                   "id": "2", | ||||
|                   "a": "<em>So</em>up of day <em>so</em>", | ||||
|                   "b": "manythe manythelazyfish" | ||||
|                 } | ||||
|               }, | ||||
|               { | ||||
|                 "id": 3, | ||||
|                 "a": "the Soup of day", | ||||
|                 "b": "manythelazyfish", | ||||
|                 "_formatted": { | ||||
|                   "id": "3", | ||||
|                   "a": "the <em>So</em>up of day", | ||||
|                   "b": "manythelazyfish" | ||||
|                 } | ||||
|               } | ||||
|             ] | ||||
|             "###); | ||||
|         }) | ||||
|         .await; | ||||
|  | ||||
|     index | ||||
|         .search(json!({"q": "manythe", "attributesToHighlight": ["a", "b"]}), |response, code| { | ||||
|             snapshot!(code, @"200 OK"); | ||||
|             snapshot!(json_string!(response["hits"]), @r###" | ||||
|             [ | ||||
|               { | ||||
|                 "id": 1, | ||||
|                 "a": "Soup of the day", | ||||
|                 "b": "manythefishou", | ||||
|                 "_formatted": { | ||||
|                   "id": "1", | ||||
|                   "a": "Soup of the day", | ||||
|                   "b": "<em>manythe</em>fishou" | ||||
|                 } | ||||
|               }, | ||||
|               { | ||||
|                 "id": 2, | ||||
|                 "a": "Soup of day so", | ||||
|                 "b": "manythe manythelazyfish", | ||||
|                 "_formatted": { | ||||
|                   "id": "2", | ||||
|                   "a": "Soup of day so", | ||||
|                   "b": "<em>manythe</em> <em>manythe</em>lazyfish" | ||||
|                 } | ||||
|               }, | ||||
|               { | ||||
|                 "id": 3, | ||||
|                 "a": "the Soup of day", | ||||
|                 "b": "manythelazyfish", | ||||
|                 "_formatted": { | ||||
|                   "id": "3", | ||||
|                   "a": "the Soup of day", | ||||
|                   "b": "<em>manythe</em>lazyfish" | ||||
|                 } | ||||
|               } | ||||
|             ] | ||||
|             "###); | ||||
|         }) | ||||
|         .await; | ||||
| } | ||||
| @@ -70,6 +70,8 @@ pub mod main_key { | ||||
|     pub const EMBEDDING_CONFIGS: &str = "embedding_configs"; | ||||
|     pub const SEARCH_CUTOFF: &str = "search_cutoff"; | ||||
|     pub const LOCALIZED_ATTRIBUTES_RULES: &str = "localized_attributes_rules"; | ||||
|     pub const FACET_SEARCH: &str = "facet_search"; | ||||
|     pub const PREFIX_SEARCH: &str = "prefix_search"; | ||||
| } | ||||
|  | ||||
| pub mod db_name { | ||||
| @@ -1233,6 +1235,10 @@ impl Index { | ||||
|         ) | ||||
|     } | ||||
|  | ||||
|     pub(crate) fn delete_words_prefixes_fst(&self, wtxn: &mut RwTxn<'_>) -> heed::Result<bool> { | ||||
|         self.main.remap_key_type::<Str>().delete(wtxn, main_key::WORDS_PREFIXES_FST_KEY) | ||||
|     } | ||||
|  | ||||
|     /// Returns the FST which is the words prefixes dictionary of the engine. | ||||
|     pub fn words_prefixes_fst<'t>(&self, rtxn: &'t RoTxn<'t>) -> Result<fst::Set<Cow<'t, [u8]>>> { | ||||
|         match self.main.remap_types::<Str, Bytes>().get(rtxn, main_key::WORDS_PREFIXES_FST_KEY)? { | ||||
| @@ -1562,6 +1568,41 @@ impl Index { | ||||
|         self.main.remap_key_type::<Str>().delete(txn, main_key::PROXIMITY_PRECISION) | ||||
|     } | ||||
|  | ||||
|     pub fn prefix_search(&self, txn: &RoTxn<'_>) -> heed::Result<Option<PrefixSearch>> { | ||||
|         self.main.remap_types::<Str, SerdeBincode<PrefixSearch>>().get(txn, main_key::PREFIX_SEARCH) | ||||
|     } | ||||
|  | ||||
|     pub(crate) fn put_prefix_search( | ||||
|         &self, | ||||
|         txn: &mut RwTxn<'_>, | ||||
|         val: PrefixSearch, | ||||
|     ) -> heed::Result<()> { | ||||
|         self.main.remap_types::<Str, SerdeBincode<PrefixSearch>>().put( | ||||
|             txn, | ||||
|             main_key::PREFIX_SEARCH, | ||||
|             &val, | ||||
|         ) | ||||
|     } | ||||
|  | ||||
|     pub(crate) fn delete_prefix_search(&self, txn: &mut RwTxn<'_>) -> heed::Result<bool> { | ||||
|         self.main.remap_key_type::<Str>().delete(txn, main_key::PREFIX_SEARCH) | ||||
|     } | ||||
|  | ||||
|     pub fn facet_search(&self, txn: &RoTxn<'_>) -> heed::Result<bool> { | ||||
|         self.main | ||||
|             .remap_types::<Str, SerdeBincode<bool>>() | ||||
|             .get(txn, main_key::FACET_SEARCH) | ||||
|             .map(|v| v.unwrap_or(true)) | ||||
|     } | ||||
|  | ||||
|     pub(crate) fn put_facet_search(&self, txn: &mut RwTxn<'_>, val: bool) -> heed::Result<()> { | ||||
|         self.main.remap_types::<Str, SerdeBincode<bool>>().put(txn, main_key::FACET_SEARCH, &val) | ||||
|     } | ||||
|  | ||||
|     pub(crate) fn delete_facet_search(&self, txn: &mut RwTxn<'_>) -> heed::Result<bool> { | ||||
|         self.main.remap_key_type::<Str>().delete(txn, main_key::FACET_SEARCH) | ||||
|     } | ||||
|  | ||||
|     pub fn localized_attributes_rules( | ||||
|         &self, | ||||
|         rtxn: &RoTxn<'_>, | ||||
| @@ -1647,10 +1688,14 @@ impl Index { | ||||
|         Ok(res) | ||||
|     } | ||||
|  | ||||
|     pub fn prefix_settings(&self, _rtxn: &RoTxn<'_>) -> Result<PrefixSettings> { | ||||
|     pub fn prefix_settings(&self, rtxn: &RoTxn<'_>) -> Result<PrefixSettings> { | ||||
|         let compute_prefixes = self.prefix_search(rtxn)?.unwrap_or_default(); | ||||
|         Ok(PrefixSettings { | ||||
|             compute_prefixes: true, | ||||
|             compute_prefixes, | ||||
|             max_prefix_length: 4, | ||||
|             #[cfg(not(test))] | ||||
|             prefix_count_threshold: 100, | ||||
|             #[cfg(test)] | ||||
|             prefix_count_threshold: 100, | ||||
|         }) | ||||
|     } | ||||
| @@ -1665,9 +1710,17 @@ pub struct IndexEmbeddingConfig { | ||||
|  | ||||
| #[derive(Debug, Deserialize, Serialize)] | ||||
| pub struct PrefixSettings { | ||||
|     pub prefix_count_threshold: u64, | ||||
|     pub prefix_count_threshold: usize, | ||||
|     pub max_prefix_length: usize, | ||||
|     pub compute_prefixes: bool, | ||||
|     pub compute_prefixes: PrefixSearch, | ||||
| } | ||||
|  | ||||
| #[derive(Debug, Clone, Copy, Serialize, Deserialize, PartialEq, Eq, Default)] | ||||
| #[serde(rename_all = "camelCase")] | ||||
| pub enum PrefixSearch { | ||||
|     #[default] | ||||
|     IndexingTime, | ||||
|     Disabled, | ||||
| } | ||||
|  | ||||
| #[derive(Serialize, Deserialize)] | ||||
|   | ||||
| @@ -49,6 +49,7 @@ pub use self::geo_sort::Strategy as GeoSortStrategy; | ||||
| use self::graph_based_ranking_rule::Words; | ||||
| use self::interner::Interned; | ||||
| use self::vector_sort::VectorSort; | ||||
| use crate::index::PrefixSearch; | ||||
| use crate::localized_attributes_rules::LocalizedFieldIds; | ||||
| use crate::score_details::{ScoreDetails, ScoringStrategy}; | ||||
| use crate::search::new::distinct::apply_distinct_rule; | ||||
| @@ -68,6 +69,7 @@ pub struct SearchContext<'ctx> { | ||||
|     pub term_interner: Interner<QueryTerm>, | ||||
|     pub phrase_docids: PhraseDocIdsCache, | ||||
|     pub restricted_fids: Option<RestrictedFids>, | ||||
|     pub prefix_search: PrefixSearch, | ||||
| } | ||||
|  | ||||
| impl<'ctx> SearchContext<'ctx> { | ||||
| @@ -85,6 +87,8 @@ impl<'ctx> SearchContext<'ctx> { | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         let prefix_search = index.prefix_search(txn)?.unwrap_or_default(); | ||||
|  | ||||
|         Ok(Self { | ||||
|             index, | ||||
|             txn, | ||||
| @@ -94,9 +98,14 @@ impl<'ctx> SearchContext<'ctx> { | ||||
|             term_interner: <_>::default(), | ||||
|             phrase_docids: <_>::default(), | ||||
|             restricted_fids: None, | ||||
|             prefix_search, | ||||
|         }) | ||||
|     } | ||||
|  | ||||
|     pub fn is_prefix_search_allowed(&self) -> bool { | ||||
|         self.prefix_search != PrefixSearch::Disabled | ||||
|     } | ||||
|  | ||||
|     pub fn attributes_to_search_on( | ||||
|         &mut self, | ||||
|         attributes_to_search_on: &'ctx [String], | ||||
|   | ||||
| @@ -28,6 +28,7 @@ pub fn located_query_terms_from_tokens( | ||||
|     words_limit: Option<usize>, | ||||
| ) -> Result<ExtractedTokens> { | ||||
|     let nbr_typos = number_of_typos_allowed(ctx)?; | ||||
|     let allow_prefix_search = ctx.is_prefix_search_allowed(); | ||||
|  | ||||
|     let mut query_terms = Vec::new(); | ||||
|  | ||||
| @@ -94,7 +95,7 @@ pub fn located_query_terms_from_tokens( | ||||
|                         ctx, | ||||
|                         word, | ||||
|                         nbr_typos(word), | ||||
|                         true, | ||||
|                         allow_prefix_search, | ||||
|                         false, | ||||
|                     )?; | ||||
|                     let located_term = LocatedQueryTerm { | ||||
|   | ||||
| @@ -173,6 +173,13 @@ impl<'i> FacetsUpdate<'i> { | ||||
|         } | ||||
|  | ||||
|         match self.normalized_delta_data { | ||||
|             _ if !self.index.facet_search(wtxn)? => { | ||||
|                 // If facet search is disabled, we don't need to compute facet search databases. | ||||
|                 // We clear the facet search databases. | ||||
|                 self.index.facet_id_string_fst.clear(wtxn)?; | ||||
|                 self.index.facet_id_normalized_string_strings.clear(wtxn)?; | ||||
|                 return Ok(()); | ||||
|             } | ||||
|             Some(data) => index_facet_search(wtxn, data, self.index), | ||||
|             None => Ok(()), | ||||
|         } | ||||
|   | ||||
| @@ -34,10 +34,12 @@ pub fn extract_facet_string_docids<R: io::Read + io::Seek>( | ||||
|         extract_facet_string_docids_settings(docid_fid_facet_string, indexer, settings_diff) | ||||
|     } else { | ||||
|         let localized_field_ids = &settings_diff.new.localized_faceted_fields_ids; | ||||
|         let facet_search = settings_diff.new.facet_search; | ||||
|         extract_facet_string_docids_document_update( | ||||
|             docid_fid_facet_string, | ||||
|             indexer, | ||||
|             localized_field_ids, | ||||
|             facet_search, | ||||
|         ) | ||||
|     } | ||||
| } | ||||
| @@ -51,6 +53,7 @@ fn extract_facet_string_docids_document_update<R: io::Read + io::Seek>( | ||||
|     docid_fid_facet_string: grenad::Reader<R>, | ||||
|     indexer: GrenadParameters, | ||||
|     localized_field_ids: &LocalizedFieldIds, | ||||
|     facet_search: bool, | ||||
| ) -> Result<(grenad::Reader<BufReader<File>>, grenad::Reader<BufReader<File>>)> { | ||||
|     let max_memory = indexer.max_memory_by_thread(); | ||||
|  | ||||
| @@ -96,7 +99,7 @@ fn extract_facet_string_docids_document_update<R: io::Read + io::Seek>( | ||||
|         let normalized_value = str::from_utf8(normalized_value_bytes)?; | ||||
|  | ||||
|         // Facet search normalization | ||||
|         { | ||||
|         if facet_search { | ||||
|             let locales = localized_field_ids.locales(field_id); | ||||
|             let hyper_normalized_value = normalize_facet_string(normalized_value, locales); | ||||
|  | ||||
| @@ -179,8 +182,10 @@ fn extract_facet_string_docids_settings<R: io::Read + io::Seek>( | ||||
|         let new_locales = settings_diff.new.localized_faceted_fields_ids.locales(field_id); | ||||
|  | ||||
|         let are_same_locales = old_locales == new_locales; | ||||
|         let reindex_facet_search = | ||||
|             settings_diff.new.facet_search && !settings_diff.old.facet_search; | ||||
|  | ||||
|         if is_same_value && are_same_locales { | ||||
|         if is_same_value && are_same_locales && !reindex_facet_search { | ||||
|             continue; | ||||
|         } | ||||
|  | ||||
| @@ -191,18 +196,26 @@ fn extract_facet_string_docids_settings<R: io::Read + io::Seek>( | ||||
|         let normalized_value = str::from_utf8(normalized_value_bytes)?; | ||||
|  | ||||
|         // Facet search normalization | ||||
|         { | ||||
|             let old_hyper_normalized_value = normalize_facet_string(normalized_value, old_locales); | ||||
|             let new_hyper_normalized_value = if are_same_locales { | ||||
|                 &old_hyper_normalized_value | ||||
|         if settings_diff.new.facet_search { | ||||
|             let new_hyper_normalized_value = normalize_facet_string(normalized_value, new_locales); | ||||
|             let old_hyper_normalized_value; | ||||
|             let old_hyper_normalized_value = if !settings_diff.old.facet_search | ||||
|                 || deladd_reader.get(DelAdd::Deletion).is_none() | ||||
|             { | ||||
|                 // if the facet search is disabled in the old settings or if no facet string is deleted, | ||||
|                 // we don't need to normalize the facet string. | ||||
|                 None | ||||
|             } else if are_same_locales { | ||||
|                 Some(&new_hyper_normalized_value) | ||||
|             } else { | ||||
|                 &normalize_facet_string(normalized_value, new_locales) | ||||
|                 old_hyper_normalized_value = normalize_facet_string(normalized_value, old_locales); | ||||
|                 Some(&old_hyper_normalized_value) | ||||
|             }; | ||||
|  | ||||
|             let set = BTreeSet::from_iter(std::iter::once(normalized_value)); | ||||
|  | ||||
|             // if the facet string is the same, we can put the deletion and addition in the same obkv. | ||||
|             if old_hyper_normalized_value == new_hyper_normalized_value.as_str() { | ||||
|             if old_hyper_normalized_value == Some(&new_hyper_normalized_value) { | ||||
|                 // nothing to do if we delete and re-add the value. | ||||
|                 if is_same_value { | ||||
|                     continue; | ||||
| @@ -222,7 +235,7 @@ fn extract_facet_string_docids_settings<R: io::Read + io::Seek>( | ||||
|             } else { | ||||
|                 // if the facet string is different, we need to insert the deletion and addition in different obkv because the related key is different. | ||||
|                 // deletion | ||||
|                 if deladd_reader.get(DelAdd::Deletion).is_some() { | ||||
|                 if let Some(old_hyper_normalized_value) = old_hyper_normalized_value { | ||||
|                     // insert old value | ||||
|                     let val = SerdeJson::bytes_encode(&set).map_err(heed::Error::Encoding)?; | ||||
|                     buffer.clear(); | ||||
|   | ||||
| @@ -80,7 +80,7 @@ pub fn extract_fid_docid_facet_values<R: io::Read + io::Seek>( | ||||
|     let new_faceted_fids: BTreeSet<_> = | ||||
|         settings_diff.new.faceted_fields_ids.iter().copied().collect(); | ||||
|  | ||||
|     if !settings_diff.settings_update_only || old_faceted_fids != new_faceted_fids { | ||||
|     if !settings_diff.settings_update_only || settings_diff.reindex_facets() { | ||||
|         let mut cursor = obkv_documents.into_cursor()?; | ||||
|         while let Some((docid_bytes, value)) = cursor.move_on_next()? { | ||||
|             let obkv = obkv::KvReader::from_slice(value); | ||||
| @@ -112,8 +112,10 @@ pub fn extract_fid_docid_facet_values<R: io::Read + io::Seek>( | ||||
|                         (field_id, None, add_value) | ||||
|                     } | ||||
|                     EitherOrBoth::Both(&field_id, _) => { | ||||
|                         // during settings update, recompute the changing settings only. | ||||
|                         if settings_diff.settings_update_only { | ||||
|                         // during settings update, recompute the changing settings only unless a global change is detected. | ||||
|                         if settings_diff.settings_update_only | ||||
|                             && !settings_diff.global_facet_settings_changed() | ||||
|                         { | ||||
|                             continue; | ||||
|                         } | ||||
|  | ||||
|   | ||||
| @@ -29,6 +29,7 @@ pub use self::transform::{Transform, TransformOutput}; | ||||
| use super::new::StdResult; | ||||
| use crate::documents::{obkv_to_object, DocumentsBatchReader}; | ||||
| use crate::error::{Error, InternalError}; | ||||
| use crate::index::{PrefixSearch, PrefixSettings}; | ||||
| use crate::thread_pool_no_abort::ThreadPoolNoAbortBuilder; | ||||
| pub use crate::update::index_documents::helpers::CursorClonableMmap; | ||||
| use crate::update::{ | ||||
| @@ -82,8 +83,6 @@ pub struct IndexDocuments<'t, 'i, 'a, FP, FA> { | ||||
|  | ||||
| #[derive(Default, Debug, Clone)] | ||||
| pub struct IndexDocumentsConfig { | ||||
|     pub words_prefix_threshold: Option<u32>, | ||||
|     pub max_prefix_length: Option<usize>, | ||||
|     pub words_positions_level_group_size: Option<NonZeroU32>, | ||||
|     pub words_positions_min_level_size: Option<NonZeroU32>, | ||||
|     pub update_method: IndexDocumentsMethod, | ||||
| @@ -565,14 +564,32 @@ where | ||||
|             self.index.words_prefixes_fst(self.wtxn)?.map_data(|cow| cow.into_owned())?; | ||||
|  | ||||
|         // Run the words prefixes update operation. | ||||
|         let mut builder = WordsPrefixesFst::new(self.wtxn, self.index); | ||||
|         if let Some(value) = self.config.words_prefix_threshold { | ||||
|             builder.threshold(value); | ||||
|         let PrefixSettings { prefix_count_threshold, max_prefix_length, compute_prefixes } = | ||||
|             self.index.prefix_settings(self.wtxn)?; | ||||
|  | ||||
|         // If the prefix search is enabled at indexing time, we compute the prefixes. | ||||
|         if compute_prefixes == PrefixSearch::IndexingTime { | ||||
|             let mut builder = WordsPrefixesFst::new(self.wtxn, self.index); | ||||
|             builder.threshold(prefix_count_threshold); | ||||
|             builder.max_prefix_length(max_prefix_length); | ||||
|             builder.execute()?; | ||||
|         } else { | ||||
|             // If the prefix search is disabled at indexing time, we delete the previous words prefixes fst. | ||||
|             // And all the associated docids databases. | ||||
|             self.index.delete_words_prefixes_fst(self.wtxn)?; | ||||
|             self.index.word_prefix_docids.clear(self.wtxn)?; | ||||
|             self.index.exact_word_prefix_docids.clear(self.wtxn)?; | ||||
|             self.index.word_prefix_position_docids.clear(self.wtxn)?; | ||||
|             self.index.word_prefix_fid_docids.clear(self.wtxn)?; | ||||
|  | ||||
|             databases_seen += 3; | ||||
|             (self.progress)(UpdateIndexingStep::MergeDataIntoFinalDatabase { | ||||
|                 databases_seen, | ||||
|                 total_databases: TOTAL_POSTING_DATABASE_COUNT, | ||||
|             }); | ||||
|  | ||||
|             return Ok(()); | ||||
|         } | ||||
|         if let Some(value) = self.config.max_prefix_length { | ||||
|             builder.max_prefix_length(value); | ||||
|         } | ||||
|         builder.execute()?; | ||||
|  | ||||
|         if (self.should_abort)() { | ||||
|             return Err(Error::InternalError(InternalError::AbortedIndexation)); | ||||
|   | ||||
| @@ -667,14 +667,23 @@ impl<'a, 'i> Transform<'a, 'i> { | ||||
|         let is_primary_key = |id: FieldId| -> bool { settings_diff.primary_key_id == Some(id) }; | ||||
|  | ||||
|         // If only a faceted field has been added, keep only this field. | ||||
|         let must_reindex_facets = settings_diff.reindex_facets(); | ||||
|         let necessary_faceted_field = |id: FieldId| -> bool { | ||||
|             let field_name = settings_diff.new.fields_ids_map.name(id).unwrap(); | ||||
|             must_reindex_facets | ||||
|                 && modified_faceted_fields | ||||
|                     .iter() | ||||
|                     .any(|long| is_faceted_by(long, field_name) || is_faceted_by(field_name, long)) | ||||
|         }; | ||||
|         let global_facet_settings_changed = settings_diff.global_facet_settings_changed(); | ||||
|         let facet_fids_changed = settings_diff.facet_fids_changed(); | ||||
|         let necessary_faceted_field = | ||||
|             |id: FieldId| -> bool { | ||||
|                 let field_name = settings_diff.new.fields_ids_map.name(id).unwrap(); | ||||
|                 if global_facet_settings_changed { | ||||
|                     settings_diff.new.user_defined_faceted_fields.iter().any(|long| { | ||||
|                         is_faceted_by(long, field_name) || is_faceted_by(field_name, long) | ||||
|                     }) | ||||
|                 } else if facet_fids_changed { | ||||
|                     modified_faceted_fields.iter().any(|long| { | ||||
|                         is_faceted_by(long, field_name) || is_faceted_by(field_name, long) | ||||
|                     }) | ||||
|                 } else { | ||||
|                     false | ||||
|                 } | ||||
|             }; | ||||
|  | ||||
|         // Alway provide all fields when vectors are involved because | ||||
|         // we need the fields for the prompt/templating. | ||||
|   | ||||
| @@ -445,7 +445,10 @@ where | ||||
|  | ||||
|         (indexing_context.send_progress)(Progress::from_step(Step::PostProcessingFacets)); | ||||
|  | ||||
|         compute_facet_search_database(index, wtxn, global_fields_ids_map)?; | ||||
|         if index.facet_search(wtxn)? { | ||||
|             compute_facet_search_database(index, wtxn, global_fields_ids_map)?; | ||||
|         } | ||||
|  | ||||
|         compute_facet_level_database(index, wtxn, facet_field_ids_delta)?; | ||||
|  | ||||
|         (indexing_context.send_progress)(Progress::from_step(Step::PostProcessingWords)); | ||||
|   | ||||
| @@ -80,12 +80,12 @@ pub struct PrefixDelta { | ||||
| } | ||||
|  | ||||
| struct PrefixFstBuilder { | ||||
|     prefix_count_threshold: u64, | ||||
|     prefix_count_threshold: usize, | ||||
|     max_prefix_length: usize, | ||||
|     /// TODO: Replace the full memory allocation | ||||
|     prefix_fst_builders: Vec<SetBuilder<Vec<u8>>>, | ||||
|     current_prefix: Vec<Prefix>, | ||||
|     current_prefix_count: Vec<u64>, | ||||
|     current_prefix_count: Vec<usize>, | ||||
|     modified_prefixes: HashSet<Prefix>, | ||||
|     current_prefix_is_modified: Vec<bool>, | ||||
| } | ||||
| @@ -95,7 +95,7 @@ impl PrefixFstBuilder { | ||||
|         let PrefixSettings { prefix_count_threshold, max_prefix_length, compute_prefixes } = | ||||
|             prefix_settings; | ||||
|  | ||||
|         if !compute_prefixes { | ||||
|         if compute_prefixes != crate::index::PrefixSearch::IndexingTime { | ||||
|             return None; | ||||
|         } | ||||
|  | ||||
|   | ||||
| @@ -17,7 +17,8 @@ use super::IndexerConfig; | ||||
| use crate::criterion::Criterion; | ||||
| use crate::error::UserError; | ||||
| use crate::index::{ | ||||
|     IndexEmbeddingConfig, DEFAULT_MIN_WORD_LEN_ONE_TYPO, DEFAULT_MIN_WORD_LEN_TWO_TYPOS, | ||||
|     IndexEmbeddingConfig, PrefixSearch, DEFAULT_MIN_WORD_LEN_ONE_TYPO, | ||||
|     DEFAULT_MIN_WORD_LEN_TWO_TYPOS, | ||||
| }; | ||||
| use crate::order_by_map::OrderByMap; | ||||
| use crate::prompt::default_max_bytes; | ||||
| @@ -177,6 +178,8 @@ pub struct Settings<'a, 't, 'i> { | ||||
|     embedder_settings: Setting<BTreeMap<String, Setting<EmbeddingSettings>>>, | ||||
|     search_cutoff: Setting<u64>, | ||||
|     localized_attributes_rules: Setting<Vec<LocalizedAttributesRule>>, | ||||
|     prefix_search: Setting<PrefixSearch>, | ||||
|     facet_search: Setting<bool>, | ||||
| } | ||||
|  | ||||
| impl<'a, 't, 'i> Settings<'a, 't, 'i> { | ||||
| @@ -212,6 +215,8 @@ impl<'a, 't, 'i> Settings<'a, 't, 'i> { | ||||
|             embedder_settings: Setting::NotSet, | ||||
|             search_cutoff: Setting::NotSet, | ||||
|             localized_attributes_rules: Setting::NotSet, | ||||
|             prefix_search: Setting::NotSet, | ||||
|             facet_search: Setting::NotSet, | ||||
|             indexer_config, | ||||
|         } | ||||
|     } | ||||
| @@ -418,6 +423,22 @@ impl<'a, 't, 'i> Settings<'a, 't, 'i> { | ||||
|         self.localized_attributes_rules = Setting::Reset; | ||||
|     } | ||||
|  | ||||
|     pub fn set_prefix_search(&mut self, value: PrefixSearch) { | ||||
|         self.prefix_search = Setting::Set(value); | ||||
|     } | ||||
|  | ||||
|     pub fn reset_prefix_search(&mut self) { | ||||
|         self.prefix_search = Setting::Reset; | ||||
|     } | ||||
|  | ||||
|     pub fn set_facet_search(&mut self, value: bool) { | ||||
|         self.facet_search = Setting::Set(value); | ||||
|     } | ||||
|  | ||||
|     pub fn reset_facet_search(&mut self) { | ||||
|         self.facet_search = Setting::Reset; | ||||
|     } | ||||
|  | ||||
|     #[tracing::instrument( | ||||
|         level = "trace" | ||||
|         skip(self, progress_callback, should_abort, settings_diff), | ||||
| @@ -944,7 +965,7 @@ impl<'a, 't, 'i> Settings<'a, 't, 'i> { | ||||
|                     false | ||||
|                 } else { | ||||
|                     self.index.put_proximity_precision(self.wtxn, new)?; | ||||
|                     true | ||||
|                     old.is_some() || new != ProximityPrecision::default() | ||||
|                 } | ||||
|             } | ||||
|             Setting::Reset => self.index.delete_proximity_precision(self.wtxn)?, | ||||
| @@ -954,6 +975,42 @@ impl<'a, 't, 'i> Settings<'a, 't, 'i> { | ||||
|         Ok(changed) | ||||
|     } | ||||
|  | ||||
|     fn update_prefix_search(&mut self) -> Result<bool> { | ||||
|         let changed = match self.prefix_search { | ||||
|             Setting::Set(new) => { | ||||
|                 let old = self.index.prefix_search(self.wtxn)?; | ||||
|                 if old == Some(new) { | ||||
|                     false | ||||
|                 } else { | ||||
|                     self.index.put_prefix_search(self.wtxn, new)?; | ||||
|                     old.is_some() || new != PrefixSearch::default() | ||||
|                 } | ||||
|             } | ||||
|             Setting::Reset => self.index.delete_prefix_search(self.wtxn)?, | ||||
|             Setting::NotSet => false, | ||||
|         }; | ||||
|  | ||||
|         Ok(changed) | ||||
|     } | ||||
|  | ||||
|     fn update_facet_search(&mut self) -> Result<bool> { | ||||
|         let changed = match self.facet_search { | ||||
|             Setting::Set(new) => { | ||||
|                 let old = self.index.facet_search(self.wtxn)?; | ||||
|                 if old == new { | ||||
|                     false | ||||
|                 } else { | ||||
|                     self.index.put_facet_search(self.wtxn, new)?; | ||||
|                     true | ||||
|                 } | ||||
|             } | ||||
|             Setting::Reset => self.index.delete_facet_search(self.wtxn)?, | ||||
|             Setting::NotSet => false, | ||||
|         }; | ||||
|  | ||||
|         Ok(changed) | ||||
|     } | ||||
|  | ||||
|     fn update_embedding_configs(&mut self) -> Result<BTreeMap<String, EmbedderAction>> { | ||||
|         match std::mem::take(&mut self.embedder_settings) { | ||||
|             Setting::Set(configs) => self.update_embedding_configs_set(configs), | ||||
| @@ -1203,6 +1260,8 @@ impl<'a, 't, 'i> Settings<'a, 't, 'i> { | ||||
|         self.update_searchable()?; | ||||
|         self.update_exact_attributes()?; | ||||
|         self.update_proximity_precision()?; | ||||
|         self.update_prefix_search()?; | ||||
|         self.update_facet_search()?; | ||||
|         self.update_localized_attributes_rules()?; | ||||
|  | ||||
|         let embedding_config_updates = self.update_embedding_configs()?; | ||||
| @@ -1282,6 +1341,7 @@ impl InnerIndexSettingsDiff { | ||||
|                 || old_settings.allowed_separators != new_settings.allowed_separators | ||||
|                 || old_settings.dictionary != new_settings.dictionary | ||||
|                 || old_settings.proximity_precision != new_settings.proximity_precision | ||||
|                 || old_settings.prefix_search != new_settings.prefix_search | ||||
|                 || old_settings.localized_searchable_fields_ids | ||||
|                     != new_settings.localized_searchable_fields_ids | ||||
|         }; | ||||
| @@ -1372,7 +1432,7 @@ impl InnerIndexSettingsDiff { | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     pub fn reindex_facets(&self) -> bool { | ||||
|     pub fn facet_fids_changed(&self) -> bool { | ||||
|         let existing_fields = &self.new.existing_fields; | ||||
|         if existing_fields.iter().any(|field| field.contains('.')) { | ||||
|             return true; | ||||
| @@ -1392,7 +1452,15 @@ impl InnerIndexSettingsDiff { | ||||
|         } | ||||
|  | ||||
|         (existing_fields - old_faceted_fields) != (existing_fields - new_faceted_fields) | ||||
|             || self.old.localized_faceted_fields_ids != self.new.localized_faceted_fields_ids | ||||
|     } | ||||
|  | ||||
|     pub fn global_facet_settings_changed(&self) -> bool { | ||||
|         self.old.localized_faceted_fields_ids != self.new.localized_faceted_fields_ids | ||||
|             || self.old.facet_search != self.new.facet_search | ||||
|     } | ||||
|  | ||||
|     pub fn reindex_facets(&self) -> bool { | ||||
|         self.facet_fids_changed() || self.global_facet_settings_changed() | ||||
|     } | ||||
|  | ||||
|     pub fn reindex_vectors(&self) -> bool { | ||||
| @@ -1432,6 +1500,8 @@ pub(crate) struct InnerIndexSettings { | ||||
|     pub non_faceted_fields_ids: Vec<FieldId>, | ||||
|     pub localized_searchable_fields_ids: LocalizedFieldIds, | ||||
|     pub localized_faceted_fields_ids: LocalizedFieldIds, | ||||
|     pub prefix_search: PrefixSearch, | ||||
|     pub facet_search: bool, | ||||
| } | ||||
|  | ||||
| impl InnerIndexSettings { | ||||
| @@ -1457,6 +1527,8 @@ impl InnerIndexSettings { | ||||
|             Some(embedding_configs) => embedding_configs, | ||||
|             None => embedders(index.embedding_configs(rtxn)?)?, | ||||
|         }; | ||||
|         let prefix_search = index.prefix_search(rtxn)?.unwrap_or_default(); | ||||
|         let facet_search = index.facet_search(rtxn)?; | ||||
|         let existing_fields: HashSet<_> = index | ||||
|             .field_distribution(rtxn)? | ||||
|             .into_iter() | ||||
| @@ -1514,6 +1586,8 @@ impl InnerIndexSettings { | ||||
|             non_faceted_fields_ids: vectors_fids.clone(), | ||||
|             localized_searchable_fields_ids, | ||||
|             localized_faceted_fields_ids, | ||||
|             prefix_search, | ||||
|             facet_search, | ||||
|         }) | ||||
|     } | ||||
|  | ||||
| @@ -2721,6 +2795,8 @@ mod tests { | ||||
|                     embedder_settings, | ||||
|                     search_cutoff, | ||||
|                     localized_attributes_rules, | ||||
|                     prefix_search, | ||||
|                     facet_search, | ||||
|                 } = settings; | ||||
|                 assert!(matches!(searchable_fields, Setting::NotSet)); | ||||
|                 assert!(matches!(displayed_fields, Setting::NotSet)); | ||||
| @@ -2746,6 +2822,8 @@ mod tests { | ||||
|                 assert!(matches!(embedder_settings, Setting::NotSet)); | ||||
|                 assert!(matches!(search_cutoff, Setting::NotSet)); | ||||
|                 assert!(matches!(localized_attributes_rules, Setting::NotSet)); | ||||
|                 assert!(matches!(prefix_search, Setting::NotSet)); | ||||
|                 assert!(matches!(facet_search, Setting::NotSet)); | ||||
|             }) | ||||
|             .unwrap(); | ||||
|     } | ||||
|   | ||||
| @@ -9,7 +9,7 @@ use crate::{Index, Result, SmallString32}; | ||||
| pub struct WordsPrefixesFst<'t, 'i> { | ||||
|     wtxn: &'t mut RwTxn<'i>, | ||||
|     index: &'i Index, | ||||
|     threshold: u32, | ||||
|     threshold: usize, | ||||
|     max_prefix_length: usize, | ||||
| } | ||||
|  | ||||
| @@ -24,8 +24,8 @@ impl<'t, 'i> WordsPrefixesFst<'t, 'i> { | ||||
|     /// | ||||
|     /// Default value is 100. This value must be higher than 50 and will be clamped | ||||
|     /// to this bound otherwise. | ||||
|     pub fn threshold(&mut self, value: u32) -> &mut Self { | ||||
|         self.threshold = value.max(50); | ||||
|     pub fn threshold(&mut self, value: usize) -> &mut Self { | ||||
|         self.threshold = value; | ||||
|         self | ||||
|     } | ||||
|  | ||||
| @@ -34,7 +34,7 @@ impl<'t, 'i> WordsPrefixesFst<'t, 'i> { | ||||
|     /// Default value is `4` bytes. This value must be between 1 and 25 will be clamped | ||||
|     /// to these bounds, otherwise. | ||||
|     pub fn max_prefix_length(&mut self, value: usize) -> &mut Self { | ||||
|         self.max_prefix_length = value.clamp(1, 25); | ||||
|         self.max_prefix_length = value; | ||||
|         self | ||||
|     } | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user