2020-01-29 00:45:57 +08:00
|
|
|
use assert_json_diff::assert_json_eq;
|
|
|
|
use serde_json::json;
|
|
|
|
|
|
|
|
mod common;
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn write_all_and_delete() {
|
2020-03-04 21:18:07 +08:00
|
|
|
let mut server = common::Server::with_uid("movies");
|
|
|
|
server.populate_movies();
|
2020-01-29 00:45:57 +08:00
|
|
|
|
|
|
|
// 2 - Send the settings
|
|
|
|
|
2020-03-04 21:18:07 +08:00
|
|
|
let body = json!([
|
2020-02-27 01:47:03 +08:00
|
|
|
"typo",
|
|
|
|
"words",
|
|
|
|
"proximity",
|
|
|
|
"attribute",
|
2020-02-27 21:31:08 +08:00
|
|
|
"wordsPosition",
|
2020-02-27 01:47:03 +08:00
|
|
|
"exactness",
|
2020-03-03 00:13:23 +08:00
|
|
|
"desc(release_date)",
|
|
|
|
"desc(rank)",
|
2020-02-10 23:51:17 +08:00
|
|
|
]);
|
2020-01-29 00:45:57 +08:00
|
|
|
|
2020-03-04 21:18:07 +08:00
|
|
|
server.update_ranking_rules(body.clone());
|
2020-01-29 00:45:57 +08:00
|
|
|
|
|
|
|
// 3 - Get all settings and compare to the previous one
|
|
|
|
|
2020-03-04 21:18:07 +08:00
|
|
|
let (response, _status_code) = server.get_ranking_rules();
|
2020-02-03 05:59:19 +08:00
|
|
|
|
2020-03-04 21:18:07 +08:00
|
|
|
assert_json_eq!(body, response, ordered: false);
|
2020-01-29 00:45:57 +08:00
|
|
|
|
|
|
|
// 4 - Delete all settings
|
|
|
|
|
2020-03-04 21:18:07 +08:00
|
|
|
server.delete_ranking_rules();
|
2020-01-29 00:45:57 +08:00
|
|
|
|
|
|
|
// 5 - Get all settings and check if they are empty
|
|
|
|
|
2020-03-04 21:18:07 +08:00
|
|
|
let (response, _status_code) = server.get_ranking_rules();
|
2020-01-29 00:45:57 +08:00
|
|
|
|
2020-03-05 22:18:19 +08:00
|
|
|
let expected = json!([
|
2020-03-02 21:34:29 +08:00
|
|
|
"typo",
|
|
|
|
"words",
|
|
|
|
"proximity",
|
|
|
|
"attribute",
|
|
|
|
"wordsPosition",
|
|
|
|
"exactness"
|
2020-02-27 01:47:03 +08:00
|
|
|
]);
|
2020-02-03 05:59:19 +08:00
|
|
|
|
2020-03-05 22:18:19 +08:00
|
|
|
assert_json_eq!(expected, response, ordered: false);
|
2020-01-29 00:45:57 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn write_all_and_update() {
|
2020-03-04 21:18:07 +08:00
|
|
|
let mut server = common::Server::with_uid("movies");
|
|
|
|
server.populate_movies();
|
2020-01-29 00:45:57 +08:00
|
|
|
|
|
|
|
// 2 - Send the settings
|
|
|
|
|
2020-03-04 21:18:07 +08:00
|
|
|
let body = json!([
|
2020-02-27 01:47:03 +08:00
|
|
|
"typo",
|
|
|
|
"words",
|
|
|
|
"proximity",
|
|
|
|
"attribute",
|
2020-02-27 21:31:08 +08:00
|
|
|
"wordsPosition",
|
2020-02-27 01:47:03 +08:00
|
|
|
"exactness",
|
2020-03-03 00:13:23 +08:00
|
|
|
"desc(release_date)",
|
|
|
|
"desc(rank)",
|
2020-02-10 23:51:17 +08:00
|
|
|
]);
|
2020-01-29 00:45:57 +08:00
|
|
|
|
2020-03-04 21:18:07 +08:00
|
|
|
server.update_ranking_rules(body.clone());
|
2020-01-29 00:45:57 +08:00
|
|
|
|
|
|
|
// 3 - Get all settings and compare to the previous one
|
|
|
|
|
2020-03-04 21:18:07 +08:00
|
|
|
let (response, _status_code) = server.get_ranking_rules();
|
2020-01-29 00:45:57 +08:00
|
|
|
|
2020-03-04 21:18:07 +08:00
|
|
|
assert_json_eq!(body, response, ordered: false);
|
2020-01-29 00:45:57 +08:00
|
|
|
|
|
|
|
// 4 - Update all settings
|
|
|
|
|
2020-03-04 21:18:07 +08:00
|
|
|
let body = json!([
|
2020-02-27 01:47:03 +08:00
|
|
|
"typo",
|
|
|
|
"words",
|
|
|
|
"proximity",
|
|
|
|
"attribute",
|
2020-02-27 21:31:08 +08:00
|
|
|
"wordsPosition",
|
2020-02-27 01:47:03 +08:00
|
|
|
"exactness",
|
2020-03-03 00:13:23 +08:00
|
|
|
"desc(release_date)",
|
2020-02-10 23:51:17 +08:00
|
|
|
]);
|
2020-01-29 00:45:57 +08:00
|
|
|
|
2020-03-04 21:18:07 +08:00
|
|
|
server.update_ranking_rules(body);
|
2020-01-29 00:45:57 +08:00
|
|
|
|
|
|
|
// 5 - Get all settings and check if the content is the same of (4)
|
|
|
|
|
2020-03-04 21:18:07 +08:00
|
|
|
let (response, _status_code) = server.get_ranking_rules();
|
2020-01-29 00:45:57 +08:00
|
|
|
|
2020-03-04 21:18:07 +08:00
|
|
|
let expected = json!([
|
2020-02-27 01:47:03 +08:00
|
|
|
"typo",
|
|
|
|
"words",
|
|
|
|
"proximity",
|
|
|
|
"attribute",
|
2020-02-27 21:31:08 +08:00
|
|
|
"wordsPosition",
|
2020-02-27 01:47:03 +08:00
|
|
|
"exactness",
|
2020-03-03 00:13:23 +08:00
|
|
|
"desc(release_date)",
|
2020-02-10 23:51:17 +08:00
|
|
|
]);
|
2020-01-29 00:45:57 +08:00
|
|
|
|
2020-03-04 21:18:07 +08:00
|
|
|
assert_json_eq!(expected, response, ordered: false);
|
2020-01-29 00:45:57 +08:00
|
|
|
}
|
2020-03-05 22:18:19 +08:00
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn send_undefined_rule() {
|
|
|
|
let mut server = common::Server::with_uid("movies");
|
|
|
|
let body = json!({
|
|
|
|
"uid": "movies",
|
2020-03-10 01:40:49 +08:00
|
|
|
"primaryKey": "id",
|
2020-03-05 22:18:19 +08:00
|
|
|
});
|
|
|
|
server.create_index(body);
|
|
|
|
|
2020-03-10 18:29:56 +08:00
|
|
|
let body = json!(["typos",]);
|
2020-03-05 22:18:19 +08:00
|
|
|
|
|
|
|
let (_response, status_code) = server.update_ranking_rules_sync(body);
|
|
|
|
assert_eq!(status_code, 400);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn send_malformed_custom_rule() {
|
|
|
|
let mut server = common::Server::with_uid("movies");
|
|
|
|
let body = json!({
|
|
|
|
"uid": "movies",
|
2020-03-10 01:40:49 +08:00
|
|
|
"primaryKey": "id",
|
2020-03-05 22:18:19 +08:00
|
|
|
});
|
|
|
|
server.create_index(body);
|
|
|
|
|
2020-03-10 18:29:56 +08:00
|
|
|
let body = json!(["dsc(truc)",]);
|
2020-03-05 22:18:19 +08:00
|
|
|
|
|
|
|
let (_response, status_code) = server.update_ranking_rules_sync(body);
|
|
|
|
assert_eq!(status_code, 400);
|
|
|
|
}
|