2021-02-24 16:30:51 +08:00
|
|
|
use crate::common::Server;
|
|
|
|
use serde_json::json;
|
|
|
|
|
|
|
|
#[actix_rt::test]
|
|
|
|
async fn get_settings_unexisting_index() {
|
|
|
|
let server = Server::new().await;
|
|
|
|
let (_response, code) = server.index("test").settings().await;
|
|
|
|
assert_eq!(code, 400)
|
|
|
|
}
|
|
|
|
|
|
|
|
#[actix_rt::test]
|
|
|
|
async fn get_settings() {
|
|
|
|
let server = Server::new().await;
|
|
|
|
let index = server.index("test");
|
|
|
|
index.create(None).await;
|
|
|
|
let (response, code) = index.settings().await;
|
|
|
|
assert_eq!(code, 200);
|
|
|
|
let settings = response.as_object().unwrap();
|
2021-03-10 21:43:10 +08:00
|
|
|
assert_eq!(settings.keys().len(), 4);
|
2021-02-24 16:30:51 +08:00
|
|
|
assert_eq!(settings["displayedAttributes"], json!(["*"]));
|
|
|
|
assert_eq!(settings["searchableAttributes"], json!(["*"]));
|
|
|
|
assert_eq!(settings["facetedAttributes"], json!({}));
|
2021-03-10 21:43:10 +08:00
|
|
|
assert_eq!(settings["rankingRules"], json!(["typo", "words", "proximity", "attribute", "wordsPosition", "exactness"]));
|
2021-02-24 16:30:51 +08:00
|
|
|
}
|
|
|
|
|
2021-02-24 16:42:36 +08:00
|
|
|
#[actix_rt::test]
|
|
|
|
async fn update_settings_unknown_field() {
|
|
|
|
let server = Server::new().await;
|
|
|
|
let index = server.index("test");
|
|
|
|
let (_response, code) = index.update_settings(json!({"foo": 12})).await;
|
|
|
|
assert_eq!(code, 400);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[actix_rt::test]
|
|
|
|
async fn test_partial_update() {
|
|
|
|
let server = Server::new().await;
|
|
|
|
let index = server.index("test");
|
2021-03-13 17:09:10 +08:00
|
|
|
let (_response, _code) = index.update_settings(json!({"displayedAttributes": ["foo"]})).await;
|
2021-02-24 16:42:36 +08:00
|
|
|
index.wait_update_id(0).await;
|
|
|
|
let (response, code) = index.settings().await;
|
|
|
|
assert_eq!(code, 200);
|
|
|
|
assert_eq!(response["displayedAttributes"],json!(["foo"]));
|
|
|
|
assert_eq!(response["searchableAttributes"],json!(["*"]));
|
|
|
|
|
2021-03-13 17:09:10 +08:00
|
|
|
let (_response, _) = index.update_settings(json!({"searchableAttributes": ["bar"]})).await;
|
2021-02-24 16:42:36 +08:00
|
|
|
index.wait_update_id(1).await;
|
|
|
|
|
|
|
|
let (response, code) = index.settings().await;
|
|
|
|
assert_eq!(code, 200);
|
|
|
|
assert_eq!(response["displayedAttributes"],json!(["foo"]));
|
|
|
|
assert_eq!(response["searchableAttributes"],json!(["bar"]));
|
|
|
|
}
|
|
|
|
|
2021-02-24 17:14:36 +08:00
|
|
|
#[actix_rt::test]
|
|
|
|
async fn delete_settings_unexisting_index() {
|
|
|
|
let server = Server::new().await;
|
|
|
|
let index = server.index("test");
|
|
|
|
let (_response, code) = index.delete_settings().await;
|
|
|
|
assert_eq!(code, 400);
|
|
|
|
}
|
|
|
|
|
2021-02-24 17:19:22 +08:00
|
|
|
#[actix_rt::test]
|
|
|
|
async fn reset_all_settings() {
|
|
|
|
let server = Server::new().await;
|
|
|
|
let index = server.index("test");
|
|
|
|
index.update_settings(json!({"displayedAttributes": ["foo"], "searchableAttributes": ["bar"]})).await;
|
|
|
|
index.wait_update_id(0).await;
|
|
|
|
let (response, code) = index.settings().await;
|
|
|
|
assert_eq!(code, 200);
|
|
|
|
assert_eq!(response["displayedAttributes"],json!(["foo"]));
|
|
|
|
assert_eq!(response["searchableAttributes"],json!(["bar"]));
|
|
|
|
|
|
|
|
index.delete_settings().await;
|
|
|
|
index.wait_update_id(1).await;
|
|
|
|
|
|
|
|
let (response, code) = index.settings().await;
|
|
|
|
assert_eq!(code, 200);
|
|
|
|
assert_eq!(response["displayedAttributes"],json!(["*"]));
|
|
|
|
assert_eq!(response["searchableAttributes"],json!(["*"]));
|
|
|
|
}
|
|
|
|
|
2021-02-24 16:30:51 +08:00
|
|
|
#[actix_rt::test]
|
|
|
|
async fn update_setting_unexisting_index() {
|
|
|
|
let server = Server::new().await;
|
|
|
|
let index = server.index("test");
|
|
|
|
let (_response, code) = index.update_settings(json!({})).await;
|
|
|
|
assert_eq!(code, 200);
|
|
|
|
let (_response, code) = index.get().await;
|
|
|
|
assert_eq!(code, 200);
|
|
|
|
}
|
|
|
|
|
2021-03-10 21:43:10 +08:00
|
|
|
#[actix_rt::test]
|
|
|
|
async fn update_setting_unexisting_index_invalid_uid() {
|
|
|
|
let server = Server::new().await;
|
|
|
|
let index = server.index("test##! ");
|
|
|
|
let (_response, code) = index.update_settings(json!({})).await;
|
|
|
|
assert_eq!(code, 400);
|
|
|
|
}
|
|
|
|
|
2021-02-24 16:30:51 +08:00
|
|
|
macro_rules! test_setting_routes {
|
|
|
|
($($setting:ident), *) => {
|
|
|
|
$(
|
|
|
|
mod $setting {
|
|
|
|
use crate::common::Server;
|
|
|
|
|
|
|
|
#[actix_rt::test]
|
|
|
|
async fn get_unexisting_index() {
|
|
|
|
let server = Server::new().await;
|
|
|
|
let url = format!("/indexes/test/settings/{}",
|
|
|
|
stringify!($setting)
|
|
|
|
.chars()
|
|
|
|
.map(|c| if c == '_' { '-' } else { c })
|
|
|
|
.collect::<String>());
|
|
|
|
let (_response, code) = server.service.get(url).await;
|
|
|
|
assert_eq!(code, 400);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[actix_rt::test]
|
|
|
|
async fn update_unexisting_index() {
|
|
|
|
let server = Server::new().await;
|
|
|
|
let url = format!("/indexes/test/settings/{}",
|
|
|
|
stringify!($setting)
|
|
|
|
.chars()
|
|
|
|
.map(|c| if c == '_' { '-' } else { c })
|
|
|
|
.collect::<String>());
|
2021-03-12 07:37:43 +08:00
|
|
|
let (response, code) = server.service.post(url, serde_json::Value::Null).await;
|
|
|
|
assert_eq!(code, 200, "{}", response);
|
|
|
|
let (response, code) = server.index("test").get().await;
|
|
|
|
assert_eq!(code, 200, "{}", response);
|
2021-02-24 16:30:51 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
#[actix_rt::test]
|
|
|
|
async fn delete_unexisting_index() {
|
|
|
|
let server = Server::new().await;
|
|
|
|
let url = format!("/indexes/test/settings/{}",
|
|
|
|
stringify!($setting)
|
|
|
|
.chars()
|
|
|
|
.map(|c| if c == '_' { '-' } else { c })
|
|
|
|
.collect::<String>());
|
|
|
|
let (_response, code) = server.service.delete(url).await;
|
|
|
|
assert_eq!(code, 400);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
)*
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
test_setting_routes!(
|
|
|
|
attributes_for_faceting,
|
|
|
|
displayed_attributes,
|
|
|
|
searchable_attributes);
|