mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-25 13:06:27 +00:00 
			
		
		
		
	refactor the tests suite slightly
This commit is contained in:
		| @@ -1,8 +1,7 @@ | |||||||
| use std::{thread, time}; | use std::{thread, time}; | ||||||
|  |  | ||||||
| use serde_json::{json, Value}; | use crate::common::{Server, Value}; | ||||||
|  | use crate::json; | ||||||
| use crate::common::Server; |  | ||||||
|  |  | ||||||
| #[actix_rt::test] | #[actix_rt::test] | ||||||
| async fn add_valid_api_key() { | async fn add_valid_api_key() { | ||||||
| @@ -162,7 +161,7 @@ async fn add_valid_api_key_null_description() { | |||||||
|     server.use_api_key("MASTER_KEY"); |     server.use_api_key("MASTER_KEY"); | ||||||
|  |  | ||||||
|     let content = json!({ |     let content = json!({ | ||||||
|         "description": Value::Null, |         "description": json!(null), | ||||||
|         "indexes": ["products"], |         "indexes": ["products"], | ||||||
|         "actions": ["documents.add"], |         "actions": ["documents.add"], | ||||||
|         "expiresAt": "2050-11-13T00:00:00" |         "expiresAt": "2050-11-13T00:00:00" | ||||||
| @@ -365,7 +364,7 @@ async fn error_add_api_key_invalid_index_uids() { | |||||||
|     server.use_api_key("MASTER_KEY"); |     server.use_api_key("MASTER_KEY"); | ||||||
|  |  | ||||||
|     let content = json!({ |     let content = json!({ | ||||||
|         "description": Value::Null, |         "description": json!(null), | ||||||
|         "indexes": ["invalid index # / \\name with spaces"], |         "indexes": ["invalid index # / \\name with spaces"], | ||||||
|         "actions": [ |         "actions": [ | ||||||
|             "documents.add" |             "documents.add" | ||||||
| @@ -507,7 +506,7 @@ async fn error_add_api_key_invalid_parameters_uid() { | |||||||
| async fn error_add_api_key_parameters_uid_already_exist() { | async fn error_add_api_key_parameters_uid_already_exist() { | ||||||
|     let mut server = Server::new_auth().await; |     let mut server = Server::new_auth().await; | ||||||
|     server.use_api_key("MASTER_KEY"); |     server.use_api_key("MASTER_KEY"); | ||||||
|     let content = json!({ |     let content: Value = json!({ | ||||||
|         "uid": "4bc0887a-0e41-4f3b-935d-0c451dcee9c8", |         "uid": "4bc0887a-0e41-4f3b-935d-0c451dcee9c8", | ||||||
|         "indexes": ["products"], |         "indexes": ["products"], | ||||||
|         "actions": ["search"], |         "actions": ["search"], | ||||||
| @@ -1146,7 +1145,7 @@ async fn patch_api_key_description() { | |||||||
|     meili_snap::snapshot!(code, @"200 OK"); |     meili_snap::snapshot!(code, @"200 OK"); | ||||||
|  |  | ||||||
|     // Remove the description |     // Remove the description | ||||||
|     let content = json!({ "description": serde_json::Value::Null }); |     let content = json!({ "description": null }); | ||||||
|  |  | ||||||
|     let (response, code) = server.patch_api_key(&uid, content).await; |     let (response, code) = server.patch_api_key(&uid, content).await; | ||||||
|     meili_snap::snapshot!(meili_snap::json_string!(response, { ".createdAt" => "[ignored]", ".updatedAt" => "[ignored]", ".uid" => "[ignored]", ".key" => "[ignored]" }), @r###" |     meili_snap::snapshot!(meili_snap::json_string!(response, { ".createdAt" => "[ignored]", ".updatedAt" => "[ignored]", ".uid" => "[ignored]", ".key" => "[ignored]" }), @r###" | ||||||
|   | |||||||
| @@ -3,10 +3,10 @@ use std::collections::{HashMap, HashSet}; | |||||||
| use ::time::format_description::well_known::Rfc3339; | use ::time::format_description::well_known::Rfc3339; | ||||||
| use maplit::{hashmap, hashset}; | use maplit::{hashmap, hashset}; | ||||||
| use once_cell::sync::Lazy; | use once_cell::sync::Lazy; | ||||||
| use serde_json::{json, Value}; |  | ||||||
| use time::{Duration, OffsetDateTime}; | use time::{Duration, OffsetDateTime}; | ||||||
|  |  | ||||||
| use crate::common::Server; | use crate::common::{Server, Value}; | ||||||
|  | use crate::json; | ||||||
|  |  | ||||||
| pub static AUTHORIZATIONS: Lazy<HashMap<(&'static str, &'static str), HashSet<&'static str>>> = | pub static AUTHORIZATIONS: Lazy<HashMap<(&'static str, &'static str), HashSet<&'static str>>> = | ||||||
|     Lazy::new(|| { |     Lazy::new(|| { | ||||||
|   | |||||||
| @@ -1,8 +1,8 @@ | |||||||
| use meili_snap::*; | use meili_snap::*; | ||||||
| use serde_json::json; |  | ||||||
| use uuid::Uuid; | use uuid::Uuid; | ||||||
|  |  | ||||||
| use crate::common::Server; | use crate::common::Server; | ||||||
|  | use crate::json; | ||||||
|  |  | ||||||
| #[actix_rt::test] | #[actix_rt::test] | ||||||
| async fn create_api_key_bad_description() { | async fn create_api_key_bad_description() { | ||||||
|   | |||||||
| @@ -7,9 +7,9 @@ mod tenant_token; | |||||||
| mod tenant_token_multi_search; | mod tenant_token_multi_search; | ||||||
|  |  | ||||||
| use actix_web::http::StatusCode; | use actix_web::http::StatusCode; | ||||||
| use serde_json::{json, Value}; |  | ||||||
|  |  | ||||||
| use crate::common::Server; | use crate::common::{Server, Value}; | ||||||
|  | use crate::json; | ||||||
|  |  | ||||||
| impl Server { | impl Server { | ||||||
|     pub fn use_api_key(&mut self, api_key: impl AsRef<str>) { |     pub fn use_api_key(&mut self, api_key: impl AsRef<str>) { | ||||||
|   | |||||||
| @@ -3,11 +3,11 @@ use std::collections::HashMap; | |||||||
| use ::time::format_description::well_known::Rfc3339; | use ::time::format_description::well_known::Rfc3339; | ||||||
| use maplit::hashmap; | use maplit::hashmap; | ||||||
| use once_cell::sync::Lazy; | use once_cell::sync::Lazy; | ||||||
| use serde_json::{json, Value}; |  | ||||||
| use time::{Duration, OffsetDateTime}; | use time::{Duration, OffsetDateTime}; | ||||||
|  |  | ||||||
| use super::authorization::{ALL_ACTIONS, AUTHORIZATIONS}; | use super::authorization::{ALL_ACTIONS, AUTHORIZATIONS}; | ||||||
| use crate::common::Server; | use crate::common::{Server, Value}; | ||||||
|  | use crate::json; | ||||||
|  |  | ||||||
| fn generate_tenant_token( | fn generate_tenant_token( | ||||||
|     parent_uid: impl AsRef<str>, |     parent_uid: impl AsRef<str>, | ||||||
| @@ -233,31 +233,31 @@ async fn search_authorized_simple_token() { | |||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
|             "searchRules" => json!({"*": {}}), |             "searchRules" => json!({"*": {}}), | ||||||
|             "exp" => Value::Null |             "exp" => json!(null) | ||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
|             "searchRules" => json!({"*": Value::Null}), |             "searchRules" => json!({"*": null}), | ||||||
|             "exp" => Value::Null |             "exp" => json!(null) | ||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
|             "searchRules" => json!(["*"]), |             "searchRules" => json!(["*"]), | ||||||
|             "exp" => Value::Null |             "exp" => json!(null) | ||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
|             "searchRules" => json!({"sales": {}}), |             "searchRules" => json!({"sales": {}}), | ||||||
|             "exp" => Value::Null |             "exp" => json!(null) | ||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
|             "searchRules" => json!({"sales": Value::Null}), |             "searchRules" => json!({"sales": null}), | ||||||
|             "exp" => Value::Null |             "exp" => json!(null) | ||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
|             "searchRules" => json!(["sales"]), |             "searchRules" => json!(["sales"]), | ||||||
|             "exp" => Value::Null |             "exp" => json!(null) | ||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
|             "searchRules" => json!(["sa*"]), |             "searchRules" => json!(["sa*"]), | ||||||
|             "exp" => Value::Null |             "exp" => json!(null) | ||||||
|         }, |         }, | ||||||
|     ]; |     ]; | ||||||
|  |  | ||||||
| @@ -386,7 +386,7 @@ async fn error_search_token_forbidden_parent_key() { | |||||||
|             "exp" => json!((OffsetDateTime::now_utc() + Duration::hours(1)).unix_timestamp()) |             "exp" => json!((OffsetDateTime::now_utc() + Duration::hours(1)).unix_timestamp()) | ||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
|             "searchRules" => json!({"*": Value::Null}), |             "searchRules" => json!({"*": null}), | ||||||
|             "exp" => json!((OffsetDateTime::now_utc() + Duration::hours(1)).unix_timestamp()) |             "exp" => json!((OffsetDateTime::now_utc() + Duration::hours(1)).unix_timestamp()) | ||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
| @@ -398,7 +398,7 @@ async fn error_search_token_forbidden_parent_key() { | |||||||
|             "exp" => json!((OffsetDateTime::now_utc() + Duration::hours(1)).unix_timestamp()) |             "exp" => json!((OffsetDateTime::now_utc() + Duration::hours(1)).unix_timestamp()) | ||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
|             "searchRules" => json!({"sales": Value::Null}), |             "searchRules" => json!({"sales": null}), | ||||||
|             "exp" => json!((OffsetDateTime::now_utc() + Duration::hours(1)).unix_timestamp()) |             "exp" => json!((OffsetDateTime::now_utc() + Duration::hours(1)).unix_timestamp()) | ||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
| @@ -428,15 +428,15 @@ async fn error_search_forbidden_token() { | |||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
|             "searchRules" => json!({"products": {}}), |             "searchRules" => json!({"products": {}}), | ||||||
|             "exp" => Value::Null |             "exp" => json!(null) | ||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
|             "searchRules" => json!({"products": Value::Null}), |             "searchRules" => json!({"products": null}), | ||||||
|             "exp" => Value::Null |             "exp" => json!(null) | ||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
|             "searchRules" => json!(["products"]), |             "searchRules" => json!(["products"]), | ||||||
|             "exp" => Value::Null |             "exp" => json!(null) | ||||||
|         }, |         }, | ||||||
|         // expired token |         // expired token | ||||||
|         hashmap! { |         hashmap! { | ||||||
| @@ -444,7 +444,7 @@ async fn error_search_forbidden_token() { | |||||||
|             "exp" => json!((OffsetDateTime::now_utc() - Duration::hours(1)).unix_timestamp()) |             "exp" => json!((OffsetDateTime::now_utc() - Duration::hours(1)).unix_timestamp()) | ||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
|             "searchRules" => json!({"*": Value::Null}), |             "searchRules" => json!({"*": null}), | ||||||
|             "exp" => json!((OffsetDateTime::now_utc() - Duration::hours(1)).unix_timestamp()) |             "exp" => json!((OffsetDateTime::now_utc() - Duration::hours(1)).unix_timestamp()) | ||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
| @@ -456,7 +456,7 @@ async fn error_search_forbidden_token() { | |||||||
|             "exp" => json!((OffsetDateTime::now_utc() - Duration::hours(1)).unix_timestamp()) |             "exp" => json!((OffsetDateTime::now_utc() - Duration::hours(1)).unix_timestamp()) | ||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
|             "searchRules" => json!({"sales": Value::Null}), |             "searchRules" => json!({"sales": null}), | ||||||
|             "exp" => json!((OffsetDateTime::now_utc() - Duration::hours(1)).unix_timestamp()) |             "exp" => json!((OffsetDateTime::now_utc() - Duration::hours(1)).unix_timestamp()) | ||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
|   | |||||||
| @@ -3,11 +3,11 @@ use std::collections::HashMap; | |||||||
| use ::time::format_description::well_known::Rfc3339; | use ::time::format_description::well_known::Rfc3339; | ||||||
| use maplit::hashmap; | use maplit::hashmap; | ||||||
| use once_cell::sync::Lazy; | use once_cell::sync::Lazy; | ||||||
| use serde_json::{json, Value}; |  | ||||||
| use time::{Duration, OffsetDateTime}; | use time::{Duration, OffsetDateTime}; | ||||||
|  |  | ||||||
| use super::authorization::ALL_ACTIONS; | use super::authorization::ALL_ACTIONS; | ||||||
| use crate::common::Server; | use crate::common::{Server, Value}; | ||||||
|  | use crate::json; | ||||||
|  |  | ||||||
| fn generate_tenant_token( | fn generate_tenant_token( | ||||||
|     parent_uid: impl AsRef<str>, |     parent_uid: impl AsRef<str>, | ||||||
| @@ -512,31 +512,31 @@ async fn single_search_authorized_simple_token() { | |||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
|             "searchRules" => json!({"*": {}}), |             "searchRules" => json!({"*": {}}), | ||||||
|             "exp" => Value::Null |             "exp" => json!(null), | ||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
|             "searchRules" => json!({"*": Value::Null}), |             "searchRules" => json!({"*": null}), | ||||||
|             "exp" => Value::Null |             "exp" => json!(null), | ||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
|             "searchRules" => json!(["*"]), |             "searchRules" => json!(["*"]), | ||||||
|             "exp" => Value::Null |             "exp" => json!(null), | ||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
|             "searchRules" => json!({"sales": {}}), |             "searchRules" => json!({"sales": {}}), | ||||||
|             "exp" => Value::Null |             "exp" => json!(null), | ||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
|             "searchRules" => json!({"sales": Value::Null}), |             "searchRules" => json!({"sales": null}), | ||||||
|             "exp" => Value::Null |             "exp" => json!(null), | ||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
|             "searchRules" => json!(["sales"]), |             "searchRules" => json!(["sales"]), | ||||||
|             "exp" => Value::Null |             "exp" => json!(null), | ||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
|             "searchRules" => json!(["sa*"]), |             "searchRules" => json!(["sa*"]), | ||||||
|             "exp" => Value::Null |             "exp" => json!(null), | ||||||
|         }, |         }, | ||||||
|     ]; |     ]; | ||||||
|  |  | ||||||
| @@ -564,31 +564,31 @@ async fn multi_search_authorized_simple_token() { | |||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
|             "searchRules" => json!({"*": {}}), |             "searchRules" => json!({"*": {}}), | ||||||
|             "exp" => Value::Null |             "exp" => json!(null), | ||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
|             "searchRules" => json!({"*": Value::Null}), |             "searchRules" => json!({"*": null}), | ||||||
|             "exp" => Value::Null |             "exp" => json!(null), | ||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
|             "searchRules" => json!(["*"]), |             "searchRules" => json!(["*"]), | ||||||
|             "exp" => Value::Null |             "exp" => json!(null), | ||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
|             "searchRules" => json!({"sales": {}, "products": {}}), |             "searchRules" => json!({"sales": {}, "products": {}}), | ||||||
|             "exp" => Value::Null |             "exp" => json!(null), | ||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
|             "searchRules" => json!({"sales": Value::Null, "products": Value::Null}), |             "searchRules" => json!({"sales": null, "products": null}), | ||||||
|             "exp" => Value::Null |             "exp" => json!(null), | ||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
|             "searchRules" => json!(["sales", "products"]), |             "searchRules" => json!(["sales", "products"]), | ||||||
|             "exp" => Value::Null |             "exp" => json!(null), | ||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
|             "searchRules" => json!(["sa*", "pro*"]), |             "searchRules" => json!(["sa*", "pro*"]), | ||||||
|             "exp" => Value::Null |             "exp" => json!(null), | ||||||
|         }, |         }, | ||||||
|     ]; |     ]; | ||||||
|  |  | ||||||
| @@ -823,7 +823,7 @@ async fn error_single_search_token_forbidden_parent_key() { | |||||||
|             "exp" => json!((OffsetDateTime::now_utc() + Duration::hours(1)).unix_timestamp()) |             "exp" => json!((OffsetDateTime::now_utc() + Duration::hours(1)).unix_timestamp()) | ||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
|             "searchRules" => json!({"*": Value::Null}), |             "searchRules" => json!({"*": null}), | ||||||
|             "exp" => json!((OffsetDateTime::now_utc() + Duration::hours(1)).unix_timestamp()) |             "exp" => json!((OffsetDateTime::now_utc() + Duration::hours(1)).unix_timestamp()) | ||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
| @@ -835,7 +835,7 @@ async fn error_single_search_token_forbidden_parent_key() { | |||||||
|             "exp" => json!((OffsetDateTime::now_utc() + Duration::hours(1)).unix_timestamp()) |             "exp" => json!((OffsetDateTime::now_utc() + Duration::hours(1)).unix_timestamp()) | ||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
|             "searchRules" => json!({"sales": Value::Null}), |             "searchRules" => json!({"sales": null}), | ||||||
|             "exp" => json!((OffsetDateTime::now_utc() + Duration::hours(1)).unix_timestamp()) |             "exp" => json!((OffsetDateTime::now_utc() + Duration::hours(1)).unix_timestamp()) | ||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
| @@ -864,7 +864,7 @@ async fn error_multi_search_token_forbidden_parent_key() { | |||||||
|             "exp" => json!((OffsetDateTime::now_utc() + Duration::hours(1)).unix_timestamp()) |             "exp" => json!((OffsetDateTime::now_utc() + Duration::hours(1)).unix_timestamp()) | ||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
|             "searchRules" => json!({"*": Value::Null}), |             "searchRules" => json!({"*": null}), | ||||||
|             "exp" => json!((OffsetDateTime::now_utc() + Duration::hours(1)).unix_timestamp()) |             "exp" => json!((OffsetDateTime::now_utc() + Duration::hours(1)).unix_timestamp()) | ||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
| @@ -876,7 +876,7 @@ async fn error_multi_search_token_forbidden_parent_key() { | |||||||
|             "exp" => json!((OffsetDateTime::now_utc() + Duration::hours(1)).unix_timestamp()) |             "exp" => json!((OffsetDateTime::now_utc() + Duration::hours(1)).unix_timestamp()) | ||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
|             "searchRules" => json!({"sales": Value::Null, "products": Value::Null}), |             "searchRules" => json!({"sales": null, "products": null}), | ||||||
|             "exp" => json!((OffsetDateTime::now_utc() + Duration::hours(1)).unix_timestamp()) |             "exp" => json!((OffsetDateTime::now_utc() + Duration::hours(1)).unix_timestamp()) | ||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
| @@ -919,15 +919,15 @@ async fn error_single_search_forbidden_token() { | |||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
|             "searchRules" => json!({"products": {}}), |             "searchRules" => json!({"products": {}}), | ||||||
|             "exp" => Value::Null |             "exp" => json!(null), | ||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
|             "searchRules" => json!({"products": Value::Null}), |             "searchRules" => json!({"products": null}), | ||||||
|             "exp" => Value::Null |             "exp" => json!(null), | ||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
|             "searchRules" => json!(["products"]), |             "searchRules" => json!(["products"]), | ||||||
|             "exp" => Value::Null |             "exp" => json!(null), | ||||||
|         }, |         }, | ||||||
|         // expired token |         // expired token | ||||||
|         hashmap! { |         hashmap! { | ||||||
| @@ -935,7 +935,7 @@ async fn error_single_search_forbidden_token() { | |||||||
|             "exp" => json!((OffsetDateTime::now_utc() - Duration::hours(1)).unix_timestamp()) |             "exp" => json!((OffsetDateTime::now_utc() - Duration::hours(1)).unix_timestamp()) | ||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
|             "searchRules" => json!({"*": Value::Null}), |             "searchRules" => json!({"*": null}), | ||||||
|             "exp" => json!((OffsetDateTime::now_utc() - Duration::hours(1)).unix_timestamp()) |             "exp" => json!((OffsetDateTime::now_utc() - Duration::hours(1)).unix_timestamp()) | ||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
| @@ -947,7 +947,7 @@ async fn error_single_search_forbidden_token() { | |||||||
|             "exp" => json!((OffsetDateTime::now_utc() - Duration::hours(1)).unix_timestamp()) |             "exp" => json!((OffsetDateTime::now_utc() - Duration::hours(1)).unix_timestamp()) | ||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
|             "searchRules" => json!({"sales": Value::Null}), |             "searchRules" => json!({"sales": null}), | ||||||
|             "exp" => json!((OffsetDateTime::now_utc() - Duration::hours(1)).unix_timestamp()) |             "exp" => json!((OffsetDateTime::now_utc() - Duration::hours(1)).unix_timestamp()) | ||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
| @@ -978,15 +978,15 @@ async fn error_multi_search_forbidden_token() { | |||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
|             "searchRules" => json!({"products": {}}), |             "searchRules" => json!({"products": {}}), | ||||||
|             "exp" => Value::Null |             "exp" => json!(null), | ||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
|             "searchRules" => json!({"products": Value::Null}), |             "searchRules" => json!({"products": null}), | ||||||
|             "exp" => Value::Null |             "exp" => json!(null), | ||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
|             "searchRules" => json!(["products"]), |             "searchRules" => json!(["products"]), | ||||||
|             "exp" => Value::Null |             "exp" => json!(null), | ||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
|             "searchRules" => json!({"sales": {}}), |             "searchRules" => json!({"sales": {}}), | ||||||
| @@ -998,15 +998,15 @@ async fn error_multi_search_forbidden_token() { | |||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
|             "searchRules" => json!({"sales": {}}), |             "searchRules" => json!({"sales": {}}), | ||||||
|             "exp" => Value::Null |             "exp" => json!(null), | ||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
|             "searchRules" => json!({"sales": Value::Null}), |             "searchRules" => json!({"sales": null}), | ||||||
|             "exp" => Value::Null |             "exp" => json!(null), | ||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
|             "searchRules" => json!(["sales"]), |             "searchRules" => json!(["sales"]), | ||||||
|             "exp" => Value::Null |             "exp" => json!(null), | ||||||
|         }, |         }, | ||||||
|         // expired token |         // expired token | ||||||
|         hashmap! { |         hashmap! { | ||||||
| @@ -1014,7 +1014,7 @@ async fn error_multi_search_forbidden_token() { | |||||||
|             "exp" => json!((OffsetDateTime::now_utc() - Duration::hours(1)).unix_timestamp()) |             "exp" => json!((OffsetDateTime::now_utc() - Duration::hours(1)).unix_timestamp()) | ||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
|             "searchRules" => json!({"*": Value::Null}), |             "searchRules" => json!({"*": null}), | ||||||
|             "exp" => json!((OffsetDateTime::now_utc() - Duration::hours(1)).unix_timestamp()) |             "exp" => json!((OffsetDateTime::now_utc() - Duration::hours(1)).unix_timestamp()) | ||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
| @@ -1026,7 +1026,7 @@ async fn error_multi_search_forbidden_token() { | |||||||
|             "exp" => json!((OffsetDateTime::now_utc() - Duration::hours(1)).unix_timestamp()) |             "exp" => json!((OffsetDateTime::now_utc() - Duration::hours(1)).unix_timestamp()) | ||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
|             "searchRules" => json!({"sales": Value::Null, "products": {}}), |             "searchRules" => json!({"sales": null, "products": {}}), | ||||||
|             "exp" => json!((OffsetDateTime::now_utc() - Duration::hours(1)).unix_timestamp()) |             "exp" => json!((OffsetDateTime::now_utc() - Duration::hours(1)).unix_timestamp()) | ||||||
|         }, |         }, | ||||||
|         hashmap! { |         hashmap! { | ||||||
|   | |||||||
| @@ -3,12 +3,13 @@ use std::panic::{catch_unwind, resume_unwind, UnwindSafe}; | |||||||
| use std::time::Duration; | use std::time::Duration; | ||||||
|  |  | ||||||
| use actix_web::http::StatusCode; | use actix_web::http::StatusCode; | ||||||
| use serde_json::{json, Value}; |  | ||||||
| use tokio::time::sleep; | use tokio::time::sleep; | ||||||
| use urlencoding::encode as urlencode; | use urlencoding::encode as urlencode; | ||||||
|  |  | ||||||
| use super::encoder::Encoder; | use super::encoder::Encoder; | ||||||
| use super::service::Service; | use super::service::Service; | ||||||
|  | use super::Value; | ||||||
|  | use crate::json; | ||||||
|  |  | ||||||
| pub struct Index<'a> { | pub struct Index<'a> { | ||||||
|     pub uid: String, |     pub uid: String, | ||||||
| @@ -242,7 +243,9 @@ impl Index<'_> { | |||||||
|  |  | ||||||
|     pub async fn delete_batch(&self, ids: Vec<u64>) -> (Value, StatusCode) { |     pub async fn delete_batch(&self, ids: Vec<u64>) -> (Value, StatusCode) { | ||||||
|         let url = format!("/indexes/{}/documents/delete-batch", urlencode(self.uid.as_ref())); |         let url = format!("/indexes/{}/documents/delete-batch", urlencode(self.uid.as_ref())); | ||||||
|         self.service.post_encoded(url, serde_json::to_value(&ids).unwrap(), self.encoder).await |         self.service | ||||||
|  |             .post_encoded(url, serde_json::to_value(&ids).unwrap().into(), self.encoder) | ||||||
|  |             .await | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     pub async fn delete_batch_raw(&self, body: Value) -> (Value, StatusCode) { |     pub async fn delete_batch_raw(&self, body: Value) -> (Value, StatusCode) { | ||||||
|   | |||||||
| @@ -3,9 +3,84 @@ pub mod index; | |||||||
| pub mod server; | pub mod server; | ||||||
| pub mod service; | pub mod service; | ||||||
|  |  | ||||||
|  | use std::fmt::{self, Display}; | ||||||
|  |  | ||||||
| pub use index::{GetAllDocumentsOptions, GetDocumentOptions}; | pub use index::{GetAllDocumentsOptions, GetDocumentOptions}; | ||||||
|  | use meili_snap::json_string; | ||||||
|  | use serde::{Deserialize, Serialize}; | ||||||
| pub use server::{default_settings, Server}; | pub use server::{default_settings, Server}; | ||||||
|  |  | ||||||
|  | #[derive(Debug, Clone, Default, Serialize, Deserialize, PartialEq, Eq)] | ||||||
|  | pub struct Value(pub serde_json::Value); | ||||||
|  |  | ||||||
|  | impl Value { | ||||||
|  |     pub fn uid(&self) -> u64 { | ||||||
|  |         if let Some(uid) = self["uid"].as_u64() { | ||||||
|  |             uid | ||||||
|  |         } else if let Some(uid) = self["taskUid"].as_u64() { | ||||||
|  |             uid | ||||||
|  |         } else { | ||||||
|  |             panic!("Didn't find any task id in: {self}"); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | impl Into<Value> for serde_json::Value { | ||||||
|  |     fn into(self) -> Value { | ||||||
|  |         serde_json::json!(null); | ||||||
|  |         Value(self) | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | impl std::ops::Deref for Value { | ||||||
|  |     type Target = serde_json::Value; | ||||||
|  |  | ||||||
|  |     fn deref(&self) -> &Self::Target { | ||||||
|  |         &self.0 | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | impl PartialEq<serde_json::Value> for Value { | ||||||
|  |     fn eq(&self, other: &serde_json::Value) -> bool { | ||||||
|  |         &self.0 == other | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | impl PartialEq<Value> for serde_json::Value { | ||||||
|  |     fn eq(&self, other: &Value) -> bool { | ||||||
|  |         self == &other.0 | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | impl PartialEq<&str> for Value { | ||||||
|  |     fn eq(&self, other: &&str) -> bool { | ||||||
|  |         self.0.eq(other) | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | impl Display for Value { | ||||||
|  |     fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { | ||||||
|  |         write!( | ||||||
|  |             f, | ||||||
|  |             "{}", | ||||||
|  |             json_string!(self, { ".enqueuedAt" => "[date]", ".processedAt" => "[date]", ".finishedAt" => "[date]", ".duration" => "[duration]" }) | ||||||
|  |         ) | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | impl From<Vec<Value>> for Value { | ||||||
|  |     fn from(value: Vec<Value>) -> Self { | ||||||
|  |         Self(value.into_iter().map(|value| value.0).collect::<serde_json::Value>()) | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #[macro_export] | ||||||
|  | macro_rules! json { | ||||||
|  |     ($($json:tt)+) => { | ||||||
|  |         $crate::common::Value(serde_json::json!($($json)+)) | ||||||
|  |     }; | ||||||
|  | } | ||||||
|  |  | ||||||
| /// Performs a search test on both post and get routes | /// Performs a search test on both post and get routes | ||||||
| #[macro_export] | #[macro_export] | ||||||
| macro_rules! test_post_get_search { | macro_rules! test_post_get_search { | ||||||
|   | |||||||
| @@ -11,13 +11,14 @@ use clap::Parser; | |||||||
| use meilisearch::option::{IndexerOpts, MaxMemory, Opt}; | use meilisearch::option::{IndexerOpts, MaxMemory, Opt}; | ||||||
| use meilisearch::{analytics, create_app, setup_meilisearch}; | use meilisearch::{analytics, create_app, setup_meilisearch}; | ||||||
| use once_cell::sync::Lazy; | use once_cell::sync::Lazy; | ||||||
| use serde_json::{json, Value}; |  | ||||||
| use tempfile::TempDir; | use tempfile::TempDir; | ||||||
| use tokio::time::sleep; | use tokio::time::sleep; | ||||||
|  |  | ||||||
| use super::index::Index; | use super::index::Index; | ||||||
| use super::service::Service; | use super::service::Service; | ||||||
| use crate::common::encoder::Encoder; | use crate::common::encoder::Encoder; | ||||||
|  | use crate::common::Value; | ||||||
|  | use crate::json; | ||||||
|  |  | ||||||
| pub struct Server { | pub struct Server { | ||||||
|     pub service: Service, |     pub service: Service, | ||||||
|   | |||||||
| @@ -7,9 +7,9 @@ use actix_web::test::TestRequest; | |||||||
| use index_scheduler::IndexScheduler; | use index_scheduler::IndexScheduler; | ||||||
| use meilisearch::{analytics, create_app, Opt}; | use meilisearch::{analytics, create_app, Opt}; | ||||||
| use meilisearch_auth::AuthController; | use meilisearch_auth::AuthController; | ||||||
| use serde_json::Value; |  | ||||||
|  |  | ||||||
| use crate::common::encoder::Encoder; | use crate::common::encoder::Encoder; | ||||||
|  | use crate::common::Value; | ||||||
|  |  | ||||||
| pub struct Service { | pub struct Service { | ||||||
|     pub index_scheduler: Arc<IndexScheduler>, |     pub index_scheduler: Arc<IndexScheduler>, | ||||||
|   | |||||||
| @@ -3,9 +3,8 @@ | |||||||
| mod common; | mod common; | ||||||
|  |  | ||||||
| use actix_web::test; | use actix_web::test; | ||||||
| use serde_json::{json, Value}; |  | ||||||
|  |  | ||||||
| use crate::common::Server; | use crate::common::{Server, Value}; | ||||||
|  |  | ||||||
| enum HttpVerb { | enum HttpVerb { | ||||||
|     Put, |     Put, | ||||||
|   | |||||||
| @@ -1,11 +1,11 @@ | |||||||
| use actix_web::test; | use actix_web::test; | ||||||
| use meili_snap::{json_string, snapshot}; | use meili_snap::{json_string, snapshot}; | ||||||
| use serde_json::{json, Value}; |  | ||||||
| use time::format_description::well_known::Rfc3339; | use time::format_description::well_known::Rfc3339; | ||||||
| use time::OffsetDateTime; | use time::OffsetDateTime; | ||||||
|  |  | ||||||
| use crate::common::encoder::Encoder; | use crate::common::encoder::Encoder; | ||||||
| use crate::common::{GetAllDocumentsOptions, Server}; | use crate::common::{GetAllDocumentsOptions, Server, Value}; | ||||||
|  | use crate::json; | ||||||
|  |  | ||||||
| /// This is the basic usage of our API and every other tests uses the content-type application/json | /// This is the basic usage of our API and every other tests uses the content-type application/json | ||||||
| #[actix_rt::test] | #[actix_rt::test] | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| use meili_snap::{json_string, snapshot}; | use meili_snap::{json_string, snapshot}; | ||||||
| use serde_json::json; |  | ||||||
|  |  | ||||||
| use crate::common::{GetAllDocumentsOptions, Server}; | use crate::common::{GetAllDocumentsOptions, Server}; | ||||||
|  | use crate::json; | ||||||
|  |  | ||||||
| #[actix_rt::test] | #[actix_rt::test] | ||||||
| async fn delete_one_document_unexisting_index() { | async fn delete_one_document_unexisting_index() { | ||||||
|   | |||||||
| @@ -1,8 +1,8 @@ | |||||||
| use meili_snap::*; | use meili_snap::*; | ||||||
| use serde_json::json; |  | ||||||
| use urlencoding::encode; | use urlencoding::encode; | ||||||
|  |  | ||||||
| use crate::common::Server; | use crate::common::Server; | ||||||
|  | use crate::json; | ||||||
|  |  | ||||||
| #[actix_rt::test] | #[actix_rt::test] | ||||||
| async fn get_all_documents_bad_offset() { | async fn get_all_documents_bad_offset() { | ||||||
|   | |||||||
| @@ -1,11 +1,11 @@ | |||||||
| use actix_web::test; | use actix_web::test; | ||||||
| use http::header::ACCEPT_ENCODING; | use http::header::ACCEPT_ENCODING; | ||||||
| use meili_snap::*; | use meili_snap::*; | ||||||
| use serde_json::{json, Value}; |  | ||||||
| use urlencoding::encode as urlencode; | use urlencoding::encode as urlencode; | ||||||
|  |  | ||||||
| use crate::common::encoder::Encoder; | use crate::common::encoder::Encoder; | ||||||
| use crate::common::{GetAllDocumentsOptions, GetDocumentOptions, Server}; | use crate::common::{GetAllDocumentsOptions, GetDocumentOptions, Server, Value}; | ||||||
|  | use crate::json; | ||||||
|  |  | ||||||
| // TODO: partial test since we are testing error, amd error is not yet fully implemented in | // TODO: partial test since we are testing error, amd error is not yet fully implemented in | ||||||
| // transplant | // transplant | ||||||
| @@ -40,7 +40,7 @@ async fn get_document() { | |||||||
|     let server = Server::new().await; |     let server = Server::new().await; | ||||||
|     let index = server.index("test"); |     let index = server.index("test"); | ||||||
|     index.create(None).await; |     index.create(None).await; | ||||||
|     let documents = serde_json::json!([ |     let documents = json!([ | ||||||
|         { |         { | ||||||
|             "id": 0, |             "id": 0, | ||||||
|             "nested": { "content": "foobar" }, |             "nested": { "content": "foobar" }, | ||||||
| @@ -53,7 +53,7 @@ async fn get_document() { | |||||||
|     assert_eq!(code, 200); |     assert_eq!(code, 200); | ||||||
|     assert_eq!( |     assert_eq!( | ||||||
|         response, |         response, | ||||||
|         serde_json::json!({ |         json!({ | ||||||
|             "id": 0, |             "id": 0, | ||||||
|             "nested": { "content": "foobar" }, |             "nested": { "content": "foobar" }, | ||||||
|         }) |         }) | ||||||
| @@ -64,7 +64,7 @@ async fn get_document() { | |||||||
|     assert_eq!(code, 200); |     assert_eq!(code, 200); | ||||||
|     assert_eq!( |     assert_eq!( | ||||||
|         response, |         response, | ||||||
|         serde_json::json!({ |         json!({ | ||||||
|             "id": 0, |             "id": 0, | ||||||
|         }) |         }) | ||||||
|     ); |     ); | ||||||
| @@ -75,7 +75,7 @@ async fn get_document() { | |||||||
|     assert_eq!(code, 200); |     assert_eq!(code, 200); | ||||||
|     assert_eq!( |     assert_eq!( | ||||||
|         response, |         response, | ||||||
|         serde_json::json!({ |         json!({ | ||||||
|             "nested": { "content": "foobar" }, |             "nested": { "content": "foobar" }, | ||||||
|         }) |         }) | ||||||
|     ); |     ); | ||||||
| @@ -122,7 +122,7 @@ async fn get_all_documents_no_options() { | |||||||
|     assert_eq!(code, 200); |     assert_eq!(code, 200); | ||||||
|     let arr = response["results"].as_array().unwrap(); |     let arr = response["results"].as_array().unwrap(); | ||||||
|     assert_eq!(arr.len(), 20); |     assert_eq!(arr.len(), 20); | ||||||
|     let first = serde_json::json!({ |     let first = json!({ | ||||||
|         "id":0, |         "id":0, | ||||||
|         "isActive":false, |         "isActive":false, | ||||||
|         "balance":"$2,668.55", |         "balance":"$2,668.55", | ||||||
|   | |||||||
| @@ -1,7 +1,8 @@ | |||||||
| use serde_json::json; | use meili_snap::snapshot; | ||||||
|  |  | ||||||
| use crate::common::encoder::Encoder; | use crate::common::encoder::Encoder; | ||||||
| use crate::common::{GetAllDocumentsOptions, Server}; | use crate::common::{GetAllDocumentsOptions, Server}; | ||||||
|  | use crate::json; | ||||||
|  |  | ||||||
| #[actix_rt::test] | #[actix_rt::test] | ||||||
| async fn error_document_update_create_index_bad_uid() { | async fn error_document_update_create_index_bad_uid() { | ||||||
| @@ -84,7 +85,13 @@ async fn update_document() { | |||||||
|  |  | ||||||
|     let (response, code) = index.get_document(1, None).await; |     let (response, code) = index.get_document(1, None).await; | ||||||
|     assert_eq!(code, 200); |     assert_eq!(code, 200); | ||||||
|     assert_eq!(response.to_string(), r##"{"doc_id":1,"content":"foo","other":"bar"}"##); |     snapshot!(response, @r###" | ||||||
|  |     { | ||||||
|  |       "doc_id": 1, | ||||||
|  |       "content": "foo", | ||||||
|  |       "other": "bar" | ||||||
|  |     } | ||||||
|  |     "###); | ||||||
| } | } | ||||||
|  |  | ||||||
| #[actix_rt::test] | #[actix_rt::test] | ||||||
| @@ -122,7 +129,13 @@ async fn update_document_gzip_encoded() { | |||||||
|  |  | ||||||
|     let (response, code) = index.get_document(1, None).await; |     let (response, code) = index.get_document(1, None).await; | ||||||
|     assert_eq!(code, 200); |     assert_eq!(code, 200); | ||||||
|     assert_eq!(response.to_string(), r##"{"doc_id":1,"content":"foo","other":"bar"}"##); |     snapshot!(response, @r###" | ||||||
|  |     { | ||||||
|  |       "doc_id": 1, | ||||||
|  |       "content": "foo", | ||||||
|  |       "other": "bar" | ||||||
|  |     } | ||||||
|  |     "###); | ||||||
| } | } | ||||||
|  |  | ||||||
| #[actix_rt::test] | #[actix_rt::test] | ||||||
|   | |||||||
| @@ -2,10 +2,10 @@ mod data; | |||||||
|  |  | ||||||
| use meili_snap::{json_string, snapshot}; | use meili_snap::{json_string, snapshot}; | ||||||
| use meilisearch::Opt; | use meilisearch::Opt; | ||||||
| use serde_json::json; |  | ||||||
|  |  | ||||||
| use self::data::GetDump; | use self::data::GetDump; | ||||||
| use crate::common::{default_settings, GetAllDocumentsOptions, Server}; | use crate::common::{default_settings, GetAllDocumentsOptions, Server}; | ||||||
|  | use crate::json; | ||||||
|  |  | ||||||
| // all the following test are ignored on windows. See #2364 | // all the following test are ignored on windows. See #2364 | ||||||
| #[actix_rt::test] | #[actix_rt::test] | ||||||
|   | |||||||
| @@ -1,6 +1,5 @@ | |||||||
| use serde_json::json; |  | ||||||
|  |  | ||||||
| use crate::common::Server; | use crate::common::Server; | ||||||
|  | use crate::json; | ||||||
|  |  | ||||||
| /// Feature name to test against. | /// Feature name to test against. | ||||||
| /// This will have to be changed by a different one when that feature is stabilized. | /// This will have to be changed by a different one when that feature is stabilized. | ||||||
|   | |||||||
| @@ -2,10 +2,10 @@ use actix_web::http::header::ContentType; | |||||||
| use actix_web::test; | use actix_web::test; | ||||||
| use http::header::ACCEPT_ENCODING; | use http::header::ACCEPT_ENCODING; | ||||||
| use meili_snap::{json_string, snapshot}; | use meili_snap::{json_string, snapshot}; | ||||||
| use serde_json::{json, Value}; |  | ||||||
|  |  | ||||||
| use crate::common::encoder::Encoder; | use crate::common::encoder::Encoder; | ||||||
| use crate::common::Server; | use crate::common::{Server, Value}; | ||||||
|  | use crate::json; | ||||||
|  |  | ||||||
| #[actix_rt::test] | #[actix_rt::test] | ||||||
| async fn create_index_no_primary_key() { | async fn create_index_no_primary_key() { | ||||||
| @@ -21,7 +21,7 @@ async fn create_index_no_primary_key() { | |||||||
|  |  | ||||||
|     assert_eq!(response["status"], "succeeded"); |     assert_eq!(response["status"], "succeeded"); | ||||||
|     assert_eq!(response["type"], "indexCreation"); |     assert_eq!(response["type"], "indexCreation"); | ||||||
|     assert_eq!(response["details"]["primaryKey"], Value::Null); |     assert_eq!(response["details"]["primaryKey"], json!(null)); | ||||||
| } | } | ||||||
|  |  | ||||||
| #[actix_rt::test] | #[actix_rt::test] | ||||||
| @@ -38,7 +38,7 @@ async fn create_index_with_gzip_encoded_request() { | |||||||
|  |  | ||||||
|     assert_eq!(response["status"], "succeeded"); |     assert_eq!(response["status"], "succeeded"); | ||||||
|     assert_eq!(response["type"], "indexCreation"); |     assert_eq!(response["type"], "indexCreation"); | ||||||
|     assert_eq!(response["details"]["primaryKey"], Value::Null); |     assert_eq!(response["details"]["primaryKey"], json!(null)); | ||||||
| } | } | ||||||
|  |  | ||||||
| #[actix_rt::test] | #[actix_rt::test] | ||||||
| @@ -86,7 +86,7 @@ async fn create_index_with_zlib_encoded_request() { | |||||||
|  |  | ||||||
|     assert_eq!(response["status"], "succeeded"); |     assert_eq!(response["status"], "succeeded"); | ||||||
|     assert_eq!(response["type"], "indexCreation"); |     assert_eq!(response["type"], "indexCreation"); | ||||||
|     assert_eq!(response["details"]["primaryKey"], Value::Null); |     assert_eq!(response["details"]["primaryKey"], json!(null)); | ||||||
| } | } | ||||||
|  |  | ||||||
| #[actix_rt::test] | #[actix_rt::test] | ||||||
| @@ -103,7 +103,7 @@ async fn create_index_with_brotli_encoded_request() { | |||||||
|  |  | ||||||
|     assert_eq!(response["status"], "succeeded"); |     assert_eq!(response["status"], "succeeded"); | ||||||
|     assert_eq!(response["type"], "indexCreation"); |     assert_eq!(response["type"], "indexCreation"); | ||||||
|     assert_eq!(response["details"]["primaryKey"], Value::Null); |     assert_eq!(response["details"]["primaryKey"], json!(null)); | ||||||
| } | } | ||||||
|  |  | ||||||
| #[actix_rt::test] | #[actix_rt::test] | ||||||
| @@ -136,7 +136,7 @@ async fn create_index_with_invalid_primary_key() { | |||||||
|  |  | ||||||
|     let (response, code) = index.get().await; |     let (response, code) = index.get().await; | ||||||
|     assert_eq!(code, 200); |     assert_eq!(code, 200); | ||||||
|     assert_eq!(response["primaryKey"], Value::Null); |     assert_eq!(response["primaryKey"], json!(null)); | ||||||
| } | } | ||||||
|  |  | ||||||
| #[actix_rt::test] | #[actix_rt::test] | ||||||
|   | |||||||
| @@ -1,6 +1,5 @@ | |||||||
| use serde_json::json; |  | ||||||
|  |  | ||||||
| use crate::common::Server; | use crate::common::Server; | ||||||
|  | use crate::json; | ||||||
|  |  | ||||||
| #[actix_rt::test] | #[actix_rt::test] | ||||||
| async fn create_and_delete_index() { | async fn create_and_delete_index() { | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| use meili_snap::*; | use meili_snap::*; | ||||||
| use serde_json::json; |  | ||||||
|  |  | ||||||
| use crate::common::Server; | use crate::common::Server; | ||||||
|  | use crate::json; | ||||||
|  |  | ||||||
| #[actix_rt::test] | #[actix_rt::test] | ||||||
| async fn get_indexes_bad_offset() { | async fn get_indexes_bad_offset() { | ||||||
|   | |||||||
| @@ -1,6 +1,5 @@ | |||||||
| use serde_json::json; |  | ||||||
|  |  | ||||||
| use crate::common::Server; | use crate::common::Server; | ||||||
|  | use crate::json; | ||||||
|  |  | ||||||
| #[actix_rt::test] | #[actix_rt::test] | ||||||
| async fn stats() { | async fn stats() { | ||||||
|   | |||||||
| @@ -1,9 +1,9 @@ | |||||||
| use serde_json::json; |  | ||||||
| use time::format_description::well_known::Rfc3339; | use time::format_description::well_known::Rfc3339; | ||||||
| use time::OffsetDateTime; | use time::OffsetDateTime; | ||||||
|  |  | ||||||
| use crate::common::encoder::Encoder; | use crate::common::encoder::Encoder; | ||||||
| use crate::common::Server; | use crate::common::Server; | ||||||
|  | use crate::json; | ||||||
|  |  | ||||||
| #[actix_rt::test] | #[actix_rt::test] | ||||||
| async fn update_primary_key() { | async fn update_primary_key() { | ||||||
|   | |||||||
| @@ -1,8 +1,8 @@ | |||||||
| use meili_snap::*; | use meili_snap::*; | ||||||
| use serde_json::json; |  | ||||||
|  |  | ||||||
| use super::DOCUMENTS; | use super::DOCUMENTS; | ||||||
| use crate::common::Server; | use crate::common::Server; | ||||||
|  | use crate::json; | ||||||
|  |  | ||||||
| #[actix_rt::test] | #[actix_rt::test] | ||||||
| async fn search_unexisting_index() { | async fn search_unexisting_index() { | ||||||
|   | |||||||
| @@ -1,8 +1,8 @@ | |||||||
| use meili_snap::snapshot; | use meili_snap::snapshot; | ||||||
| use once_cell::sync::Lazy; | use once_cell::sync::Lazy; | ||||||
| use serde_json::{json, Value}; |  | ||||||
|  |  | ||||||
| use crate::common::Server; | use crate::common::{Server, Value}; | ||||||
|  | use crate::json; | ||||||
|  |  | ||||||
| pub(self) static DOCUMENTS: Lazy<Value> = Lazy::new(|| { | pub(self) static DOCUMENTS: Lazy<Value> = Lazy::new(|| { | ||||||
|     json!([ |     json!([ | ||||||
|   | |||||||
| @@ -1,8 +1,8 @@ | |||||||
| use insta::{allow_duplicates, assert_json_snapshot}; | use insta::{allow_duplicates, assert_json_snapshot}; | ||||||
| use serde_json::json; |  | ||||||
|  |  | ||||||
| use super::*; | use super::*; | ||||||
| use crate::common::Server; | use crate::common::Server; | ||||||
|  | use crate::json; | ||||||
|  |  | ||||||
| #[actix_rt::test] | #[actix_rt::test] | ||||||
| async fn formatted_contain_wildcard() { | async fn formatted_contain_wildcard() { | ||||||
|   | |||||||
| @@ -1,8 +1,8 @@ | |||||||
| use meili_snap::{json_string, snapshot}; | use meili_snap::{json_string, snapshot}; | ||||||
| use once_cell::sync::Lazy; | use once_cell::sync::Lazy; | ||||||
| use serde_json::{json, Value}; |  | ||||||
|  |  | ||||||
| use crate::common::Server; | use crate::common::{Server, Value}; | ||||||
|  | use crate::json; | ||||||
|  |  | ||||||
| pub(self) static DOCUMENTS: Lazy<Value> = Lazy::new(|| { | pub(self) static DOCUMENTS: Lazy<Value> = Lazy::new(|| { | ||||||
|     json!([ |     json!([ | ||||||
|   | |||||||
| @@ -10,9 +10,9 @@ mod pagination; | |||||||
| mod restrict_searchable; | mod restrict_searchable; | ||||||
|  |  | ||||||
| use once_cell::sync::Lazy; | use once_cell::sync::Lazy; | ||||||
| use serde_json::{json, Value}; |  | ||||||
|  |  | ||||||
| use crate::common::Server; | use crate::common::{Server, Value}; | ||||||
|  | use crate::json; | ||||||
|  |  | ||||||
| pub(self) static DOCUMENTS: Lazy<Value> = Lazy::new(|| { | pub(self) static DOCUMENTS: Lazy<Value> = Lazy::new(|| { | ||||||
|     json!([ |     json!([ | ||||||
|   | |||||||
| @@ -1,8 +1,8 @@ | |||||||
| use meili_snap::{json_string, snapshot}; | use meili_snap::{json_string, snapshot}; | ||||||
| use serde_json::json; |  | ||||||
|  |  | ||||||
| use super::{DOCUMENTS, NESTED_DOCUMENTS}; | use super::{DOCUMENTS, NESTED_DOCUMENTS}; | ||||||
| use crate::common::Server; | use crate::common::Server; | ||||||
|  | use crate::json; | ||||||
|  |  | ||||||
| #[actix_rt::test] | #[actix_rt::test] | ||||||
| async fn search_empty_list() { | async fn search_empty_list() { | ||||||
|   | |||||||
| @@ -1,6 +1,5 @@ | |||||||
| use serde_json::json; |  | ||||||
|  |  | ||||||
| use crate::common::Server; | use crate::common::Server; | ||||||
|  | use crate::json; | ||||||
| use crate::search::DOCUMENTS; | use crate::search::DOCUMENTS; | ||||||
|  |  | ||||||
| #[actix_rt::test] | #[actix_rt::test] | ||||||
|   | |||||||
| @@ -1,9 +1,9 @@ | |||||||
| use meili_snap::{json_string, snapshot}; | use meili_snap::{json_string, snapshot}; | ||||||
| use once_cell::sync::Lazy; | use once_cell::sync::Lazy; | ||||||
| use serde_json::{json, Value}; |  | ||||||
|  |  | ||||||
| use crate::common::index::Index; | use crate::common::index::Index; | ||||||
| use crate::common::Server; | use crate::common::{Server, Value}; | ||||||
|  | use crate::json; | ||||||
|  |  | ||||||
| async fn index_with_documents<'a>(server: &'a Server, documents: &Value) -> Index<'a> { | async fn index_with_documents<'a>(server: &'a Server, documents: &Value) -> Index<'a> { | ||||||
|     let index = server.index("test"); |     let index = server.index("test"); | ||||||
|   | |||||||
| @@ -1,6 +1,5 @@ | |||||||
| use serde_json::json; |  | ||||||
|  |  | ||||||
| use crate::common::Server; | use crate::common::Server; | ||||||
|  | use crate::json; | ||||||
|  |  | ||||||
| #[actix_rt::test] | #[actix_rt::test] | ||||||
| async fn set_and_reset_distinct_attribute() { | async fn set_and_reset_distinct_attribute() { | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| use meili_snap::*; | use meili_snap::*; | ||||||
| use serde_json::json; |  | ||||||
|  |  | ||||||
| use crate::common::Server; | use crate::common::Server; | ||||||
|  | use crate::json; | ||||||
|  |  | ||||||
| #[actix_rt::test] | #[actix_rt::test] | ||||||
| async fn settings_bad_displayed_attributes() { | async fn settings_bad_displayed_attributes() { | ||||||
|   | |||||||
| @@ -1,16 +1,16 @@ | |||||||
| use std::collections::HashMap; | use std::collections::HashMap; | ||||||
|  |  | ||||||
| use once_cell::sync::Lazy; | use once_cell::sync::Lazy; | ||||||
| use serde_json::{json, Value}; |  | ||||||
|  |  | ||||||
| use crate::common::Server; | use crate::common::{Server, Value}; | ||||||
|  | use crate::json; | ||||||
|  |  | ||||||
| static DEFAULT_SETTINGS_VALUES: Lazy<HashMap<&'static str, Value>> = Lazy::new(|| { | static DEFAULT_SETTINGS_VALUES: Lazy<HashMap<&'static str, Value>> = Lazy::new(|| { | ||||||
|     let mut map = HashMap::new(); |     let mut map = HashMap::new(); | ||||||
|     map.insert("displayed_attributes", json!(["*"])); |     map.insert("displayed_attributes", json!(["*"])); | ||||||
|     map.insert("searchable_attributes", json!(["*"])); |     map.insert("searchable_attributes", json!(["*"])); | ||||||
|     map.insert("filterable_attributes", json!([])); |     map.insert("filterable_attributes", json!([])); | ||||||
|     map.insert("distinct_attribute", json!(Value::Null)); |     map.insert("distinct_attribute", json!(null)); | ||||||
|     map.insert( |     map.insert( | ||||||
|         "ranking_rules", |         "ranking_rules", | ||||||
|         json!(["words", "typo", "proximity", "attribute", "sort", "exactness"]), |         json!(["words", "typo", "proximity", "attribute", "sort", "exactness"]), | ||||||
| @@ -229,7 +229,7 @@ macro_rules! test_setting_routes { | |||||||
|                         .chars() |                         .chars() | ||||||
|                         .map(|c| if c == '_' { '-' } else { c }) |                         .map(|c| if c == '_' { '-' } else { c }) | ||||||
|                         .collect::<String>()); |                         .collect::<String>()); | ||||||
|                     let (response, code) = server.service.$write_method(url, serde_json::Value::Null).await; |                     let (response, code) = server.service.$write_method(url, serde_json::Value::Null.into()).await; | ||||||
|                     assert_eq!(code, 202, "{}", response); |                     assert_eq!(code, 202, "{}", response); | ||||||
|                     server.index("").wait_task(0).await; |                     server.index("").wait_task(0).await; | ||||||
|                     let (response, code) = server.index("test").get().await; |                     let (response, code) = server.index("test").get().await; | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| use meili_snap::{json_string, snapshot}; | use meili_snap::{json_string, snapshot}; | ||||||
| use serde_json::json; |  | ||||||
|  |  | ||||||
| use crate::common::Server; | use crate::common::Server; | ||||||
|  | use crate::json; | ||||||
|  |  | ||||||
| #[actix_rt::test] | #[actix_rt::test] | ||||||
| async fn set_and_reset() { | async fn set_and_reset() { | ||||||
|   | |||||||
| @@ -7,6 +7,7 @@ use meilisearch::Opt; | |||||||
|  |  | ||||||
| use crate::common::server::default_settings; | use crate::common::server::default_settings; | ||||||
| use crate::common::{GetAllDocumentsOptions, Server}; | use crate::common::{GetAllDocumentsOptions, Server}; | ||||||
|  | use crate::json; | ||||||
|  |  | ||||||
| macro_rules! verify_snapshot { | macro_rules! verify_snapshot { | ||||||
|     ( |     ( | ||||||
| @@ -45,7 +46,7 @@ async fn perform_snapshot() { | |||||||
|  |  | ||||||
|     let index = server.index("test"); |     let index = server.index("test"); | ||||||
|     index |     index | ||||||
|         .update_settings(serde_json::json! ({ |         .update_settings(json! ({ | ||||||
|         "searchableAttributes": [], |         "searchableAttributes": [], | ||||||
|         })) |         })) | ||||||
|         .await; |         .await; | ||||||
| @@ -104,7 +105,7 @@ async fn perform_on_demand_snapshot() { | |||||||
|  |  | ||||||
|     let index = server.index("catto"); |     let index = server.index("catto"); | ||||||
|     index |     index | ||||||
|         .update_settings(serde_json::json! ({ |         .update_settings(json! ({ | ||||||
|         "searchableAttributes": [], |         "searchableAttributes": [], | ||||||
|         })) |         })) | ||||||
|         .await; |         .await; | ||||||
| @@ -128,23 +129,15 @@ async fn perform_on_demand_snapshot() { | |||||||
|       "enqueuedAt": "[date]" |       "enqueuedAt": "[date]" | ||||||
|     } |     } | ||||||
|     "###); |     "###); | ||||||
|     let task = index.wait_task(3).await; |     let task = index.wait_task(4).await; | ||||||
|     snapshot!(json_string!(task, { ".enqueuedAt" => "[date]", ".startedAt" => "[date]", ".finishedAt" => "[date]", ".duration" => "[duration]" }), @r###" |     snapshot!(json_string!(task, { ".enqueuedAt" => "[date]", ".startedAt" => "[date]", ".finishedAt" => "[date]", ".duration" => "[duration]" }), @r###" | ||||||
|     { |     { | ||||||
|       "uid": 3, |       "uid": 4, | ||||||
|       "indexUid": "doggo", |       "indexUid": null, | ||||||
|       "status": "failed", |       "status": "succeeded", | ||||||
|       "type": "indexCreation", |       "type": "snapshotCreation", | ||||||
|       "canceledBy": null, |       "canceledBy": null, | ||||||
|       "details": { |       "error": null, | ||||||
|         "primaryKey": "bone" |  | ||||||
|       }, |  | ||||||
|       "error": { |  | ||||||
|         "message": "Index `doggo` already exists.", |  | ||||||
|         "code": "index_already_exists", |  | ||||||
|         "type": "invalid_request", |  | ||||||
|         "link": "https://docs.meilisearch.com/errors#index_already_exists" |  | ||||||
|       }, |  | ||||||
|       "duration": "[duration]", |       "duration": "[duration]", | ||||||
|       "enqueuedAt": "[date]", |       "enqueuedAt": "[date]", | ||||||
|       "startedAt": "[date]", |       "startedAt": "[date]", | ||||||
|   | |||||||
| @@ -1,8 +1,8 @@ | |||||||
| use serde_json::json; |  | ||||||
| use time::format_description::well_known::Rfc3339; | use time::format_description::well_known::Rfc3339; | ||||||
| use time::OffsetDateTime; | use time::OffsetDateTime; | ||||||
|  |  | ||||||
| use crate::common::Server; | use crate::common::Server; | ||||||
|  | use crate::json; | ||||||
|  |  | ||||||
| #[actix_rt::test] | #[actix_rt::test] | ||||||
| async fn get_settings_unexisting_index() { | async fn get_settings_unexisting_index() { | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| use meili_snap::*; | use meili_snap::*; | ||||||
| use serde_json::json; |  | ||||||
|  |  | ||||||
| use crate::common::Server; | use crate::common::Server; | ||||||
|  | use crate::json; | ||||||
|  |  | ||||||
| #[actix_rt::test] | #[actix_rt::test] | ||||||
| async fn swap_indexes_bad_format() { | async fn swap_indexes_bad_format() { | ||||||
|   | |||||||
| @@ -1,9 +1,9 @@ | |||||||
| mod errors; | mod errors; | ||||||
|  |  | ||||||
| use meili_snap::{json_string, snapshot}; | use meili_snap::{json_string, snapshot}; | ||||||
| use serde_json::json; |  | ||||||
|  |  | ||||||
| use crate::common::{GetAllDocumentsOptions, Server}; | use crate::common::{GetAllDocumentsOptions, Server}; | ||||||
|  | use crate::json; | ||||||
|  |  | ||||||
| #[actix_rt::test] | #[actix_rt::test] | ||||||
| async fn swap_indexes() { | async fn swap_indexes() { | ||||||
|   | |||||||
| @@ -1,11 +1,11 @@ | |||||||
| mod errors; | mod errors; | ||||||
|  |  | ||||||
| use meili_snap::insta::assert_json_snapshot; | use meili_snap::insta::assert_json_snapshot; | ||||||
| use serde_json::json; |  | ||||||
| use time::format_description::well_known::Rfc3339; | use time::format_description::well_known::Rfc3339; | ||||||
| use time::OffsetDateTime; | use time::OffsetDateTime; | ||||||
|  |  | ||||||
| use crate::common::Server; | use crate::common::Server; | ||||||
|  | use crate::json; | ||||||
|  |  | ||||||
| #[actix_rt::test] | #[actix_rt::test] | ||||||
| async fn error_get_unexisting_task_status() { | async fn error_get_unexisting_task_status() { | ||||||
| @@ -33,7 +33,7 @@ async fn get_task_status() { | |||||||
|     index.create(None).await; |     index.create(None).await; | ||||||
|     index |     index | ||||||
|         .add_documents( |         .add_documents( | ||||||
|             serde_json::json!([{ |             json!([{ | ||||||
|                 "id": 1, |                 "id": 1, | ||||||
|                 "content": "foobar", |                 "content": "foobar", | ||||||
|             }]), |             }]), | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user