mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-26 05:26:27 +00:00 
			
		
		
		
	Merge branch 'main' into settings-customizing-tokenization
This commit is contained in:
		| @@ -19,6 +19,7 @@ actix-http = { version = "3.3.1", default-features = false, features = [ | ||||
|     "compress-gzip", | ||||
|     "rustls", | ||||
| ] } | ||||
| actix-utils = "3.0.1" | ||||
| actix-web = { version = "4.3.1", default-features = false, features = [ | ||||
|     "macros", | ||||
|     "compress-brotli", | ||||
| @@ -50,13 +51,14 @@ futures-util = "0.3.28" | ||||
| http = "0.2.9" | ||||
| index-scheduler = { path = "../index-scheduler" } | ||||
| indexmap = { version = "1.9.3", features = ["serde-1"] } | ||||
| is-terminal = "0.4.8" | ||||
| itertools = "0.10.5" | ||||
| jsonwebtoken = "8.3.0" | ||||
| lazy_static = "1.4.0" | ||||
| log = "0.4.17" | ||||
| meilisearch-auth = { path = "../meilisearch-auth" } | ||||
| meilisearch-types = { path = "../meilisearch-types" } | ||||
| mimalloc = { version = "0.1.36", default-features = false } | ||||
| mimalloc = { version = "0.1.37", default-features = false } | ||||
| mime = "0.3.17" | ||||
| num_cpus = "1.15.0" | ||||
| obkv = "0.2.0" | ||||
| @@ -102,8 +104,6 @@ uuid = { version = "1.3.1", features = ["serde", "v4"] } | ||||
| walkdir = "2.3.3" | ||||
| yaup = "0.2.1" | ||||
| serde_urlencoded = "0.7.1" | ||||
| actix-utils = "3.0.1" | ||||
| atty = "0.2.14" | ||||
| termcolor = "1.2.0" | ||||
|  | ||||
| [dev-dependencies] | ||||
| @@ -154,5 +154,5 @@ thai = ["meilisearch-types/thai"] | ||||
| greek = ["meilisearch-types/greek"] | ||||
|  | ||||
| [package.metadata.mini-dashboard] | ||||
| assets-url = "https://github.com/meilisearch/mini-dashboard/releases/download/v0.2.7/build.zip" | ||||
| sha1 = "28b45bf772c84f9a6e16bc1689b393bfce8da7d6" | ||||
| assets-url = "https://github.com/meilisearch/mini-dashboard/releases/download/v0.2.11/build.zip" | ||||
| sha1 = "83cd44ed1e5f97ecb581dc9f958a63f4ccc982d9" | ||||
|   | ||||
| @@ -574,6 +574,10 @@ pub struct SearchAggregator { | ||||
|     filter_total_number_of_criteria: usize, | ||||
|     used_syntax: HashMap<String, usize>, | ||||
|  | ||||
|     // attributes_to_search_on | ||||
|     // every time a search is done using attributes_to_search_on | ||||
|     attributes_to_search_on_total_number_of_uses: usize, | ||||
|  | ||||
|     // q | ||||
|     // The maximum number of terms in a q request | ||||
|     max_terms_number: usize, | ||||
| @@ -647,6 +651,11 @@ impl SearchAggregator { | ||||
|             ret.filter_sum_of_criteria_terms = RE.split(&stringified_filters).count(); | ||||
|         } | ||||
|  | ||||
|         // attributes_to_search_on | ||||
|         if let Some(_) = query.attributes_to_search_on { | ||||
|             ret.attributes_to_search_on_total_number_of_uses = 1; | ||||
|         } | ||||
|  | ||||
|         if let Some(ref q) = query.q { | ||||
|             ret.max_terms_number = q.split_whitespace().count(); | ||||
|         } | ||||
| @@ -720,9 +729,18 @@ impl SearchAggregator { | ||||
|             let used_syntax = self.used_syntax.entry(key).or_insert(0); | ||||
|             *used_syntax = used_syntax.saturating_add(value); | ||||
|         } | ||||
|  | ||||
|         // attributes_to_search_on | ||||
|         self.attributes_to_search_on_total_number_of_uses = self | ||||
|             .attributes_to_search_on_total_number_of_uses | ||||
|             .saturating_add(other.attributes_to_search_on_total_number_of_uses); | ||||
|  | ||||
|         // q | ||||
|         self.max_terms_number = self.max_terms_number.max(other.max_terms_number); | ||||
|  | ||||
|         // vector | ||||
|         self.max_vector_size = self.max_vector_size.max(other.max_vector_size); | ||||
|  | ||||
|         // pagination | ||||
|         self.max_limit = self.max_limit.max(other.max_limit); | ||||
|         self.max_offset = self.max_offset.max(other.max_offset); | ||||
| @@ -761,17 +779,17 @@ impl SearchAggregator { | ||||
|         if self.total_received == 0 { | ||||
|             None | ||||
|         } else { | ||||
|             // the index of the 99th percentage of value | ||||
|             let percentile_99th = 0.99 * (self.total_succeeded as f64 - 1.) + 1.; | ||||
|             // we get all the values in a sorted manner | ||||
|             let time_spent = self.time_spent.into_sorted_vec(); | ||||
|             // the index of the 99th percentage of value | ||||
|             let percentile_99th = time_spent.len() * 99 / 100; | ||||
|             // We are only interested by the slowest value of the 99th fastest results | ||||
|             let time_spent = time_spent.get(percentile_99th as usize); | ||||
|             let time_spent = time_spent.get(percentile_99th); | ||||
|  | ||||
|             let properties = json!({ | ||||
|                 "user-agent": self.user_agents, | ||||
|                 "requests": { | ||||
|                     "99th_response_time":  time_spent.map(|t| format!("{:.2}", t)), | ||||
|                     "99th_response_time": time_spent.map(|t| format!("{:.2}", t)), | ||||
|                     "total_succeeded": self.total_succeeded, | ||||
|                     "total_failed": self.total_received.saturating_sub(self.total_succeeded), // just to be sure we never panics | ||||
|                     "total_received": self.total_received, | ||||
| @@ -786,9 +804,15 @@ impl SearchAggregator { | ||||
|                    "avg_criteria_number": format!("{:.2}", self.filter_sum_of_criteria_terms as f64 / self.filter_total_number_of_criteria as f64), | ||||
|                    "most_used_syntax": self.used_syntax.iter().max_by_key(|(_, v)| *v).map(|(k, _)| json!(k)).unwrap_or_else(|| json!(null)), | ||||
|                 }, | ||||
|                 "attributes_to_search_on": { | ||||
|                    "total_number_of_uses": self.attributes_to_search_on_total_number_of_uses, | ||||
|                 }, | ||||
|                 "q": { | ||||
|                    "max_terms_number": self.max_terms_number, | ||||
|                 }, | ||||
|                 "vector": { | ||||
|                     "max_vector_size": self.max_vector_size, | ||||
|                 }, | ||||
|                 "pagination": { | ||||
|                    "max_limit": self.max_limit, | ||||
|                    "max_offset": self.max_offset, | ||||
| @@ -843,6 +867,10 @@ pub struct MultiSearchAggregator { | ||||
|     // sum of the number of search queries in the requests, use with total_received to compute an average | ||||
|     total_search_count: usize, | ||||
|  | ||||
|     // scoring | ||||
|     show_ranking_score: bool, | ||||
|     show_ranking_score_details: bool, | ||||
|  | ||||
|     // context | ||||
|     user_agents: HashSet<String>, | ||||
| } | ||||
| @@ -856,6 +884,9 @@ impl MultiSearchAggregator { | ||||
|         let distinct_indexes: HashSet<_> = | ||||
|             query.iter().map(|query| query.index_uid.as_str()).collect(); | ||||
|  | ||||
|         let show_ranking_score = query.iter().any(|query| query.show_ranking_score); | ||||
|         let show_ranking_score_details = query.iter().any(|query| query.show_ranking_score_details); | ||||
|  | ||||
|         Self { | ||||
|             timestamp, | ||||
|             total_received: 1, | ||||
| @@ -863,6 +894,8 @@ impl MultiSearchAggregator { | ||||
|             total_distinct_index_count: distinct_indexes.len(), | ||||
|             total_single_index: if distinct_indexes.len() == 1 { 1 } else { 0 }, | ||||
|             total_search_count: query.len(), | ||||
|             show_ranking_score, | ||||
|             show_ranking_score_details, | ||||
|             user_agents, | ||||
|         } | ||||
|     } | ||||
| @@ -884,6 +917,9 @@ impl MultiSearchAggregator { | ||||
|             this.total_distinct_index_count.saturating_add(other.total_distinct_index_count); | ||||
|         let total_single_index = this.total_single_index.saturating_add(other.total_single_index); | ||||
|         let total_search_count = this.total_search_count.saturating_add(other.total_search_count); | ||||
|         let show_ranking_score = this.show_ranking_score || other.show_ranking_score; | ||||
|         let show_ranking_score_details = | ||||
|             this.show_ranking_score_details || other.show_ranking_score_details; | ||||
|         let mut user_agents = this.user_agents; | ||||
|  | ||||
|         for user_agent in other.user_agents.into_iter() { | ||||
| @@ -899,6 +935,8 @@ impl MultiSearchAggregator { | ||||
|             total_single_index, | ||||
|             total_search_count, | ||||
|             user_agents, | ||||
|             show_ranking_score, | ||||
|             show_ranking_score_details, | ||||
|             // do not add _ or ..Default::default() here | ||||
|         }; | ||||
|  | ||||
| @@ -925,6 +963,10 @@ impl MultiSearchAggregator { | ||||
|                 "searches": { | ||||
|                     "total_search_count": self.total_search_count, | ||||
|                     "avg_search_count": (self.total_search_count as f64) / (self.total_received as f64), | ||||
|                 }, | ||||
|                 "scoring": { | ||||
|                     "show_ranking_score": self.show_ranking_score, | ||||
|                     "show_ranking_score_details": self.show_ranking_score_details, | ||||
|                 } | ||||
|             }); | ||||
|  | ||||
| @@ -1145,6 +1187,7 @@ pub struct DocumentsDeletionAggregator { | ||||
|     #[serde(rename = "user-agent")] | ||||
|     user_agents: HashSet<String>, | ||||
|  | ||||
|     #[serde(rename = "requests.total_received")] | ||||
|     total_received: usize, | ||||
|     per_document_id: bool, | ||||
|     clear_all: bool, | ||||
| @@ -1295,6 +1338,7 @@ pub struct HealthAggregator { | ||||
|     #[serde(rename = "user-agent")] | ||||
|     user_agents: HashSet<String>, | ||||
|  | ||||
|     #[serde(rename = "requests.total_received")] | ||||
|     total_received: usize, | ||||
| } | ||||
|  | ||||
| @@ -1345,7 +1389,7 @@ pub struct DocumentsFetchAggregator { | ||||
|     #[serde(rename = "user-agent")] | ||||
|     user_agents: HashSet<String>, | ||||
|  | ||||
|     #[serde(rename = "requests.max_limit")] | ||||
|     #[serde(rename = "requests.total_received")] | ||||
|     total_received: usize, | ||||
|  | ||||
|     // a call on ../documents/:doc_id | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| use std::env; | ||||
| use std::io::Write; | ||||
| use std::io::{stderr, Write}; | ||||
| use std::path::PathBuf; | ||||
| use std::sync::Arc; | ||||
|  | ||||
| @@ -7,6 +7,7 @@ use actix_web::http::KeepAlive; | ||||
| use actix_web::web::Data; | ||||
| use actix_web::HttpServer; | ||||
| use index_scheduler::IndexScheduler; | ||||
| use is_terminal::IsTerminal; | ||||
| use meilisearch::analytics::Analytics; | ||||
| use meilisearch::{analytics, create_app, prototype_name, setup_meilisearch, Opt}; | ||||
| use meilisearch_auth::{generate_master_key, AuthController, MASTER_KEY_MIN_SIZE}; | ||||
| @@ -190,7 +191,7 @@ Anonymous telemetry:\t\"Enabled\"" | ||||
|     } | ||||
|  | ||||
|     eprintln!(); | ||||
|     eprintln!("Check out Meilisearch Cloud!\thttps://cloud.meilisearch.com/login?utm_campaign=oss&utm_source=engine&utm_medium=cli"); | ||||
|     eprintln!("Check out Meilisearch Cloud!\thttps://www.meilisearch.com/cloud?utm_campaign=oss&utm_source=engine&utm_medium=cli"); | ||||
|     eprintln!("Documentation:\t\t\thttps://www.meilisearch.com/docs"); | ||||
|     eprintln!("Source code:\t\t\thttps://github.com/meilisearch/meilisearch"); | ||||
|     eprintln!("Discord:\t\t\thttps://discord.meilisearch.com"); | ||||
| @@ -201,8 +202,7 @@ const WARNING_BG_COLOR: Option<Color> = Some(Color::Ansi256(178)); | ||||
| const WARNING_FG_COLOR: Option<Color> = Some(Color::Ansi256(0)); | ||||
|  | ||||
| fn print_master_key_too_short_warning() { | ||||
|     let choice = | ||||
|         if atty::is(atty::Stream::Stderr) { ColorChoice::Auto } else { ColorChoice::Never }; | ||||
|     let choice = if stderr().is_terminal() { ColorChoice::Auto } else { ColorChoice::Never }; | ||||
|     let mut stderr = StandardStream::stderr(choice); | ||||
|     stderr | ||||
|         .set_color( | ||||
| @@ -227,8 +227,7 @@ fn print_master_key_too_short_warning() { | ||||
| } | ||||
|  | ||||
| fn print_missing_master_key_warning() { | ||||
|     let choice = | ||||
|         if atty::is(atty::Stream::Stderr) { ColorChoice::Auto } else { ColorChoice::Never }; | ||||
|     let choice = if stderr().is_terminal() { ColorChoice::Auto } else { ColorChoice::Never }; | ||||
|     let mut stderr = StandardStream::stderr(choice); | ||||
|     stderr | ||||
|         .set_color( | ||||
|   | ||||
| @@ -50,4 +50,10 @@ lazy_static! { | ||||
|         &["kind", "value"] | ||||
|     ) | ||||
|     .expect("Can't create a metric"); | ||||
|     pub static ref MEILISEARCH_LAST_UPDATE: IntGauge = | ||||
|         register_int_gauge!(opts!("meilisearch_last_update", "Meilisearch Last Update")) | ||||
|             .expect("Can't create a metric"); | ||||
|     pub static ref MEILISEARCH_IS_INDEXING: IntGauge = | ||||
|         register_int_gauge!(opts!("meilisearch_is_indexing", "Meilisearch Is Indexing")) | ||||
|             .expect("Can't create a metric"); | ||||
| } | ||||
|   | ||||
| @@ -64,7 +64,20 @@ async fn patch_features( | ||||
|         vector_store: new_features.0.vector_store.unwrap_or(old_features.vector_store), | ||||
|     }; | ||||
|  | ||||
|     analytics.publish("Experimental features Updated".to_string(), json!(new_features), Some(&req)); | ||||
|     // explicitly destructure for analytics rather than using the `Serialize` implementation, because | ||||
|     // the it renames to camelCase, which we don't want for analytics. | ||||
|     // **Do not** ignore fields with `..` or `_` here, because we want to add them in the future. | ||||
|     let meilisearch_types::features::RuntimeTogglableFeatures { score_details, vector_store } = | ||||
|         new_features; | ||||
|  | ||||
|     analytics.publish( | ||||
|         "Experimental features Updated".to_string(), | ||||
|         json!({ | ||||
|             "score_details": score_details, | ||||
|             "vector_store": vector_store, | ||||
|         }), | ||||
|         Some(&req), | ||||
|     ); | ||||
|     index_scheduler.put_runtime_features(new_features)?; | ||||
|     Ok(HttpResponse::Ok().json(new_features)) | ||||
| } | ||||
|   | ||||
| @@ -35,7 +35,7 @@ pub struct SearchQueryGet { | ||||
|     #[deserr(default, error = DeserrQueryParamError<InvalidSearchQ>)] | ||||
|     q: Option<String>, | ||||
|     #[deserr(default, error = DeserrQueryParamError<InvalidSearchVector>)] | ||||
|     vector: Option<Vec<f32>>, | ||||
|     vector: Option<CS<f32>>, | ||||
|     #[deserr(default = Param(DEFAULT_SEARCH_OFFSET()), error = DeserrQueryParamError<InvalidSearchOffset>)] | ||||
|     offset: Param<usize>, | ||||
|     #[deserr(default = Param(DEFAULT_SEARCH_LIMIT()), error = DeserrQueryParamError<InvalidSearchLimit>)] | ||||
| @@ -88,7 +88,7 @@ impl From<SearchQueryGet> for SearchQuery { | ||||
|  | ||||
|         Self { | ||||
|             q: other.q, | ||||
|             vector: other.vector, | ||||
|             vector: other.vector.map(CS::into_inner), | ||||
|             offset: other.offset.0, | ||||
|             limit: other.limit.0, | ||||
|             page: other.page.as_deref().copied(), | ||||
|   | ||||
| @@ -5,6 +5,7 @@ use index_scheduler::IndexScheduler; | ||||
| use log::debug; | ||||
| use meilisearch_types::deserr::DeserrJsonError; | ||||
| use meilisearch_types::error::ResponseError; | ||||
| use meilisearch_types::facet_values_sort::FacetValuesSort; | ||||
| use meilisearch_types::index_uid::IndexUid; | ||||
| use meilisearch_types::settings::{settings, RankingRuleView, Settings, Unchecked}; | ||||
| use meilisearch_types::tasks::KindWithContent; | ||||
| @@ -628,10 +629,16 @@ pub async fn update_all( | ||||
|                     .as_ref() | ||||
|                     .set() | ||||
|                     .and_then(|s| s.max_values_per_facet.as_ref().set()), | ||||
|                 "sort_facet_values_by": new_settings.faceting | ||||
|                 "sort_facet_values_by_star_count": new_settings.faceting | ||||
|                     .as_ref() | ||||
|                     .set() | ||||
|                     .and_then(|s| s.sort_facet_values_by.as_ref().set()), | ||||
|                     .and_then(|s| { | ||||
|                         s.sort_facet_values_by.as_ref().set().map(|s| s.iter().any(|(k, v)| k == "*" && v == &FacetValuesSort::Count)) | ||||
|                     }), | ||||
|                 "sort_facet_values_by_total": new_settings.faceting | ||||
|                     .as_ref() | ||||
|                     .set() | ||||
|                     .and_then(|s| s.sort_facet_values_by.as_ref().set().map(|s| s.len())), | ||||
|             }, | ||||
|             "pagination": { | ||||
|                 "max_total_hits": new_settings.pagination | ||||
|   | ||||
| @@ -49,6 +49,11 @@ pub async fn get_metrics( | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     if let Some(last_update) = response.last_update { | ||||
|         crate::metrics::MEILISEARCH_LAST_UPDATE.set(last_update.unix_timestamp()); | ||||
|     } | ||||
|     crate::metrics::MEILISEARCH_IS_INDEXING.set(index_scheduler.is_task_processing()? as i64); | ||||
|  | ||||
|     let encoder = TextEncoder::new(); | ||||
|     let mut buffer = vec![]; | ||||
|     encoder.encode(&prometheus::gather(), &mut buffer).expect("Failed to encode metrics"); | ||||
|   | ||||
| @@ -284,9 +284,6 @@ pub fn create_all_stats( | ||||
|     used_database_size += index_scheduler.used_size()?; | ||||
|     database_size += auth_controller.size()?; | ||||
|     used_database_size += auth_controller.used_size()?; | ||||
|     let update_file_size = index_scheduler.compute_update_file_size()?; | ||||
|     database_size += update_file_size; | ||||
|     used_database_size += update_file_size; | ||||
|  | ||||
|     let stats = Stats { database_size, used_database_size, last_update: last_task, indexes }; | ||||
|     Ok(stats) | ||||
|   | ||||
| @@ -325,7 +325,7 @@ async fn cancel_tasks( | ||||
|  | ||||
|     let query = params.into_query(); | ||||
|  | ||||
|     let tasks = index_scheduler.get_task_ids_from_authorized_indexes( | ||||
|     let (tasks, _) = index_scheduler.get_task_ids_from_authorized_indexes( | ||||
|         &index_scheduler.read_txn()?, | ||||
|         &query, | ||||
|         index_scheduler.filters(), | ||||
| @@ -370,7 +370,7 @@ async fn delete_tasks( | ||||
|     ); | ||||
|     let query = params.into_query(); | ||||
|  | ||||
|     let tasks = index_scheduler.get_task_ids_from_authorized_indexes( | ||||
|     let (tasks, _) = index_scheduler.get_task_ids_from_authorized_indexes( | ||||
|         &index_scheduler.read_txn()?, | ||||
|         &query, | ||||
|         index_scheduler.filters(), | ||||
| @@ -387,6 +387,7 @@ async fn delete_tasks( | ||||
| #[derive(Debug, Serialize)] | ||||
| pub struct AllTasks { | ||||
|     results: Vec<TaskView>, | ||||
|     total: u64, | ||||
|     limit: u32, | ||||
|     from: Option<u32>, | ||||
|     next: Option<u32>, | ||||
| @@ -406,23 +407,17 @@ async fn get_tasks( | ||||
|     let limit = params.limit.0; | ||||
|     let query = params.into_query(); | ||||
|  | ||||
|     let mut tasks_results: Vec<TaskView> = index_scheduler | ||||
|         .get_tasks_from_authorized_indexes(query, index_scheduler.filters())? | ||||
|         .into_iter() | ||||
|         .map(|t| TaskView::from_task(&t)) | ||||
|         .collect(); | ||||
|     let filters = index_scheduler.filters(); | ||||
|     let (tasks, total) = index_scheduler.get_tasks_from_authorized_indexes(query, filters)?; | ||||
|     let mut results: Vec<_> = tasks.iter().map(TaskView::from_task).collect(); | ||||
|  | ||||
|     // If we were able to fetch the number +1 tasks we asked | ||||
|     // it means that there is more to come. | ||||
|     let next = if tasks_results.len() == limit as usize { | ||||
|         tasks_results.pop().map(|t| t.uid) | ||||
|     } else { | ||||
|         None | ||||
|     }; | ||||
|     let next = if results.len() == limit as usize { results.pop().map(|t| t.uid) } else { None }; | ||||
|  | ||||
|     let from = tasks_results.first().map(|t| t.uid); | ||||
|     let from = results.first().map(|t| t.uid); | ||||
|     let tasks = AllTasks { results, limit: limit.saturating_sub(1), total, from, next }; | ||||
|  | ||||
|     let tasks = AllTasks { results: tasks_results, limit: limit.saturating_sub(1), from, next }; | ||||
|     Ok(HttpResponse::Ok().json(tasks)) | ||||
| } | ||||
|  | ||||
| @@ -444,10 +439,10 @@ async fn get_task( | ||||
|     analytics.publish("Tasks Seen".to_string(), json!({ "per_task_uid": true }), Some(&req)); | ||||
|  | ||||
|     let query = index_scheduler::Query { uids: Some(vec![task_uid]), ..Query::default() }; | ||||
|     let filters = index_scheduler.filters(); | ||||
|     let (tasks, _) = index_scheduler.get_tasks_from_authorized_indexes(query, filters)?; | ||||
|  | ||||
|     if let Some(task) = | ||||
|         index_scheduler.get_tasks_from_authorized_indexes(query, index_scheduler.filters())?.first() | ||||
|     { | ||||
|     if let Some(task) = tasks.first() { | ||||
|         let task_view = TaskView::from_task(task); | ||||
|         Ok(HttpResponse::Ok().json(task_view)) | ||||
|     } else { | ||||
|   | ||||
| @@ -61,6 +61,8 @@ pub static AUTHORIZATIONS: Lazy<HashMap<(&'static str, &'static str), HashSet<&' | ||||
|             ("DELETE",  "/keys/mykey/") =>                                     hashset!{"keys.delete", "*"}, | ||||
|             ("POST",    "/keys") =>                                            hashset!{"keys.create", "*"}, | ||||
|             ("GET",     "/keys") =>                                            hashset!{"keys.get", "*"}, | ||||
|             ("GET",     "/experimental-features") =>                           hashset!{"experimental.get", "*"}, | ||||
|             ("PATCH",   "/experimental-features") =>                           hashset!{"experimental.update", "*"}, | ||||
|         }; | ||||
|  | ||||
|         authorizations | ||||
|   | ||||
| @@ -189,6 +189,14 @@ impl Server { | ||||
|         let url = format!("/tasks/{}", update_id); | ||||
|         self.service.get(url).await | ||||
|     } | ||||
|  | ||||
|     pub async fn get_features(&self) -> (Value, StatusCode) { | ||||
|         self.service.get("/experimental-features").await | ||||
|     } | ||||
|  | ||||
|     pub async fn set_features(&self, value: Value) -> (Value, StatusCode) { | ||||
|         self.service.patch("/experimental-features", value).await | ||||
|     } | ||||
| } | ||||
|  | ||||
| pub fn default_settings(dir: impl AsRef<Path>) -> Opt { | ||||
|   | ||||
| @@ -85,7 +85,7 @@ async fn import_dump_v1_movie_raw() { | ||||
|     snapshot!(code, @"200 OK"); | ||||
|     assert_eq!( | ||||
|         tasks, | ||||
|         json!({ "results": [{"uid": 0, "indexUid": "indexUID", "status": "succeeded", "type": "documentAdditionOrUpdate", "canceledBy": null, "details": { "receivedDocuments": 0, "indexedDocuments": 31968 }, "error": null, "duration": "PT9.317060500S", "enqueuedAt": "2021-09-08T09:08:45.153219Z", "startedAt": "2021-09-08T09:08:45.3961665Z", "finishedAt": "2021-09-08T09:08:54.713227Z" }], "limit": 20, "from": 0, "next": null }) | ||||
|         json!({ "results": [{"uid": 0, "indexUid": "indexUID", "status": "succeeded", "type": "documentAdditionOrUpdate", "canceledBy": null, "details": { "receivedDocuments": 0, "indexedDocuments": 31968 }, "error": null, "duration": "PT9.317060500S", "enqueuedAt": "2021-09-08T09:08:45.153219Z", "startedAt": "2021-09-08T09:08:45.3961665Z", "finishedAt": "2021-09-08T09:08:54.713227Z" }], "total": 1,  "limit": 20, "from": 0, "next": null }) | ||||
|     ); | ||||
|  | ||||
|     // finally we're just going to check that we can still get a few documents by id | ||||
| @@ -245,7 +245,7 @@ async fn import_dump_v1_movie_with_settings() { | ||||
|     snapshot!(code, @"200 OK"); | ||||
|     assert_eq!( | ||||
|         tasks, | ||||
|         json!({ "results": [{ "uid": 1, "indexUid": "indexUID", "status": "succeeded", "type": "settingsUpdate", "canceledBy": null, "details": { "displayedAttributes": ["genres", "id", "overview", "poster", "release_date", "title"], "searchableAttributes": ["title", "overview"], "filterableAttributes": ["genres"], "sortableAttributes": ["genres"], "stopWords": ["of", "the"] }, "error": null, "duration": "PT7.288826907S", "enqueuedAt": "2021-09-08T09:34:40.882977Z", "startedAt": "2021-09-08T09:34:40.883073093Z", "finishedAt": "2021-09-08T09:34:48.1719Z"}, { "uid": 0, "indexUid": "indexUID", "status": "succeeded", "type": "documentAdditionOrUpdate", "canceledBy": null, "details": { "receivedDocuments": 0, "indexedDocuments": 31968 }, "error": null, "duration": "PT9.090735774S", "enqueuedAt": "2021-09-08T09:34:16.036101Z", "startedAt": "2021-09-08T09:34:16.261191226Z", "finishedAt": "2021-09-08T09:34:25.351927Z" }], "limit": 20, "from": 1, "next": null }) | ||||
|         json!({ "results": [{ "uid": 1, "indexUid": "indexUID", "status": "succeeded", "type": "settingsUpdate", "canceledBy": null, "details": { "displayedAttributes": ["genres", "id", "overview", "poster", "release_date", "title"], "searchableAttributes": ["title", "overview"], "filterableAttributes": ["genres"], "sortableAttributes": ["genres"], "stopWords": ["of", "the"] }, "error": null, "duration": "PT7.288826907S", "enqueuedAt": "2021-09-08T09:34:40.882977Z", "startedAt": "2021-09-08T09:34:40.883073093Z", "finishedAt": "2021-09-08T09:34:48.1719Z"}, { "uid": 0, "indexUid": "indexUID", "status": "succeeded", "type": "documentAdditionOrUpdate", "canceledBy": null, "details": { "receivedDocuments": 0, "indexedDocuments": 31968 }, "error": null, "duration": "PT9.090735774S", "enqueuedAt": "2021-09-08T09:34:16.036101Z", "startedAt": "2021-09-08T09:34:16.261191226Z", "finishedAt": "2021-09-08T09:34:25.351927Z" }], "total": 2, "limit": 20, "from": 1, "next": null }) | ||||
|     ); | ||||
|  | ||||
|     // finally we're just going to check that we can still get a few documents by id | ||||
| @@ -523,7 +523,7 @@ async fn import_dump_v2_movie_raw() { | ||||
|     snapshot!(code, @"200 OK"); | ||||
|     assert_eq!( | ||||
|         tasks, | ||||
|         json!({ "results": [{"uid": 0, "indexUid": "indexUID", "status": "succeeded", "type": "documentAdditionOrUpdate", "canceledBy": null, "details": { "receivedDocuments": 0, "indexedDocuments": 31944 }, "error": null, "duration": "PT41.751156S", "enqueuedAt": "2021-09-08T08:30:30.550282Z", "startedAt": "2021-09-08T08:30:30.553012Z", "finishedAt": "2021-09-08T08:31:12.304168Z" }], "limit": 20, "from": 0, "next": null }) | ||||
|         json!({ "results": [{"uid": 0, "indexUid": "indexUID", "status": "succeeded", "type": "documentAdditionOrUpdate", "canceledBy": null, "details": { "receivedDocuments": 0, "indexedDocuments": 31944 }, "error": null, "duration": "PT41.751156S", "enqueuedAt": "2021-09-08T08:30:30.550282Z", "startedAt": "2021-09-08T08:30:30.553012Z", "finishedAt": "2021-09-08T08:31:12.304168Z" }], "total": 1, "limit": 20, "from": 0, "next": null }) | ||||
|     ); | ||||
|  | ||||
|     // finally we're just going to check that we can still get a few documents by id | ||||
| @@ -667,7 +667,7 @@ async fn import_dump_v2_movie_with_settings() { | ||||
|     snapshot!(code, @"200 OK"); | ||||
|     assert_eq!( | ||||
|         tasks, | ||||
|         json!({ "results": [{ "uid": 1, "indexUid": "indexUID", "status": "succeeded", "type": "settingsUpdate", "canceledBy": null, "details": { "displayedAttributes": ["title", "genres", "overview", "poster", "release_date"], "searchableAttributes": ["title", "overview"], "filterableAttributes": ["genres"], "stopWords": ["of", "the"] }, "error": null, "duration": "PT37.488777S", "enqueuedAt": "2021-09-08T08:24:02.323444Z", "startedAt": "2021-09-08T08:24:02.324145Z", "finishedAt": "2021-09-08T08:24:39.812922Z" }, { "uid": 0, "indexUid": "indexUID", "status": "succeeded", "type": "documentAdditionOrUpdate", "canceledBy": null, "details": { "receivedDocuments": 0, "indexedDocuments": 31944 }, "error": null, "duration": "PT39.941318S", "enqueuedAt": "2021-09-08T08:21:14.742672Z", "startedAt": "2021-09-08T08:21:14.750166Z", "finishedAt": "2021-09-08T08:21:54.691484Z" }], "limit": 20, "from": 1, "next": null }) | ||||
|         json!({ "results": [{ "uid": 1, "indexUid": "indexUID", "status": "succeeded", "type": "settingsUpdate", "canceledBy": null, "details": { "displayedAttributes": ["title", "genres", "overview", "poster", "release_date"], "searchableAttributes": ["title", "overview"], "filterableAttributes": ["genres"], "stopWords": ["of", "the"] }, "error": null, "duration": "PT37.488777S", "enqueuedAt": "2021-09-08T08:24:02.323444Z", "startedAt": "2021-09-08T08:24:02.324145Z", "finishedAt": "2021-09-08T08:24:39.812922Z" }, { "uid": 0, "indexUid": "indexUID", "status": "succeeded", "type": "documentAdditionOrUpdate", "canceledBy": null, "details": { "receivedDocuments": 0, "indexedDocuments": 31944 }, "error": null, "duration": "PT39.941318S", "enqueuedAt": "2021-09-08T08:21:14.742672Z", "startedAt": "2021-09-08T08:21:14.750166Z", "finishedAt": "2021-09-08T08:21:54.691484Z" }], "total": 2, "limit": 20, "from": 1, "next": null }) | ||||
|     ); | ||||
|  | ||||
|     // finally we're just going to check that we can still get a few documents by id | ||||
| @@ -942,7 +942,7 @@ async fn import_dump_v3_movie_raw() { | ||||
|     snapshot!(code, @"200 OK"); | ||||
|     assert_eq!( | ||||
|         tasks, | ||||
|         json!({ "results": [{"uid": 0, "indexUid": "indexUID", "status": "succeeded", "type": "documentAdditionOrUpdate", "canceledBy": null, "details": { "receivedDocuments": 0, "indexedDocuments": 31944 }, "error": null, "duration": "PT41.751156S", "enqueuedAt": "2021-09-08T08:30:30.550282Z", "startedAt": "2021-09-08T08:30:30.553012Z", "finishedAt": "2021-09-08T08:31:12.304168Z" }], "limit": 20, "from": 0, "next": null }) | ||||
|         json!({ "results": [{"uid": 0, "indexUid": "indexUID", "status": "succeeded", "type": "documentAdditionOrUpdate", "canceledBy": null, "details": { "receivedDocuments": 0, "indexedDocuments": 31944 }, "error": null, "duration": "PT41.751156S", "enqueuedAt": "2021-09-08T08:30:30.550282Z", "startedAt": "2021-09-08T08:30:30.553012Z", "finishedAt": "2021-09-08T08:31:12.304168Z" }], "total": 1, "limit": 20, "from": 0, "next": null }) | ||||
|     ); | ||||
|  | ||||
|     // finally we're just going to check that we can still get a few documents by id | ||||
| @@ -1086,7 +1086,7 @@ async fn import_dump_v3_movie_with_settings() { | ||||
|     snapshot!(code, @"200 OK"); | ||||
|     assert_eq!( | ||||
|         tasks, | ||||
|         json!({ "results": [{ "uid": 1, "indexUid": "indexUID", "status": "succeeded", "type": "settingsUpdate", "canceledBy": null, "details": { "displayedAttributes": ["title", "genres", "overview", "poster", "release_date"], "searchableAttributes": ["title", "overview"], "filterableAttributes": ["genres"], "stopWords": ["of", "the"] }, "error": null, "duration": "PT37.488777S", "enqueuedAt": "2021-09-08T08:24:02.323444Z", "startedAt": "2021-09-08T08:24:02.324145Z", "finishedAt": "2021-09-08T08:24:39.812922Z" }, { "uid": 0, "indexUid": "indexUID", "status": "succeeded", "type": "documentAdditionOrUpdate", "canceledBy": null, "details": { "receivedDocuments": 0, "indexedDocuments": 31944 }, "error": null, "duration": "PT39.941318S", "enqueuedAt": "2021-09-08T08:21:14.742672Z", "startedAt": "2021-09-08T08:21:14.750166Z", "finishedAt": "2021-09-08T08:21:54.691484Z" }], "limit": 20, "from": 1, "next": null }) | ||||
|         json!({ "results": [{ "uid": 1, "indexUid": "indexUID", "status": "succeeded", "type": "settingsUpdate", "canceledBy": null, "details": { "displayedAttributes": ["title", "genres", "overview", "poster", "release_date"], "searchableAttributes": ["title", "overview"], "filterableAttributes": ["genres"], "stopWords": ["of", "the"] }, "error": null, "duration": "PT37.488777S", "enqueuedAt": "2021-09-08T08:24:02.323444Z", "startedAt": "2021-09-08T08:24:02.324145Z", "finishedAt": "2021-09-08T08:24:39.812922Z" }, { "uid": 0, "indexUid": "indexUID", "status": "succeeded", "type": "documentAdditionOrUpdate", "canceledBy": null, "details": { "receivedDocuments": 0, "indexedDocuments": 31944 }, "error": null, "duration": "PT39.941318S", "enqueuedAt": "2021-09-08T08:21:14.742672Z", "startedAt": "2021-09-08T08:21:14.750166Z", "finishedAt": "2021-09-08T08:21:54.691484Z" }], "total": 2, "limit": 20, "from": 1, "next": null }) | ||||
|     ); | ||||
|  | ||||
|     // finally we're just going to check that we can["results"] still get a few documents by id | ||||
| @@ -1361,7 +1361,7 @@ async fn import_dump_v4_movie_raw() { | ||||
|     snapshot!(code, @"200 OK"); | ||||
|     assert_eq!( | ||||
|         tasks, | ||||
|         json!({ "results": [{"uid": 0, "indexUid": "indexUID", "status": "succeeded", "type": "documentAdditionOrUpdate", "canceledBy": null, "details": { "receivedDocuments": 0, "indexedDocuments": 31944 }, "error": null, "duration": "PT41.751156S", "enqueuedAt": "2021-09-08T08:30:30.550282Z", "startedAt": "2021-09-08T08:30:30.553012Z", "finishedAt": "2021-09-08T08:31:12.304168Z" }], "limit" : 20, "from": 0, "next": null }) | ||||
|         json!({ "results": [{"uid": 0, "indexUid": "indexUID", "status": "succeeded", "type": "documentAdditionOrUpdate", "canceledBy": null, "details": { "receivedDocuments": 0, "indexedDocuments": 31944 }, "error": null, "duration": "PT41.751156S", "enqueuedAt": "2021-09-08T08:30:30.550282Z", "startedAt": "2021-09-08T08:30:30.553012Z", "finishedAt": "2021-09-08T08:31:12.304168Z" }], "total": 1, "limit" : 20, "from": 0, "next": null }) | ||||
|     ); | ||||
|  | ||||
|     // finally we're just going to check that we can still get a few documents by id | ||||
| @@ -1505,7 +1505,7 @@ async fn import_dump_v4_movie_with_settings() { | ||||
|     snapshot!(code, @"200 OK"); | ||||
|     assert_eq!( | ||||
|         tasks, | ||||
|         json!({ "results": [{ "uid": 1, "indexUid": "indexUID", "status": "succeeded", "type": "settingsUpdate", "canceledBy": null, "details": { "displayedAttributes": ["title", "genres", "overview", "poster", "release_date"], "searchableAttributes": ["title", "overview"], "filterableAttributes": ["genres"], "stopWords": ["of", "the"] }, "error": null, "duration": "PT37.488777S", "enqueuedAt": "2021-09-08T08:24:02.323444Z", "startedAt": "2021-09-08T08:24:02.324145Z", "finishedAt": "2021-09-08T08:24:39.812922Z" }, { "uid": 0, "indexUid": "indexUID", "status": "succeeded", "type": "documentAdditionOrUpdate", "canceledBy": null, "details": { "receivedDocuments": 0, "indexedDocuments": 31944 }, "error": null, "duration": "PT39.941318S", "enqueuedAt": "2021-09-08T08:21:14.742672Z", "startedAt": "2021-09-08T08:21:14.750166Z", "finishedAt": "2021-09-08T08:21:54.691484Z" }], "limit": 20, "from": 1, "next": null }) | ||||
|         json!({ "results": [{ "uid": 1, "indexUid": "indexUID", "status": "succeeded", "type": "settingsUpdate", "canceledBy": null, "details": { "displayedAttributes": ["title", "genres", "overview", "poster", "release_date"], "searchableAttributes": ["title", "overview"], "filterableAttributes": ["genres"], "stopWords": ["of", "the"] }, "error": null, "duration": "PT37.488777S", "enqueuedAt": "2021-09-08T08:24:02.323444Z", "startedAt": "2021-09-08T08:24:02.324145Z", "finishedAt": "2021-09-08T08:24:39.812922Z" }, { "uid": 0, "indexUid": "indexUID", "status": "succeeded", "type": "documentAdditionOrUpdate", "canceledBy": null, "details": { "receivedDocuments": 0, "indexedDocuments": 31944 }, "error": null, "duration": "PT39.941318S", "enqueuedAt": "2021-09-08T08:21:14.742672Z", "startedAt": "2021-09-08T08:21:14.750166Z", "finishedAt": "2021-09-08T08:21:54.691484Z" }], "total": 2, "limit": 20, "from": 1, "next": null }) | ||||
|     ); | ||||
|  | ||||
|     // finally we're just going to check that we can still get a few documents by id | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T09:08:54.713227Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 1, | ||||
|   "limit": 1, | ||||
|   "from": 0, | ||||
|   "next": null | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T09:08:54.713227Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 1, | ||||
|   "limit": 1, | ||||
|   "from": 0, | ||||
|   "next": null | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T09:08:54.713227Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 1, | ||||
|   "limit": 1, | ||||
|   "from": 0, | ||||
|   "next": null | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T09:08:54.713227Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 1, | ||||
|   "limit": 1, | ||||
|   "from": 0, | ||||
|   "next": null | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T09:08:54.713227Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 1, | ||||
|   "limit": 1, | ||||
|   "from": 0, | ||||
|   "next": null | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T09:08:54.713227Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 1, | ||||
|   "limit": 1, | ||||
|   "from": 0, | ||||
|   "next": null | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T09:08:54.713227Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 1, | ||||
|   "limit": 1, | ||||
|   "from": 0, | ||||
|   "next": null | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T09:34:25.351927Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 1, | ||||
|   "limit": 1, | ||||
|   "from": 0, | ||||
|   "next": null | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T09:34:25.351927Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 1, | ||||
|   "limit": 1, | ||||
|   "from": 0, | ||||
|   "next": null | ||||
|   | ||||
| @@ -40,6 +40,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T09:34:48.1719Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 2, | ||||
|   "limit": 1, | ||||
|   "from": 1, | ||||
|   "next": 0 | ||||
|   | ||||
| @@ -40,6 +40,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T09:34:48.1719Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 2, | ||||
|   "limit": 1, | ||||
|   "from": 1, | ||||
|   "next": 0 | ||||
|   | ||||
| @@ -40,6 +40,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T09:34:48.1719Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 2, | ||||
|   "limit": 1, | ||||
|   "from": 1, | ||||
|   "next": 0 | ||||
|   | ||||
| @@ -40,6 +40,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T09:34:48.1719Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 2, | ||||
|   "limit": 1, | ||||
|   "from": 1, | ||||
|   "next": 0 | ||||
|   | ||||
| @@ -40,6 +40,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T09:34:48.1719Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 2, | ||||
|   "limit": 1, | ||||
|   "from": 1, | ||||
|   "next": 0 | ||||
|   | ||||
| @@ -45,6 +45,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T09:26:57.319083Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 1, | ||||
|   "limit": 1, | ||||
|   "from": 0, | ||||
|   "next": null | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T09:28:46.369971Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 92, | ||||
|   "limit": 1, | ||||
|   "from": 92, | ||||
|   "next": 91 | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T09:28:46.369971Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 93, | ||||
|   "limit": 1, | ||||
|   "from": 92, | ||||
|   "next": 91 | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T09:28:46.369971Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 93, | ||||
|   "limit": 1, | ||||
|   "from": 92, | ||||
|   "next": 91 | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T09:28:46.369971Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 93, | ||||
|   "limit": 1, | ||||
|   "from": 92, | ||||
|   "next": 91 | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T09:28:46.369971Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 93, | ||||
|   "limit": 1, | ||||
|   "from": 92, | ||||
|   "next": 91 | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T09:28:46.369971Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 93, | ||||
|   "limit": 1, | ||||
|   "from": 92, | ||||
|   "next": 91 | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:31:12.304168Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 1, | ||||
|   "limit": 1, | ||||
|   "from": 0, | ||||
|   "next": null | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:31:12.304168Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 1, | ||||
|   "limit": 1, | ||||
|   "from": 0, | ||||
|   "next": null | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:31:12.304168Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 1, | ||||
|   "limit": 1, | ||||
|   "from": 0, | ||||
|   "next": null | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:31:12.304168Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 1, | ||||
|   "limit": 1, | ||||
|   "from": 0, | ||||
|   "next": null | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:31:12.304168Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 1, | ||||
|   "limit": 1, | ||||
|   "from": 0, | ||||
|   "next": null | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:31:12.304168Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 1, | ||||
|   "limit": 1, | ||||
|   "from": 0, | ||||
|   "next": null | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:31:12.304168Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 1, | ||||
|   "limit": 1, | ||||
|   "from": 0, | ||||
|   "next": null | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:21:54.691484Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 1, | ||||
|   "limit": 1, | ||||
|   "from": 0, | ||||
|   "next": null | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:21:54.691484Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 1, | ||||
|   "limit": 1, | ||||
|   "from": 0, | ||||
|   "next": null | ||||
|   | ||||
| @@ -36,6 +36,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:24:39.812922Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 2, | ||||
|   "limit": 1, | ||||
|   "from": 1, | ||||
|   "next": 0 | ||||
|   | ||||
| @@ -36,6 +36,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:24:39.812922Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 2, | ||||
|   "limit": 1, | ||||
|   "from": 1, | ||||
|   "next": 0 | ||||
|   | ||||
| @@ -36,6 +36,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:24:39.812922Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 2, | ||||
|   "limit": 1, | ||||
|   "from": 1, | ||||
|   "next": 0 | ||||
|   | ||||
| @@ -36,6 +36,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:24:39.812922Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 2, | ||||
|   "limit": 1, | ||||
|   "from": 1, | ||||
|   "next": 0 | ||||
|   | ||||
| @@ -36,6 +36,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:24:39.812922Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 2, | ||||
|   "limit": 1, | ||||
|   "from": 1, | ||||
|   "next": 0 | ||||
|   | ||||
| @@ -41,6 +41,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:40:28.669652Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 1, | ||||
|   "limit": 1, | ||||
|   "from": 0, | ||||
|   "next": null | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:51:53.095314Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 92, | ||||
|   "limit": 1, | ||||
|   "from": 92, | ||||
|   "next": 91 | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:51:53.095314Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 93, | ||||
|   "limit": 1, | ||||
|   "from": 92, | ||||
|   "next": 91 | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:51:53.095314Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 93, | ||||
|   "limit": 1, | ||||
|   "from": 92, | ||||
|   "next": 91 | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:51:53.095314Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 93, | ||||
|   "limit": 1, | ||||
|   "from": 92, | ||||
|   "next": 91 | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:51:53.095314Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 93, | ||||
|   "limit": 1, | ||||
|   "from": 92, | ||||
|   "next": 91 | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:51:53.095314Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 93, | ||||
|   "limit": 1, | ||||
|   "from": 92, | ||||
|   "next": 91 | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:31:12.304168Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 1, | ||||
|   "limit": 1, | ||||
|   "from": 0, | ||||
|   "next": null | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:31:12.304168Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 1, | ||||
|   "limit": 1, | ||||
|   "from": 0, | ||||
|   "next": null | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:31:12.304168Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 1, | ||||
|   "limit": 1, | ||||
|   "from": 0, | ||||
|   "next": null | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:31:12.304168Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 1, | ||||
|   "limit": 1, | ||||
|   "from": 0, | ||||
|   "next": null | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:31:12.304168Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 1, | ||||
|   "limit": 1, | ||||
|   "from": 0, | ||||
|   "next": null | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:31:12.304168Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 1, | ||||
|   "limit": 1, | ||||
|   "from": 0, | ||||
|   "next": null | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:31:12.304168Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 1, | ||||
|   "limit": 1, | ||||
|   "from": 0, | ||||
|   "next": null | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:21:54.691484Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 1, | ||||
|   "limit": 1, | ||||
|   "from": 0, | ||||
|   "next": null | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:21:54.691484Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 1, | ||||
|   "limit": 1, | ||||
|   "from": 0, | ||||
|   "next": null | ||||
|   | ||||
| @@ -36,6 +36,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:24:39.812922Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 2, | ||||
|   "limit": 1, | ||||
|   "from": 1, | ||||
|   "next": 0 | ||||
|   | ||||
| @@ -36,6 +36,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:24:39.812922Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 2, | ||||
|   "limit": 1, | ||||
|   "from": 1, | ||||
|   "next": 0 | ||||
|   | ||||
| @@ -36,6 +36,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:24:39.812922Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 2, | ||||
|   "limit": 1, | ||||
|   "from": 1, | ||||
|   "next": 0 | ||||
|   | ||||
| @@ -36,6 +36,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:24:39.812922Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 2, | ||||
|   "limit": 1, | ||||
|   "from": 1, | ||||
|   "next": 0 | ||||
|   | ||||
| @@ -36,6 +36,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:24:39.812922Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 2, | ||||
|   "limit": 1, | ||||
|   "from": 1, | ||||
|   "next": 0 | ||||
|   | ||||
| @@ -41,6 +41,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:40:28.669652Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 1, | ||||
|   "limit": 1, | ||||
|   "from": 0, | ||||
|   "next": null | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:51:53.095314Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 92, | ||||
|   "limit": 1, | ||||
|   "from": 92, | ||||
|   "next": 91 | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:51:53.095314Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 93, | ||||
|   "limit": 1, | ||||
|   "from": 92, | ||||
|   "next": 91 | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:51:53.095314Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 93, | ||||
|   "limit": 1, | ||||
|   "from": 92, | ||||
|   "next": 91 | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:51:53.095314Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 93, | ||||
|   "limit": 1, | ||||
|   "from": 92, | ||||
|   "next": 91 | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:51:53.095314Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 93, | ||||
|   "limit": 1, | ||||
|   "from": 92, | ||||
|   "next": 91 | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:51:53.095314Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 93, | ||||
|   "limit": 1, | ||||
|   "from": 92, | ||||
|   "next": 91 | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:31:12.304168Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 1, | ||||
|   "limit": 1, | ||||
|   "from": 0, | ||||
|   "next": null | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:31:12.304168Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 1, | ||||
|   "limit": 1, | ||||
|   "from": 0, | ||||
|   "next": null | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:31:12.304168Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 1, | ||||
|   "limit": 1, | ||||
|   "from": 0, | ||||
|   "next": null | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:31:12.304168Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 1, | ||||
|   "limit": 1, | ||||
|   "from": 0, | ||||
|   "next": null | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:31:12.304168Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 1, | ||||
|   "limit": 1, | ||||
|   "from": 0, | ||||
|   "next": null | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:31:12.304168Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 1, | ||||
|   "limit": 1, | ||||
|   "from": 0, | ||||
|   "next": null | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:31:12.304168Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 1, | ||||
|   "limit": 1, | ||||
|   "from": 0, | ||||
|   "next": null | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:21:54.691484Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 1, | ||||
|   "limit": 1, | ||||
|   "from": 0, | ||||
|   "next": null | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:21:54.691484Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 1, | ||||
|   "limit": 1, | ||||
|   "from": 0, | ||||
|   "next": null | ||||
|   | ||||
| @@ -36,6 +36,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:24:39.812922Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 2, | ||||
|   "limit": 1, | ||||
|   "from": 1, | ||||
|   "next": 0 | ||||
|   | ||||
| @@ -36,6 +36,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:24:39.812922Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 2, | ||||
|   "limit": 1, | ||||
|   "from": 1, | ||||
|   "next": 0 | ||||
|   | ||||
| @@ -36,6 +36,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:24:39.812922Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 2, | ||||
|   "limit": 1, | ||||
|   "from": 1, | ||||
|   "next": 0 | ||||
|   | ||||
| @@ -36,6 +36,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:24:39.812922Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 2, | ||||
|   "limit": 1, | ||||
|   "from": 1, | ||||
|   "next": 0 | ||||
|   | ||||
| @@ -36,6 +36,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:24:39.812922Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 2, | ||||
|   "limit": 1, | ||||
|   "from": 1, | ||||
|   "next": 0 | ||||
|   | ||||
| @@ -41,6 +41,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:40:28.669652Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 1, | ||||
|   "limit": 1, | ||||
|   "from": 0, | ||||
|   "next": null | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:51:53.095314Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 92, | ||||
|   "limit": 1, | ||||
|   "from": 92, | ||||
|   "next": 91 | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:51:53.095314Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 93, | ||||
|   "limit": 1, | ||||
|   "from": 92, | ||||
|   "next": 91 | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:51:53.095314Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 93, | ||||
|   "limit": 1, | ||||
|   "from": 92, | ||||
|   "next": 91 | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:51:53.095314Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 93, | ||||
|   "limit": 1, | ||||
|   "from": 92, | ||||
|   "next": 91 | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:51:53.095314Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 93, | ||||
|   "limit": 1, | ||||
|   "from": 92, | ||||
|   "next": 91 | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2021-09-08T08:51:53.095314Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 93, | ||||
|   "limit": 1, | ||||
|   "from": 92, | ||||
|   "next": 91 | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2022-06-08T14:59:24.804443Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 1, | ||||
|   "limit": 1, | ||||
|   "from": 0, | ||||
|   "next": null | ||||
|   | ||||
| @@ -20,6 +20,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "2022-06-08T14:59:29.997781Z" | ||||
|     } | ||||
|   ], | ||||
|   "total": 2, | ||||
|   "limit": 1, | ||||
|   "from": 1, | ||||
|   "next": 0 | ||||
|   | ||||
| @@ -19,6 +19,7 @@ source: meilisearch/tests/dumps/mod.rs | ||||
|       "finishedAt": "[date]" | ||||
|     } | ||||
|   ], | ||||
|   "total": 5, | ||||
|   "limit": 1, | ||||
|   "from": 4, | ||||
|   "next": 3 | ||||
|   | ||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user