meilisearch/meilisearch-http/tests/settings.rs

527 lines
14 KiB
Rust
Raw Normal View History

2020-01-23 18:30:18 +08:00
use assert_json_diff::assert_json_eq;
use serde_json::json;
2020-03-10 18:29:56 +08:00
use std::convert::Into;
2020-01-19 02:00:41 +08:00
mod common;
2020-04-16 17:09:47 +08:00
#[actix_rt::test]
async fn write_all_and_delete() {
let mut server = common::Server::test_server().await;
2020-01-19 02:00:41 +08:00
// 2 - Send the settings
2020-03-04 21:18:07 +08:00
let body = json!({
2020-01-21 19:03:48 +08:00
"rankingRules": [
2020-02-27 01:47:03 +08:00
"typo",
"words",
"proximity",
"attribute",
"wordsPosition",
2020-02-27 01:47:03 +08:00
"exactness",
"desc(registered)",
"desc(age)",
2020-01-19 02:00:41 +08:00
],
"distinctAttribute": "id",
2020-01-30 01:30:21 +08:00
"searchableAttributes": [
2020-02-03 05:59:19 +08:00
"id",
"name",
"color",
"gender",
"email",
"phone",
"address",
"registered",
"about"
2020-01-19 02:00:41 +08:00
],
2020-01-30 01:30:21 +08:00
"displayedAttributes": [
"name",
"gender",
"email",
"registered",
"age",
2020-01-19 02:00:41 +08:00
],
2020-01-21 19:03:48 +08:00
"stopWords": [
"ad",
"in",
"ut",
2020-01-19 02:00:41 +08:00
],
"synonyms": {
"road": ["street", "avenue"],
"street": ["avenue"],
2020-01-28 01:27:42 +08:00
},
"attributesForFaceting": ["name"],
2020-01-19 02:00:41 +08:00
});
2020-04-16 17:09:47 +08:00
server.update_all_settings(body.clone()).await;
2020-01-19 02:00:41 +08:00
// 3 - Get all settings and compare to the previous one
2020-04-16 17:09:47 +08:00
let (response, _status_code) = server.get_all_settings().await;
2020-03-04 21:18:07 +08:00
assert_json_eq!(body, response, ordered: false);
// 4 - Delete all settings
2020-04-16 17:09:47 +08:00
server.delete_all_settings().await;
2020-03-04 21:18:07 +08:00
// 5 - Get all settings and check if they are set to default values
2020-04-16 17:09:47 +08:00
let (response, _status_code) = server.get_all_settings().await;
2020-01-19 02:00:41 +08:00
2020-03-04 21:18:07 +08:00
let expect = json!({
2020-02-27 01:47:03 +08:00
"rankingRules": [
"typo",
"words",
"proximity",
"attribute",
"wordsPosition",
2020-02-27 01:47:03 +08:00
"exactness"
],
2020-02-26 23:05:02 +08:00
"distinctAttribute": null,
2020-07-10 17:37:01 +08:00
"searchableAttributes": ["*"],
"displayedAttributes": ["*"],
"stopWords": [],
"synonyms": {},
2020-06-03 17:09:25 +08:00
"attributesForFaceting": [],
});
2020-01-19 02:00:41 +08:00
2020-03-04 21:18:07 +08:00
assert_json_eq!(expect, response, ordered: false);
2020-01-19 02:00:41 +08:00
}
2020-01-20 16:52:24 +08:00
2020-04-16 17:09:47 +08:00
#[actix_rt::test]
async fn write_all_and_update() {
let mut server = common::Server::test_server().await;
2020-01-20 16:52:24 +08:00
// 2 - Send the settings
2020-03-04 21:18:07 +08:00
let body = json!({
2020-01-21 19:03:48 +08:00
"rankingRules": [
2020-02-27 01:47:03 +08:00
"typo",
"words",
"proximity",
"attribute",
"wordsPosition",
2020-02-27 01:47:03 +08:00
"exactness",
"desc(registered)",
"desc(age)",
2020-01-20 16:52:24 +08:00
],
"distinctAttribute": "id",
2020-01-30 01:30:21 +08:00
"searchableAttributes": [
"id",
"name",
"color",
"gender",
"email",
"phone",
"address",
"registered",
"about"
2020-01-20 16:52:24 +08:00
],
2020-01-30 01:30:21 +08:00
"displayedAttributes": [
"name",
"gender",
"email",
"registered",
"age",
2020-01-20 16:52:24 +08:00
],
2020-01-21 19:03:48 +08:00
"stopWords": [
"ad",
"in",
"ut",
2020-01-20 16:52:24 +08:00
],
"synonyms": {
"road": ["street", "avenue"],
"street": ["avenue"],
2020-01-28 01:27:42 +08:00
},
"attributesForFaceting": ["name"],
2020-01-20 16:52:24 +08:00
});
2020-04-16 17:09:47 +08:00
server.update_all_settings(body.clone()).await;
2020-01-20 16:52:24 +08:00
// 3 - Get all settings and compare to the previous one
2020-04-16 17:09:47 +08:00
let (response, _status_code) = server.get_all_settings().await;
2020-01-20 16:52:24 +08:00
2020-03-04 21:18:07 +08:00
assert_json_eq!(body, response, ordered: false);
2020-01-20 16:52:24 +08:00
// 4 - Update all settings
2020-03-04 21:18:07 +08:00
let body = json!({
2020-01-21 19:03:48 +08:00
"rankingRules": [
2020-02-27 01:47:03 +08:00
"typo",
"words",
"proximity",
"attribute",
"wordsPosition",
2020-02-27 01:47:03 +08:00
"exactness",
"desc(age)",
2020-01-20 16:52:24 +08:00
],
"distinctAttribute": null,
2020-01-30 01:30:21 +08:00
"searchableAttributes": [
"name",
"color",
"age",
2020-01-20 16:52:24 +08:00
],
2020-01-30 01:30:21 +08:00
"displayedAttributes": [
"name",
"color",
"age",
"registered",
"picture",
2020-01-20 16:52:24 +08:00
],
"stopWords": [],
2020-01-20 16:52:24 +08:00
"synonyms": {
"road": ["street", "avenue"],
"street": ["avenue"],
"HP": ["Harry Potter"],
"Harry Potter": ["HP"]
2020-01-28 01:27:42 +08:00
},
2020-05-06 04:27:06 +08:00
"attributesForFaceting": ["title"],
2020-01-20 16:52:24 +08:00
});
2020-04-16 17:09:47 +08:00
server.update_all_settings(body).await;
2020-01-20 16:52:24 +08:00
// 5 - Get all settings and check if the content is the same of (4)
2020-04-16 17:09:47 +08:00
let (response, _status_code) = server.get_all_settings().await;
2020-01-20 16:52:24 +08:00
2020-03-04 21:18:07 +08:00
let expected = json!({
2020-01-21 19:03:48 +08:00
"rankingRules": [
2020-02-27 01:47:03 +08:00
"typo",
"words",
"proximity",
"attribute",
"wordsPosition",
2020-02-27 01:47:03 +08:00
"exactness",
"desc(age)",
2020-01-20 16:52:24 +08:00
],
2020-02-26 23:05:02 +08:00
"distinctAttribute": null,
2020-01-30 01:30:21 +08:00
"searchableAttributes": [
"name",
"color",
"age",
2020-01-20 16:52:24 +08:00
],
2020-01-30 01:30:21 +08:00
"displayedAttributes": [
"name",
"color",
"age",
"registered",
"picture",
2020-01-20 16:52:24 +08:00
],
"stopWords": [],
2020-01-20 16:52:24 +08:00
"synonyms": {
"road": ["street", "avenue"],
"street": ["avenue"],
"hp": ["harry potter"],
"harry potter": ["hp"]
2020-01-27 15:52:36 +08:00
},
2020-05-06 04:27:06 +08:00
"attributesForFaceting": ["title"],
2020-01-20 16:52:24 +08:00
});
2020-03-04 21:18:07 +08:00
assert_json_eq!(expected, response, ordered: false);
2020-01-20 16:52:24 +08:00
}
2020-04-16 17:09:47 +08:00
#[actix_rt::test]
async fn test_default_settings() {
let mut server = common::Server::with_uid("test");
let body = json!({
"uid": "test",
});
2020-04-16 17:09:47 +08:00
server.create_index(body).await;
// 1 - Get all settings and compare to the previous one
let body = json!({
"rankingRules": [
"typo",
"words",
"proximity",
"attribute",
"wordsPosition",
"exactness"
],
"distinctAttribute": null,
2020-07-10 17:37:01 +08:00
"searchableAttributes": ["*"],
"displayedAttributes": ["*"],
"stopWords": [],
"synonyms": {},
2020-06-03 17:09:25 +08:00
"attributesForFaceting": [],
});
2020-04-16 17:09:47 +08:00
let (response, _status_code) = server.get_all_settings().await;
assert_json_eq!(body, response, ordered: false);
}
2020-04-16 17:09:47 +08:00
#[actix_rt::test]
async fn test_default_settings_2() {
let mut server = common::Server::with_uid("test");
let body = json!({
"uid": "test",
"primaryKey": "id",
});
2020-04-16 17:09:47 +08:00
server.create_index(body).await;
// 1 - Get all settings and compare to the previous one
let body = json!({
"rankingRules": [
"typo",
"words",
"proximity",
"attribute",
"wordsPosition",
"exactness"
],
"distinctAttribute": null,
2020-07-10 17:37:01 +08:00
"searchableAttributes": ["*"],
"displayedAttributes": ["*"],
"stopWords": [],
"synonyms": {},
2020-06-03 17:09:25 +08:00
"attributesForFaceting": [],
});
2020-04-16 17:09:47 +08:00
let (response, _status_code) = server.get_all_settings().await;
assert_json_eq!(body, response, ordered: false);
}
// Test issue https://github.com/meilisearch/MeiliSearch/issues/516
2020-04-16 17:09:47 +08:00
#[actix_rt::test]
async fn write_setting_and_update_partial() {
let mut server = common::Server::with_uid("test");
let body = json!({
"uid": "test",
});
2020-04-16 17:09:47 +08:00
server.create_index(body).await;
// 2 - Send the settings
let body = json!({
"searchableAttributes": [
"id",
"name",
"color",
"gender",
"email",
"phone",
"address",
"about"
],
"displayedAttributes": [
"name",
"gender",
"email",
"registered",
"age",
]
});
2020-04-16 17:09:47 +08:00
server.update_all_settings(body.clone()).await;
// 2 - Send the settings
let body = json!({
"rankingRules": [
"typo",
"words",
"proximity",
"attribute",
"wordsPosition",
"exactness",
"desc(age)",
"desc(registered)",
],
"distinctAttribute": "id",
"stopWords": [
"ad",
"in",
"ut",
],
"synonyms": {
"road": ["street", "avenue"],
"street": ["avenue"],
},
});
2020-04-16 17:09:47 +08:00
server.update_all_settings(body.clone()).await;
// 2 - Send the settings
let expected = json!({
"rankingRules": [
"typo",
"words",
"proximity",
"attribute",
"wordsPosition",
"exactness",
"desc(age)",
"desc(registered)",
],
"distinctAttribute": "id",
"searchableAttributes": [
"id",
"name",
"color",
"gender",
"email",
"phone",
"address",
"about"
],
"displayedAttributes": [
"name",
"gender",
"email",
"registered",
"age",
],
"stopWords": [
"ad",
"in",
"ut",
],
"synonyms": {
"road": ["street", "avenue"],
"street": ["avenue"],
},
2020-06-03 17:09:25 +08:00
"attributesForFaceting": [],
});
2020-04-16 17:09:47 +08:00
let (response, _status_code) = server.get_all_settings().await;
assert_json_eq!(expected, response, ordered: false);
}
2020-06-03 17:09:25 +08:00
#[actix_rt::test]
async fn attributes_for_faceting_settings() {
let mut server = common::Server::test_server().await;
// initial attributes array should be empty
let (response, _status_code) = server.get_request("/indexes/test/settings/attributes-for-faceting").await;
assert_eq!(response, json!([]));
// add an attribute and test for its presence
let (_response, _status_code) = server.post_request_async(
"/indexes/test/settings/attributes-for-faceting",
json!(["foobar"])).await;
let (response, _status_code) = server.get_request("/indexes/test/settings/attributes-for-faceting").await;
assert_eq!(response, json!(["foobar"]));
// remove all attributes and test for emptiness
let (_response, _status_code) = server.delete_request_async(
"/indexes/test/settings/attributes-for-faceting").await;
let (response, _status_code) = server.get_request("/indexes/test/settings/attributes-for-faceting").await;
assert_eq!(response, json!([]));
}
2020-06-16 15:52:58 +08:00
#[actix_rt::test]
async fn setting_ranking_rules_dont_mess_with_other_settings() {
let mut server = common::Server::test_server().await;
let body = json!({
"rankingRules": ["asc(foobar)"]
});
server.update_all_settings(body).await;
let (response, _) = server.get_all_settings().await;
assert_eq!(response["rankingRules"].as_array().unwrap().len(), 1);
assert_eq!(response["rankingRules"].as_array().unwrap().first().unwrap().as_str().unwrap(), "asc(foobar)");
assert!(!response["searchableAttributes"].as_array().unwrap().iter().any(|e| e.as_str().unwrap() == "foobar"));
assert!(!response["displayedAttributes"].as_array().unwrap().iter().any(|e| e.as_str().unwrap() == "foobar"));
}
2020-07-16 00:51:36 +08:00
#[actix_rt::test]
async fn displayed_and_searchable_attributes_reset_to_wildcard() {
let mut server = common::Server::test_server().await;
server.update_all_settings(json!({ "searchableAttributes": ["color"], "displayedAttributes": ["color"] })).await;
let (response, _) = server.get_all_settings().await;
2020-07-16 01:21:03 +08:00
2020-07-16 00:51:36 +08:00
assert_eq!(response["searchableAttributes"].as_array().unwrap()[0], "color");
assert_eq!(response["displayedAttributes"].as_array().unwrap()[0], "color");
2020-07-16 01:21:03 +08:00
2020-07-16 00:51:36 +08:00
server.delete_searchable_attributes().await;
server.delete_displayed_attributes().await;
2020-07-16 01:21:03 +08:00
let (response, _) = server.get_all_settings().await;
2020-07-16 22:12:23 +08:00
assert_eq!(response["searchableAttributes"].as_array().unwrap().len(), 1);
assert_eq!(response["displayedAttributes"].as_array().unwrap().len(), 1);
2020-07-16 01:21:03 +08:00
assert_eq!(response["searchableAttributes"].as_array().unwrap()[0], "*");
assert_eq!(response["displayedAttributes"].as_array().unwrap()[0], "*");
let mut server = common::Server::test_server().await;
server.update_all_settings(json!({ "searchableAttributes": ["color"], "displayedAttributes": ["color"] })).await;
let (response, _) = server.get_all_settings().await;
assert_eq!(response["searchableAttributes"].as_array().unwrap()[0], "color");
assert_eq!(response["displayedAttributes"].as_array().unwrap()[0], "color");
server.update_all_settings(json!({ "searchableAttributes": [], "displayedAttributes": [] })).await;
2020-07-16 00:51:36 +08:00
let (response, _) = server.get_all_settings().await;
2020-07-16 22:12:23 +08:00
assert_eq!(response["searchableAttributes"].as_array().unwrap().len(), 1);
assert_eq!(response["displayedAttributes"].as_array().unwrap().len(), 1);
assert_eq!(response["searchableAttributes"].as_array().unwrap()[0], "*");
assert_eq!(response["displayedAttributes"].as_array().unwrap()[0], "*");
}
#[actix_rt::test]
async fn settings_that_contains_wildcard_is_wildcard() {
let mut server = common::Server::test_server().await;
server.update_all_settings(json!({ "searchableAttributes": ["color", "*"], "displayedAttributes": ["color", "*"] })).await;
let (response, _) = server.get_all_settings().await;
assert_eq!(response["searchableAttributes"].as_array().unwrap().len(), 1);
assert_eq!(response["displayedAttributes"].as_array().unwrap().len(), 1);
2020-07-16 00:51:36 +08:00
assert_eq!(response["searchableAttributes"].as_array().unwrap()[0], "*");
assert_eq!(response["displayedAttributes"].as_array().unwrap()[0], "*");
}
2020-10-10 10:43:09 +08:00
#[actix_rt::test]
async fn test_displayed_attributes_field() {
let mut server = common::Server::test_server().await;
let body = json!({
"rankingRules": [
"typo",
"words",
"proximity",
"attribute",
"wordsPosition",
"exactness",
"desc(registered)",
"desc(age)",
],
"distinctAttribute": "id",
"searchableAttributes": [
"id",
"name",
"color",
"gender",
"email",
"phone",
"address",
"registered",
"about"
],
"displayedAttributes": [
"age",
"email",
"gender",
"name",
"registered",
],
"stopWords": [
"ad",
"in",
"ut",
],
"synonyms": {
"road": ["avenue", "street"],
"street": ["avenue"],
},
"attributesForFaceting": ["name"],
});
server.update_all_settings(body.clone()).await;
let (response, _status_code) = server.get_all_settings().await;
assert_json_eq!(body, response, ordered: true);
}