mirror of
https://github.com/meilisearch/meilisearch.git
synced 2024-12-02 10:05:05 +08:00
remove legacy tests
This commit is contained in:
parent
ac2af4354d
commit
1968bfac4d
@ -1,12 +0,0 @@
|
|||||||
mod common;
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn dashboard() {
|
|
||||||
let mut server = common::Server::with_uid("movies");
|
|
||||||
|
|
||||||
let (_response, status_code) = server.get_request("/").await;
|
|
||||||
assert_eq!(status_code, 200);
|
|
||||||
|
|
||||||
let (_response, status_code) = server.get_request("/bulma.min.css").await;
|
|
||||||
assert_eq!(status_code, 200);
|
|
||||||
}
|
|
@ -1,222 +0,0 @@
|
|||||||
use serde_json::json;
|
|
||||||
|
|
||||||
mod common;
|
|
||||||
|
|
||||||
// Test issue https://github.com/meilisearch/MeiliSearch/issues/519
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn check_add_documents_with_primary_key_param() {
|
|
||||||
let mut server = common::Server::with_uid("movies");
|
|
||||||
|
|
||||||
// 1 - Create the index with no primary_key
|
|
||||||
|
|
||||||
let body = json!({
|
|
||||||
"uid": "movies",
|
|
||||||
});
|
|
||||||
let (response, status_code) = server.create_index(body).await;
|
|
||||||
assert_eq!(status_code, 201);
|
|
||||||
assert_eq!(response["primaryKey"], json!(null));
|
|
||||||
|
|
||||||
// 2 - Add documents
|
|
||||||
|
|
||||||
let body = json!([{
|
|
||||||
"title": "Test",
|
|
||||||
"comment": "comment test"
|
|
||||||
}]);
|
|
||||||
|
|
||||||
let url = "/indexes/movies/documents?primaryKey=title";
|
|
||||||
let (response, status_code) = server.post_request(&url, body).await;
|
|
||||||
eprintln!("{:#?}", response);
|
|
||||||
assert_eq!(status_code, 202);
|
|
||||||
let update_id = response["updateId"].as_u64().unwrap();
|
|
||||||
server.wait_update_id(update_id).await;
|
|
||||||
|
|
||||||
// 3 - Check update success
|
|
||||||
|
|
||||||
let (response, status_code) = server.get_update_status(update_id).await;
|
|
||||||
assert_eq!(status_code, 200);
|
|
||||||
assert_eq!(response["status"], "processed");
|
|
||||||
}
|
|
||||||
|
|
||||||
// Test issue https://github.com/meilisearch/MeiliSearch/issues/568
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn check_add_documents_with_nested_boolean() {
|
|
||||||
let mut server = common::Server::with_uid("tasks");
|
|
||||||
|
|
||||||
// 1 - Create the index with no primary_key
|
|
||||||
|
|
||||||
let body = json!({ "uid": "tasks" });
|
|
||||||
let (response, status_code) = server.create_index(body).await;
|
|
||||||
assert_eq!(status_code, 201);
|
|
||||||
assert_eq!(response["primaryKey"], json!(null));
|
|
||||||
|
|
||||||
// 2 - Add a document that contains a boolean in a nested object
|
|
||||||
|
|
||||||
let body = json!([{
|
|
||||||
"id": 12161,
|
|
||||||
"created_at": "2019-04-10T14:57:57.522Z",
|
|
||||||
"foo": {
|
|
||||||
"bar": {
|
|
||||||
"id": 121,
|
|
||||||
"crash": false
|
|
||||||
},
|
|
||||||
"id": 45912
|
|
||||||
}
|
|
||||||
}]);
|
|
||||||
|
|
||||||
let url = "/indexes/tasks/documents";
|
|
||||||
let (response, status_code) = server.post_request(&url, body).await;
|
|
||||||
eprintln!("{:#?}", response);
|
|
||||||
assert_eq!(status_code, 202);
|
|
||||||
let update_id = response["updateId"].as_u64().unwrap();
|
|
||||||
server.wait_update_id(update_id).await;
|
|
||||||
|
|
||||||
// 3 - Check update success
|
|
||||||
|
|
||||||
let (response, status_code) = server.get_update_status(update_id).await;
|
|
||||||
assert_eq!(status_code, 200);
|
|
||||||
assert_eq!(response["status"], "processed");
|
|
||||||
}
|
|
||||||
|
|
||||||
// Test issue https://github.com/meilisearch/MeiliSearch/issues/571
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn check_add_documents_with_nested_null() {
|
|
||||||
let mut server = common::Server::with_uid("tasks");
|
|
||||||
|
|
||||||
// 1 - Create the index with no primary_key
|
|
||||||
|
|
||||||
let body = json!({ "uid": "tasks" });
|
|
||||||
let (response, status_code) = server.create_index(body).await;
|
|
||||||
assert_eq!(status_code, 201);
|
|
||||||
assert_eq!(response["primaryKey"], json!(null));
|
|
||||||
|
|
||||||
// 2 - Add a document that contains a null in a nested object
|
|
||||||
|
|
||||||
let body = json!([{
|
|
||||||
"id": 0,
|
|
||||||
"foo": {
|
|
||||||
"bar": null
|
|
||||||
}
|
|
||||||
}]);
|
|
||||||
|
|
||||||
let url = "/indexes/tasks/documents";
|
|
||||||
let (response, status_code) = server.post_request(&url, body).await;
|
|
||||||
eprintln!("{:#?}", response);
|
|
||||||
assert_eq!(status_code, 202);
|
|
||||||
let update_id = response["updateId"].as_u64().unwrap();
|
|
||||||
server.wait_update_id(update_id).await;
|
|
||||||
|
|
||||||
// 3 - Check update success
|
|
||||||
|
|
||||||
let (response, status_code) = server.get_update_status(update_id).await;
|
|
||||||
assert_eq!(status_code, 200);
|
|
||||||
assert_eq!(response["status"], "processed");
|
|
||||||
}
|
|
||||||
|
|
||||||
// Test issue https://github.com/meilisearch/MeiliSearch/issues/574
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn check_add_documents_with_nested_sequence() {
|
|
||||||
let mut server = common::Server::with_uid("tasks");
|
|
||||||
|
|
||||||
// 1 - Create the index with no primary_key
|
|
||||||
|
|
||||||
let body = json!({ "uid": "tasks" });
|
|
||||||
let (response, status_code) = server.create_index(body).await;
|
|
||||||
assert_eq!(status_code, 201);
|
|
||||||
assert_eq!(response["primaryKey"], json!(null));
|
|
||||||
|
|
||||||
// 2 - Add a document that contains a seq in a nested object
|
|
||||||
|
|
||||||
let body = json!([{
|
|
||||||
"id": 0,
|
|
||||||
"foo": {
|
|
||||||
"bar": [123,456],
|
|
||||||
"fez": [{
|
|
||||||
"id": 255,
|
|
||||||
"baz": "leesz",
|
|
||||||
"fuzz": {
|
|
||||||
"fax": [234]
|
|
||||||
},
|
|
||||||
"sas": []
|
|
||||||
}],
|
|
||||||
"foz": [{
|
|
||||||
"id": 255,
|
|
||||||
"baz": "leesz",
|
|
||||||
"fuzz": {
|
|
||||||
"fax": [234]
|
|
||||||
},
|
|
||||||
"sas": []
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": 256,
|
|
||||||
"baz": "loss",
|
|
||||||
"fuzz": {
|
|
||||||
"fax": [235]
|
|
||||||
},
|
|
||||||
"sas": [321, 321]
|
|
||||||
}]
|
|
||||||
}
|
|
||||||
}]);
|
|
||||||
|
|
||||||
let url = "/indexes/tasks/documents";
|
|
||||||
let (response, status_code) = server.post_request(&url, body.clone()).await;
|
|
||||||
eprintln!("{:#?}", response);
|
|
||||||
assert_eq!(status_code, 202);
|
|
||||||
let update_id = response["updateId"].as_u64().unwrap();
|
|
||||||
server.wait_update_id(update_id).await;
|
|
||||||
|
|
||||||
// 3 - Check update success
|
|
||||||
|
|
||||||
let (response, status_code) = server.get_update_status(update_id).await;
|
|
||||||
assert_eq!(status_code, 200);
|
|
||||||
assert_eq!(response["status"], "processed");
|
|
||||||
|
|
||||||
let url = "/indexes/tasks/search?q=leesz";
|
|
||||||
let (response, status_code) = server.get_request(&url).await;
|
|
||||||
assert_eq!(status_code, 200);
|
|
||||||
assert_eq!(response["hits"], body);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
// test sample from #807
|
|
||||||
async fn add_document_with_long_field() {
|
|
||||||
let mut server = common::Server::with_uid("test");
|
|
||||||
server.create_index(json!({ "uid": "test" })).await;
|
|
||||||
let body = json!([{
|
|
||||||
"documentId":"de1c2adbb897effdfe0deae32a01035e46f932ce",
|
|
||||||
"rank":1,
|
|
||||||
"relurl":"/configuration/app/web.html#locations",
|
|
||||||
"section":"Web",
|
|
||||||
"site":"docs",
|
|
||||||
"text":" The locations block is the most powerful, and potentially most involved, section of the .platform.app.yaml file. It allows you to control how the application container responds to incoming requests at a very fine-grained level. Common patterns also vary between language containers due to the way PHP-FPM handles incoming requests.\nEach entry of the locations block is an absolute URI path (with leading /) and its value includes the configuration directives for how the web server should handle matching requests. That is, if your domain is example.com then '/' means “requests for example.com/”, while '/admin' means “requests for example.com/admin”. If multiple blocks could match an incoming request then the most-specific will apply.\nweb:locations:'/':# Rules for all requests that don't otherwise match....'/sites/default/files':# Rules for any requests that begin with /sites/default/files....The simplest possible locations configuration is one that simply passes all requests on to your application unconditionally:\nweb:locations:'/':passthru:trueThat is, all requests to /* should be forwarded to the process started by web.commands.start above. Note that for PHP containers the passthru key must specify what PHP file the request should be forwarded to, and must also specify a docroot under which the file lives. For example:\nweb:locations:'/':root:'web'passthru:'/app.php'This block will serve requests to / from the web directory in the application, and if a file doesn’t exist on disk then the request will be forwarded to the /app.php script.\nA full list of the possible subkeys for locations is below.\n root: The folder from which to serve static assets for this location relative to the application root. The application root is the directory in which the .platform.app.yaml file is located. Typical values for this property include public or web. Setting it to '' is not recommended, and its behavior may vary depending on the type of application. Absolute paths are not supported.\n passthru: Whether to forward disallowed and missing resources from this location to the application and can be true, false or an absolute URI path (with leading /). The default value is false. For non-PHP applications it will generally be just true or false. In a PHP application this will typically be the front controller such as /index.php or /app.php. This entry works similar to mod_rewrite under Apache. Note: If the value of passthru does not begin with the same value as the location key it is under, the passthru may evaluate to another entry. That may be useful when you want different cache settings for different paths, for instance, but want missing files in all of them to map back to the same front controller. See the example block below.\n index: The files to consider when serving a request for a directory: an array of file names or null. (typically ['index.html']). Note that in order for this to work, access to the static files named must be allowed by the allow or rules keys for this location.\n expires: How long to allow static assets from this location to be cached (this enables the Cache-Control and Expires headers) and can be a time or -1 for no caching (default). Times can be suffixed with “ms” (milliseconds), “s” (seconds), “m” (minutes), “h” (hours), “d” (days), “w” (weeks), “M” (months, 30d) or “y” (years, 365d).\n scripts: Whether to allow loading scripts in that location (true or false). This directive is only meaningful on PHP.\n allow: Whether to allow serving files which don’t match a rule (true or false, default: true).\n headers: Any additional headers to apply to static assets. This section is a mapping of header names to header values. Responses from the application aren’t affected, to avoid overlap with the application’s own ability to include custom headers in the response.\n rules: Specific overrides for a specific location. The key is a PCRE (regular expression) that is matched against the full request path.\n request_buffering: Most application servers do not support chunked requests (e.g. fpm, uwsgi), so Platform.sh enables request_buffering by default to handle them. That default configuration would look like this if it was present in .platform.app.yaml:\nweb:locations:'/':passthru:truerequest_buffering:enabled:truemax_request_size:250mIf the application server can already efficiently handle chunked requests, the request_buffering subkey can be modified to disable it entirely (enabled: false). Additionally, applications that frequently deal with uploads greater than 250MB in size can update the max_request_size key to the application’s needs. Note that modifications to request_buffering will need to be specified at each location where it is desired.\n ",
|
|
||||||
"title":"Locations",
|
|
||||||
"url":"/configuration/app/web.html#locations"
|
|
||||||
}]);
|
|
||||||
server.add_or_replace_multiple_documents(body).await;
|
|
||||||
let (response, _status) = server
|
|
||||||
.search_post(json!({ "q": "request_buffering" }))
|
|
||||||
.await;
|
|
||||||
assert!(!response["hits"].as_array().unwrap().is_empty());
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn documents_with_same_id_are_overwritten() {
|
|
||||||
let mut server = common::Server::with_uid("test");
|
|
||||||
server.create_index(json!({ "uid": "test"})).await;
|
|
||||||
let documents = json!([
|
|
||||||
{
|
|
||||||
"id": 1,
|
|
||||||
"content": "test1"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": 1,
|
|
||||||
"content": "test2"
|
|
||||||
},
|
|
||||||
]);
|
|
||||||
server.add_or_replace_multiple_documents(documents).await;
|
|
||||||
let (response, _status) = server.get_all_documents().await;
|
|
||||||
assert_eq!(response.as_array().unwrap().len(), 1);
|
|
||||||
assert_eq!(
|
|
||||||
response.as_array().unwrap()[0].as_object().unwrap()["content"],
|
|
||||||
"test2"
|
|
||||||
);
|
|
||||||
}
|
|
@ -1,67 +0,0 @@
|
|||||||
mod common;
|
|
||||||
|
|
||||||
use serde_json::json;
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn delete() {
|
|
||||||
let mut server = common::Server::test_server().await;
|
|
||||||
|
|
||||||
let (_response, status_code) = server.get_document(50).await;
|
|
||||||
assert_eq!(status_code, 200);
|
|
||||||
|
|
||||||
server.delete_document(50).await;
|
|
||||||
|
|
||||||
let (_response, status_code) = server.get_document(50).await;
|
|
||||||
assert_eq!(status_code, 404);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Resolve the issue https://github.com/meilisearch/MeiliSearch/issues/493
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn delete_batch() {
|
|
||||||
let mut server = common::Server::test_server().await;
|
|
||||||
|
|
||||||
let doc_ids = vec!(50, 55, 60);
|
|
||||||
for doc_id in &doc_ids {
|
|
||||||
let (_response, status_code) = server.get_document(doc_id).await;
|
|
||||||
assert_eq!(status_code, 200);
|
|
||||||
}
|
|
||||||
|
|
||||||
let body = serde_json::json!(&doc_ids);
|
|
||||||
server.delete_multiple_documents(body).await;
|
|
||||||
|
|
||||||
for doc_id in &doc_ids {
|
|
||||||
let (_response, status_code) = server.get_document(doc_id).await;
|
|
||||||
assert_eq!(status_code, 404);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn text_clear_all_placeholder_search() {
|
|
||||||
let mut server = common::Server::with_uid("test");
|
|
||||||
let body = json!({
|
|
||||||
"uid": "test",
|
|
||||||
});
|
|
||||||
|
|
||||||
server.create_index(body).await;
|
|
||||||
let settings = json!({
|
|
||||||
"attributesForFaceting": ["genre"],
|
|
||||||
});
|
|
||||||
|
|
||||||
server.update_all_settings(settings).await;
|
|
||||||
|
|
||||||
let documents = json!([
|
|
||||||
{ "id": 2, "title": "Pride and Prejudice", "author": "Jane Austin", "genre": "romance" },
|
|
||||||
{ "id": 456, "title": "Le Petit Prince", "author": "Antoine de Saint-Exupéry", "genre": "adventure" },
|
|
||||||
{ "id": 1, "title": "Alice In Wonderland", "author": "Lewis Carroll", "genre": "fantasy" },
|
|
||||||
{ "id": 1344, "title": "The Hobbit", "author": "J. R. R. Tolkien", "genre": "fantasy" },
|
|
||||||
{ "id": 4, "title": "Harry Potter and the Half-Blood Prince", "author": "J. K. Rowling", "genre": "fantasy" },
|
|
||||||
{ "id": 42, "title": "The Hitchhiker's Guide to the Galaxy", "author": "Douglas Adams" }
|
|
||||||
]);
|
|
||||||
|
|
||||||
server.add_or_update_multiple_documents(documents).await;
|
|
||||||
server.clear_all_documents().await;
|
|
||||||
let (response, _) = server.search_post(json!({ "q": "", "facetsDistribution": ["genre"] })).await;
|
|
||||||
assert_eq!(response["nbHits"], 0);
|
|
||||||
let (response, _) = server.search_post(json!({ "q": "" })).await;
|
|
||||||
assert_eq!(response["nbHits"], 0);
|
|
||||||
}
|
|
@ -1,23 +0,0 @@
|
|||||||
use serde_json::json;
|
|
||||||
use actix_web::http::StatusCode;
|
|
||||||
|
|
||||||
mod common;
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn get_documents_from_unexisting_index_is_error() {
|
|
||||||
let mut server = common::Server::with_uid("test");
|
|
||||||
let (response, status) = server.get_all_documents().await;
|
|
||||||
assert_eq!(status, StatusCode::NOT_FOUND);
|
|
||||||
assert_eq!(response["errorCode"], "index_not_found");
|
|
||||||
assert_eq!(response["errorType"], "invalid_request_error");
|
|
||||||
assert_eq!(response["errorLink"], "https://docs.meilisearch.com/errors#index_not_found");
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn get_empty_documents_list() {
|
|
||||||
let mut server = common::Server::with_uid("test");
|
|
||||||
server.create_index(json!({ "uid": "test" })).await;
|
|
||||||
let (response, status) = server.get_all_documents().await;
|
|
||||||
assert_eq!(status, StatusCode::OK);
|
|
||||||
assert!(response.as_array().unwrap().is_empty());
|
|
||||||
}
|
|
@ -1,395 +0,0 @@
|
|||||||
use assert_json_diff::{assert_json_eq, assert_json_include};
|
|
||||||
use meilisearch_http::helpers::compression;
|
|
||||||
use serde_json::{json, Value};
|
|
||||||
use std::fs::File;
|
|
||||||
use std::path::Path;
|
|
||||||
use std::thread;
|
|
||||||
use std::time::Duration;
|
|
||||||
use tempfile::TempDir;
|
|
||||||
|
|
||||||
#[macro_use] mod common;
|
|
||||||
|
|
||||||
async fn trigger_and_wait_dump(server: &mut common::Server) -> String {
|
|
||||||
let (value, status_code) = server.trigger_dump().await;
|
|
||||||
|
|
||||||
assert_eq!(status_code, 202);
|
|
||||||
|
|
||||||
let dump_uid = value["uid"].as_str().unwrap().to_string();
|
|
||||||
|
|
||||||
for _ in 0..20 as u8 {
|
|
||||||
let (value, status_code) = server.get_dump_status(&dump_uid).await;
|
|
||||||
|
|
||||||
assert_eq!(status_code, 200);
|
|
||||||
assert_ne!(value["status"].as_str(), Some("dump_process_failed"));
|
|
||||||
|
|
||||||
if value["status"].as_str() == Some("done") { return dump_uid }
|
|
||||||
thread::sleep(Duration::from_millis(100));
|
|
||||||
}
|
|
||||||
|
|
||||||
unreachable!("dump creation runned out of time")
|
|
||||||
}
|
|
||||||
|
|
||||||
fn current_db_version() -> (String, String, String) {
|
|
||||||
let current_version_major = env!("CARGO_PKG_VERSION_MAJOR").to_string();
|
|
||||||
let current_version_minor = env!("CARGO_PKG_VERSION_MINOR").to_string();
|
|
||||||
let current_version_patch = env!("CARGO_PKG_VERSION_PATCH").to_string();
|
|
||||||
|
|
||||||
(current_version_major, current_version_minor, current_version_patch)
|
|
||||||
}
|
|
||||||
|
|
||||||
fn current_dump_version() -> String {
|
|
||||||
"V1".into()
|
|
||||||
}
|
|
||||||
|
|
||||||
fn read_all_jsonline<R: std::io::Read>(r: R) -> Value {
|
|
||||||
let deserializer = serde_json::Deserializer::from_reader(r);
|
|
||||||
let iterator = deserializer.into_iter::<serde_json::Value>();
|
|
||||||
|
|
||||||
json!(iterator.map(|v| v.unwrap()).collect::<Vec<Value>>())
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
#[ignore]
|
|
||||||
async fn trigger_dump_should_return_ok() {
|
|
||||||
let server = common::Server::test_server().await;
|
|
||||||
|
|
||||||
let (_, status_code) = server.trigger_dump().await;
|
|
||||||
|
|
||||||
assert_eq!(status_code, 202);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
#[ignore]
|
|
||||||
async fn trigger_dump_twice_should_return_conflict() {
|
|
||||||
let server = common::Server::test_server().await;
|
|
||||||
|
|
||||||
let expected = json!({
|
|
||||||
"message": "Another dump is already in progress",
|
|
||||||
"errorCode": "dump_already_in_progress",
|
|
||||||
"errorType": "invalid_request_error",
|
|
||||||
"errorLink": "https://docs.meilisearch.com/errors#dump_already_in_progress"
|
|
||||||
});
|
|
||||||
|
|
||||||
let (_, status_code) = server.trigger_dump().await;
|
|
||||||
|
|
||||||
assert_eq!(status_code, 202);
|
|
||||||
|
|
||||||
let (value, status_code) = server.trigger_dump().await;
|
|
||||||
|
|
||||||
|
|
||||||
assert_json_eq!(expected, value, ordered: false);
|
|
||||||
assert_eq!(status_code, 409);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
#[ignore]
|
|
||||||
async fn trigger_dump_concurently_should_return_conflict() {
|
|
||||||
let server = common::Server::test_server().await;
|
|
||||||
|
|
||||||
let expected = json!({
|
|
||||||
"message": "Another dump is already in progress",
|
|
||||||
"errorCode": "dump_already_in_progress",
|
|
||||||
"errorType": "invalid_request_error",
|
|
||||||
"errorLink": "https://docs.meilisearch.com/errors#dump_already_in_progress"
|
|
||||||
});
|
|
||||||
|
|
||||||
let ((_value_1, _status_code_1), (value_2, status_code_2)) = futures::join!(server.trigger_dump(), server.trigger_dump());
|
|
||||||
|
|
||||||
assert_json_eq!(expected, value_2, ordered: false);
|
|
||||||
assert_eq!(status_code_2, 409);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
#[ignore]
|
|
||||||
async fn get_dump_status_early_should_return_in_progress() {
|
|
||||||
let mut server = common::Server::test_server().await;
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
let (value, status_code) = server.trigger_dump().await;
|
|
||||||
|
|
||||||
assert_eq!(status_code, 202);
|
|
||||||
|
|
||||||
let dump_uid = value["uid"].as_str().unwrap().to_string();
|
|
||||||
|
|
||||||
let (value, status_code) = server.get_dump_status(&dump_uid).await;
|
|
||||||
|
|
||||||
let expected = json!({
|
|
||||||
"uid": dump_uid,
|
|
||||||
"status": "in_progress"
|
|
||||||
});
|
|
||||||
|
|
||||||
assert_eq!(status_code, 200);
|
|
||||||
|
|
||||||
assert_json_eq!(expected, value, ordered: false);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
#[ignore]
|
|
||||||
async fn get_dump_status_should_return_done() {
|
|
||||||
let mut server = common::Server::test_server().await;
|
|
||||||
|
|
||||||
|
|
||||||
let (value, status_code) = server.trigger_dump().await;
|
|
||||||
|
|
||||||
assert_eq!(status_code, 202);
|
|
||||||
|
|
||||||
let dump_uid = value["uid"].as_str().unwrap().to_string();
|
|
||||||
|
|
||||||
let expected = json!({
|
|
||||||
"uid": dump_uid.clone(),
|
|
||||||
"status": "done"
|
|
||||||
});
|
|
||||||
|
|
||||||
thread::sleep(Duration::from_secs(1)); // wait dump until process end
|
|
||||||
|
|
||||||
let (value, status_code) = server.get_dump_status(&dump_uid).await;
|
|
||||||
|
|
||||||
assert_eq!(status_code, 200);
|
|
||||||
|
|
||||||
assert_json_eq!(expected, value, ordered: false);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
#[ignore]
|
|
||||||
async fn get_dump_status_should_return_error_provoking_it() {
|
|
||||||
let mut server = common::Server::test_server().await;
|
|
||||||
|
|
||||||
|
|
||||||
let (value, status_code) = server.trigger_dump().await;
|
|
||||||
|
|
||||||
// removing destination directory provoking `No such file or directory` error
|
|
||||||
std::fs::remove_dir(server.data().dumps_dir.clone()).unwrap();
|
|
||||||
|
|
||||||
assert_eq!(status_code, 202);
|
|
||||||
|
|
||||||
let dump_uid = value["uid"].as_str().unwrap().to_string();
|
|
||||||
|
|
||||||
let expected = json!({
|
|
||||||
"uid": dump_uid.clone(),
|
|
||||||
"status": "failed",
|
|
||||||
"message": "Dump process failed: compressing dump; No such file or directory (os error 2)",
|
|
||||||
"errorCode": "dump_process_failed",
|
|
||||||
"errorType": "internal_error",
|
|
||||||
"errorLink": "https://docs.meilisearch.com/errors#dump_process_failed"
|
|
||||||
});
|
|
||||||
|
|
||||||
thread::sleep(Duration::from_secs(1)); // wait dump until process end
|
|
||||||
|
|
||||||
let (value, status_code) = server.get_dump_status(&dump_uid).await;
|
|
||||||
|
|
||||||
assert_eq!(status_code, 200);
|
|
||||||
|
|
||||||
assert_json_eq!(expected, value, ordered: false);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
#[ignore]
|
|
||||||
async fn dump_metadata_should_be_valid() {
|
|
||||||
let mut server = common::Server::test_server().await;
|
|
||||||
|
|
||||||
let body = json!({
|
|
||||||
"uid": "test2",
|
|
||||||
"primaryKey": "test2_id",
|
|
||||||
});
|
|
||||||
|
|
||||||
server.create_index(body).await;
|
|
||||||
|
|
||||||
let uid = trigger_and_wait_dump(&mut server).await;
|
|
||||||
|
|
||||||
let dumps_dir = Path::new(&server.data().dumps_dir);
|
|
||||||
let tmp_dir = TempDir::new().unwrap();
|
|
||||||
let tmp_dir_path = tmp_dir.path();
|
|
||||||
|
|
||||||
compression::from_tar_gz(&dumps_dir.join(&format!("{}.dump", uid)), tmp_dir_path).unwrap();
|
|
||||||
|
|
||||||
let file = File::open(tmp_dir_path.join("metadata.json")).unwrap();
|
|
||||||
let mut metadata: serde_json::Value = serde_json::from_reader(file).unwrap();
|
|
||||||
|
|
||||||
// fields are randomly ordered
|
|
||||||
metadata.get_mut("indexes").unwrap()
|
|
||||||
.as_array_mut().unwrap()
|
|
||||||
.sort_by(|a, b|
|
|
||||||
a.get("uid").unwrap().as_str().cmp(&b.get("uid").unwrap().as_str())
|
|
||||||
);
|
|
||||||
|
|
||||||
let (major, minor, patch) = current_db_version();
|
|
||||||
|
|
||||||
let expected = json!({
|
|
||||||
"indexes": [{
|
|
||||||
"uid": "test",
|
|
||||||
"primaryKey": "id",
|
|
||||||
}, {
|
|
||||||
"uid": "test2",
|
|
||||||
"primaryKey": "test2_id",
|
|
||||||
}
|
|
||||||
],
|
|
||||||
"dbVersion": format!("{}.{}.{}", major, minor, patch),
|
|
||||||
"dumpVersion": current_dump_version()
|
|
||||||
});
|
|
||||||
|
|
||||||
assert_json_include!(expected: expected, actual: metadata);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
#[ignore]
|
|
||||||
async fn dump_gzip_should_have_been_created() {
|
|
||||||
let mut server = common::Server::test_server().await;
|
|
||||||
|
|
||||||
|
|
||||||
let dump_uid = trigger_and_wait_dump(&mut server).await;
|
|
||||||
let dumps_dir = Path::new(&server.data().dumps_dir);
|
|
||||||
|
|
||||||
let compressed_path = dumps_dir.join(format!("{}.dump", dump_uid));
|
|
||||||
assert!(File::open(compressed_path).is_ok());
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
#[ignore]
|
|
||||||
async fn dump_index_settings_should_be_valid() {
|
|
||||||
let mut server = common::Server::test_server().await;
|
|
||||||
|
|
||||||
let expected = json!({
|
|
||||||
"rankingRules": [
|
|
||||||
"typo",
|
|
||||||
"words",
|
|
||||||
"proximity",
|
|
||||||
"attribute",
|
|
||||||
"wordsPosition",
|
|
||||||
"exactness"
|
|
||||||
],
|
|
||||||
"distinctAttribute": "email",
|
|
||||||
"searchableAttributes": [
|
|
||||||
"balance",
|
|
||||||
"picture",
|
|
||||||
"age",
|
|
||||||
"color",
|
|
||||||
"name",
|
|
||||||
"gender",
|
|
||||||
"email",
|
|
||||||
"phone",
|
|
||||||
"address",
|
|
||||||
"about",
|
|
||||||
"registered",
|
|
||||||
"latitude",
|
|
||||||
"longitude",
|
|
||||||
"tags"
|
|
||||||
],
|
|
||||||
"displayedAttributes": [
|
|
||||||
"id",
|
|
||||||
"isActive",
|
|
||||||
"balance",
|
|
||||||
"picture",
|
|
||||||
"age",
|
|
||||||
"color",
|
|
||||||
"name",
|
|
||||||
"gender",
|
|
||||||
"email",
|
|
||||||
"phone",
|
|
||||||
"address",
|
|
||||||
"about",
|
|
||||||
"registered",
|
|
||||||
"latitude",
|
|
||||||
"longitude",
|
|
||||||
"tags"
|
|
||||||
],
|
|
||||||
"stopWords": [
|
|
||||||
"in",
|
|
||||||
"ad"
|
|
||||||
],
|
|
||||||
"synonyms": {
|
|
||||||
"wolverine": ["xmen", "logan"],
|
|
||||||
"logan": ["wolverine", "xmen"]
|
|
||||||
},
|
|
||||||
"attributesForFaceting": [
|
|
||||||
"gender",
|
|
||||||
"color",
|
|
||||||
"tags"
|
|
||||||
]
|
|
||||||
});
|
|
||||||
|
|
||||||
server.update_all_settings(expected.clone()).await;
|
|
||||||
|
|
||||||
let uid = trigger_and_wait_dump(&mut server).await;
|
|
||||||
|
|
||||||
let dumps_dir = Path::new(&server.data().dumps_dir);
|
|
||||||
let tmp_dir = TempDir::new().unwrap();
|
|
||||||
let tmp_dir_path = tmp_dir.path();
|
|
||||||
|
|
||||||
compression::from_tar_gz(&dumps_dir.join(&format!("{}.dump", uid)), tmp_dir_path).unwrap();
|
|
||||||
|
|
||||||
let file = File::open(tmp_dir_path.join("test").join("settings.json")).unwrap();
|
|
||||||
let settings: serde_json::Value = serde_json::from_reader(file).unwrap();
|
|
||||||
|
|
||||||
assert_json_eq!(expected, settings, ordered: false);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
#[ignore]
|
|
||||||
async fn dump_index_documents_should_be_valid() {
|
|
||||||
let mut server = common::Server::test_server().await;
|
|
||||||
|
|
||||||
let dataset = include_bytes!("assets/dumps/v1/test/documents.jsonl");
|
|
||||||
let mut slice: &[u8] = dataset;
|
|
||||||
|
|
||||||
let expected: Value = read_all_jsonline(&mut slice);
|
|
||||||
|
|
||||||
let uid = trigger_and_wait_dump(&mut server).await;
|
|
||||||
|
|
||||||
let dumps_dir = Path::new(&server.data().dumps_dir);
|
|
||||||
let tmp_dir = TempDir::new().unwrap();
|
|
||||||
let tmp_dir_path = tmp_dir.path();
|
|
||||||
|
|
||||||
compression::from_tar_gz(&dumps_dir.join(&format!("{}.dump", uid)), tmp_dir_path).unwrap();
|
|
||||||
|
|
||||||
let file = File::open(tmp_dir_path.join("test").join("documents.jsonl")).unwrap();
|
|
||||||
let documents = read_all_jsonline(file);
|
|
||||||
|
|
||||||
assert_json_eq!(expected, documents, ordered: false);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
#[ignore]
|
|
||||||
async fn dump_index_updates_should_be_valid() {
|
|
||||||
let mut server = common::Server::test_server().await;
|
|
||||||
|
|
||||||
let dataset = include_bytes!("assets/dumps/v1/test/updates.jsonl");
|
|
||||||
let mut slice: &[u8] = dataset;
|
|
||||||
|
|
||||||
let expected: Value = read_all_jsonline(&mut slice);
|
|
||||||
|
|
||||||
let uid = trigger_and_wait_dump(&mut server).await;
|
|
||||||
|
|
||||||
let dumps_dir = Path::new(&server.data().dumps_dir);
|
|
||||||
let tmp_dir = TempDir::new().unwrap();
|
|
||||||
let tmp_dir_path = tmp_dir.path();
|
|
||||||
|
|
||||||
compression::from_tar_gz(&dumps_dir.join(&format!("{}.dump", uid)), tmp_dir_path).unwrap();
|
|
||||||
|
|
||||||
let file = File::open(tmp_dir_path.join("test").join("updates.jsonl")).unwrap();
|
|
||||||
let mut updates = read_all_jsonline(file);
|
|
||||||
|
|
||||||
|
|
||||||
// hotfix until #943 is fixed (https://github.com/meilisearch/MeiliSearch/issues/943)
|
|
||||||
updates.as_array_mut().unwrap()
|
|
||||||
.get_mut(0).unwrap()
|
|
||||||
.get_mut("type").unwrap()
|
|
||||||
.get_mut("settings").unwrap()
|
|
||||||
.get_mut("displayed_attributes").unwrap()
|
|
||||||
.get_mut("Update").unwrap()
|
|
||||||
.as_array_mut().unwrap().sort_by(|a, b| a.as_str().cmp(&b.as_str()));
|
|
||||||
|
|
||||||
eprintln!("{}\n", updates.to_string());
|
|
||||||
eprintln!("{}", expected.to_string());
|
|
||||||
assert_json_include!(expected: expected, actual: updates);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
#[ignore]
|
|
||||||
async fn get_unexisting_dump_status_should_return_not_found() {
|
|
||||||
let mut server = common::Server::test_server().await;
|
|
||||||
|
|
||||||
let (_, status_code) = server.get_dump_status("4242").await;
|
|
||||||
|
|
||||||
assert_eq!(status_code, 404);
|
|
||||||
}
|
|
@ -1,200 +0,0 @@
|
|||||||
mod common;
|
|
||||||
|
|
||||||
use std::thread;
|
|
||||||
use std::time::Duration;
|
|
||||||
|
|
||||||
use actix_http::http::StatusCode;
|
|
||||||
use serde_json::{json, Map, Value};
|
|
||||||
|
|
||||||
macro_rules! assert_error {
|
|
||||||
($code:literal, $type:literal, $status:path, $req:expr) => {
|
|
||||||
let (response, status_code) = $req;
|
|
||||||
assert_eq!(status_code, $status);
|
|
||||||
assert_eq!(response["errorCode"].as_str().unwrap(), $code);
|
|
||||||
assert_eq!(response["errorType"].as_str().unwrap(), $type);
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
macro_rules! assert_error_async {
|
|
||||||
($code:literal, $type:literal, $server:expr, $req:expr) => {
|
|
||||||
let (response, _) = $req;
|
|
||||||
let update_id = response["updateId"].as_u64().unwrap();
|
|
||||||
for _ in 1..10 {
|
|
||||||
let (response, status_code) = $server.get_update_status(update_id).await;
|
|
||||||
assert_eq!(status_code, StatusCode::OK);
|
|
||||||
if response["status"] == "processed" || response["status"] == "failed" {
|
|
||||||
println!("response: {}", response);
|
|
||||||
assert_eq!(response["status"], "failed");
|
|
||||||
assert_eq!(response["errorCode"], $code);
|
|
||||||
assert_eq!(response["errorType"], $type);
|
|
||||||
return
|
|
||||||
}
|
|
||||||
thread::sleep(Duration::from_secs(1));
|
|
||||||
}
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn index_already_exists_error() {
|
|
||||||
let mut server = common::Server::with_uid("test");
|
|
||||||
let body = json!({
|
|
||||||
"uid": "test"
|
|
||||||
});
|
|
||||||
let (response, status_code) = server.create_index(body.clone()).await;
|
|
||||||
println!("{}", response);
|
|
||||||
assert_eq!(status_code, StatusCode::CREATED);
|
|
||||||
|
|
||||||
let (response, status_code) = server.create_index(body.clone()).await;
|
|
||||||
println!("{}", response);
|
|
||||||
|
|
||||||
assert_error!(
|
|
||||||
"index_already_exists",
|
|
||||||
"invalid_request_error",
|
|
||||||
StatusCode::BAD_REQUEST,
|
|
||||||
(response, status_code));
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn index_not_found_error() {
|
|
||||||
let mut server = common::Server::with_uid("test");
|
|
||||||
assert_error!(
|
|
||||||
"index_not_found",
|
|
||||||
"invalid_request_error",
|
|
||||||
StatusCode::NOT_FOUND,
|
|
||||||
server.get_index().await);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn primary_key_already_present_error() {
|
|
||||||
let mut server = common::Server::with_uid("test");
|
|
||||||
let body = json!({
|
|
||||||
"uid": "test",
|
|
||||||
"primaryKey": "test"
|
|
||||||
});
|
|
||||||
server.create_index(body.clone()).await;
|
|
||||||
let body = json!({
|
|
||||||
"primaryKey": "t"
|
|
||||||
});
|
|
||||||
assert_error!(
|
|
||||||
"primary_key_already_present",
|
|
||||||
"invalid_request_error",
|
|
||||||
StatusCode::BAD_REQUEST,
|
|
||||||
server.update_index(body).await);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn max_field_limit_exceeded_error() {
|
|
||||||
let mut server = common::Server::test_server().await;
|
|
||||||
let body = json!({
|
|
||||||
"uid": "test",
|
|
||||||
});
|
|
||||||
server.create_index(body).await;
|
|
||||||
let mut doc = Map::with_capacity(70_000);
|
|
||||||
doc.insert("id".into(), Value::String("foo".into()));
|
|
||||||
for i in 0..69_999 {
|
|
||||||
doc.insert(format!("field{}", i), Value::String("foo".into()));
|
|
||||||
}
|
|
||||||
let docs = json!([doc]);
|
|
||||||
assert_error_async!(
|
|
||||||
"max_fields_limit_exceeded",
|
|
||||||
"invalid_request_error",
|
|
||||||
server,
|
|
||||||
server.add_or_replace_multiple_documents_sync(docs).await);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn missing_document_id() {
|
|
||||||
let mut server = common::Server::test_server().await;
|
|
||||||
let body = json!({
|
|
||||||
"uid": "test",
|
|
||||||
"primaryKey": "test"
|
|
||||||
});
|
|
||||||
server.create_index(body).await;
|
|
||||||
let docs = json!([
|
|
||||||
{
|
|
||||||
"foo": "bar",
|
|
||||||
}
|
|
||||||
]);
|
|
||||||
assert_error_async!(
|
|
||||||
"missing_document_id",
|
|
||||||
"invalid_request_error",
|
|
||||||
server,
|
|
||||||
server.add_or_replace_multiple_documents_sync(docs).await);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn facet_error() {
|
|
||||||
let mut server = common::Server::test_server().await;
|
|
||||||
let search = json!({
|
|
||||||
"q": "foo",
|
|
||||||
"facetFilters": ["test:hello"]
|
|
||||||
});
|
|
||||||
assert_error!(
|
|
||||||
"invalid_facet",
|
|
||||||
"invalid_request_error",
|
|
||||||
StatusCode::BAD_REQUEST,
|
|
||||||
server.search_post(search).await);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn filters_error() {
|
|
||||||
let mut server = common::Server::test_server().await;
|
|
||||||
let search = json!({
|
|
||||||
"q": "foo",
|
|
||||||
"filters": "fo:12"
|
|
||||||
});
|
|
||||||
assert_error!(
|
|
||||||
"invalid_filter",
|
|
||||||
"invalid_request_error",
|
|
||||||
StatusCode::BAD_REQUEST,
|
|
||||||
server.search_post(search).await);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn bad_request_error() {
|
|
||||||
let mut server = common::Server::with_uid("test");
|
|
||||||
let body = json!({
|
|
||||||
"foo": "bar",
|
|
||||||
});
|
|
||||||
assert_error!(
|
|
||||||
"bad_request",
|
|
||||||
"invalid_request_error",
|
|
||||||
StatusCode::BAD_REQUEST,
|
|
||||||
server.search_post(body).await);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn document_not_found_error() {
|
|
||||||
let mut server = common::Server::with_uid("test");
|
|
||||||
server.create_index(json!({"uid": "test"})).await;
|
|
||||||
assert_error!(
|
|
||||||
"document_not_found",
|
|
||||||
"invalid_request_error",
|
|
||||||
StatusCode::NOT_FOUND,
|
|
||||||
server.get_document(100).await);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn payload_too_large_error() {
|
|
||||||
let mut server = common::Server::with_uid("test");
|
|
||||||
let bigvec = vec![0u64; 10_000_000]; // 80mb
|
|
||||||
assert_error!(
|
|
||||||
"payload_too_large",
|
|
||||||
"invalid_request_error",
|
|
||||||
StatusCode::PAYLOAD_TOO_LARGE,
|
|
||||||
server.create_index(json!(bigvec)).await);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn missing_primary_key_error() {
|
|
||||||
let mut server = common::Server::with_uid("test");
|
|
||||||
server.create_index(json!({"uid": "test"})).await;
|
|
||||||
let document = json!([{
|
|
||||||
"content": "test"
|
|
||||||
}]);
|
|
||||||
assert_error!(
|
|
||||||
"missing_primary_key",
|
|
||||||
"invalid_request_error",
|
|
||||||
StatusCode::BAD_REQUEST,
|
|
||||||
server.add_or_replace_multiple_documents_sync(document).await);
|
|
||||||
}
|
|
@ -1,11 +0,0 @@
|
|||||||
mod common;
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn test_healthyness() {
|
|
||||||
let mut server = common::Server::with_uid("movies");
|
|
||||||
|
|
||||||
// Check that the server is healthy
|
|
||||||
|
|
||||||
let (_response, status_code) = server.get_health().await;
|
|
||||||
assert_eq!(status_code, 204);
|
|
||||||
}
|
|
@ -1,809 +0,0 @@
|
|||||||
use actix_web::http::StatusCode;
|
|
||||||
use assert_json_diff::assert_json_eq;
|
|
||||||
use serde_json::{json, Value};
|
|
||||||
|
|
||||||
mod common;
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn create_index_with_name() {
|
|
||||||
let mut server = common::Server::with_uid("movies");
|
|
||||||
|
|
||||||
// 1 - Create a new index
|
|
||||||
|
|
||||||
let body = json!({
|
|
||||||
"name": "movies",
|
|
||||||
});
|
|
||||||
|
|
||||||
let (res1_value, status_code) = server.create_index(body).await;
|
|
||||||
|
|
||||||
assert_eq!(status_code, 201);
|
|
||||||
assert_eq!(res1_value.as_object().unwrap().len(), 5);
|
|
||||||
let r1_name = res1_value["name"].as_str().unwrap();
|
|
||||||
let r1_uid = res1_value["uid"].as_str().unwrap();
|
|
||||||
let r1_created_at = res1_value["createdAt"].as_str().unwrap();
|
|
||||||
let r1_updated_at = res1_value["updatedAt"].as_str().unwrap();
|
|
||||||
assert_eq!(r1_name, "movies");
|
|
||||||
assert_eq!(r1_uid.len(), 8);
|
|
||||||
assert!(r1_created_at.len() > 1);
|
|
||||||
assert!(r1_updated_at.len() > 1);
|
|
||||||
|
|
||||||
// 2 - Check the list of indexes
|
|
||||||
|
|
||||||
let (res2_value, status_code) = server.list_indexes().await;
|
|
||||||
|
|
||||||
assert_eq!(status_code, 200);
|
|
||||||
assert_eq!(res2_value.as_array().unwrap().len(), 1);
|
|
||||||
assert_eq!(res2_value[0].as_object().unwrap().len(), 5);
|
|
||||||
let r2_name = res2_value[0]["name"].as_str().unwrap();
|
|
||||||
let r2_uid = res2_value[0]["uid"].as_str().unwrap();
|
|
||||||
let r2_created_at = res2_value[0]["createdAt"].as_str().unwrap();
|
|
||||||
let r2_updated_at = res2_value[0]["updatedAt"].as_str().unwrap();
|
|
||||||
assert_eq!(r2_name, r1_name);
|
|
||||||
assert_eq!(r2_uid.len(), r1_uid.len());
|
|
||||||
assert_eq!(r2_created_at.len(), r1_created_at.len());
|
|
||||||
assert_eq!(r2_updated_at.len(), r1_updated_at.len());
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn create_index_with_uid() {
|
|
||||||
let mut server = common::Server::with_uid("movies");
|
|
||||||
|
|
||||||
// 1 - Create a new index
|
|
||||||
|
|
||||||
let body = json!({
|
|
||||||
"uid": "movies",
|
|
||||||
});
|
|
||||||
|
|
||||||
let (res1_value, status_code) = server.create_index(body.clone()).await;
|
|
||||||
|
|
||||||
assert_eq!(status_code, 201);
|
|
||||||
assert_eq!(res1_value.as_object().unwrap().len(), 5);
|
|
||||||
let r1_name = res1_value["name"].as_str().unwrap();
|
|
||||||
let r1_uid = res1_value["uid"].as_str().unwrap();
|
|
||||||
let r1_created_at = res1_value["createdAt"].as_str().unwrap();
|
|
||||||
let r1_updated_at = res1_value["updatedAt"].as_str().unwrap();
|
|
||||||
assert_eq!(r1_name, "movies");
|
|
||||||
assert_eq!(r1_uid, "movies");
|
|
||||||
assert!(r1_created_at.len() > 1);
|
|
||||||
assert!(r1_updated_at.len() > 1);
|
|
||||||
|
|
||||||
// 1.5 verify that error is thrown when trying to create the same index
|
|
||||||
|
|
||||||
let (response, status_code) = server.create_index(body).await;
|
|
||||||
|
|
||||||
assert_eq!(status_code, 400);
|
|
||||||
assert_eq!(
|
|
||||||
response["errorCode"].as_str().unwrap(),
|
|
||||||
"index_already_exists"
|
|
||||||
);
|
|
||||||
|
|
||||||
// 2 - Check the list of indexes
|
|
||||||
|
|
||||||
let (res2_value, status_code) = server.list_indexes().await;
|
|
||||||
|
|
||||||
assert_eq!(status_code, 200);
|
|
||||||
assert_eq!(res2_value.as_array().unwrap().len(), 1);
|
|
||||||
assert_eq!(res2_value[0].as_object().unwrap().len(), 5);
|
|
||||||
let r2_name = res2_value[0]["name"].as_str().unwrap();
|
|
||||||
let r2_uid = res2_value[0]["uid"].as_str().unwrap();
|
|
||||||
let r2_created_at = res2_value[0]["createdAt"].as_str().unwrap();
|
|
||||||
let r2_updated_at = res2_value[0]["updatedAt"].as_str().unwrap();
|
|
||||||
assert_eq!(r2_name, r1_name);
|
|
||||||
assert_eq!(r2_uid, r1_uid);
|
|
||||||
assert_eq!(r2_created_at.len(), r1_created_at.len());
|
|
||||||
assert_eq!(r2_updated_at.len(), r1_updated_at.len());
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn create_index_with_name_and_uid() {
|
|
||||||
let mut server = common::Server::with_uid("movies");
|
|
||||||
|
|
||||||
// 1 - Create a new index
|
|
||||||
|
|
||||||
let body = json!({
|
|
||||||
"name": "Films",
|
|
||||||
"uid": "fr_movies",
|
|
||||||
});
|
|
||||||
let (res1_value, status_code) = server.create_index(body).await;
|
|
||||||
|
|
||||||
assert_eq!(status_code, 201);
|
|
||||||
assert_eq!(res1_value.as_object().unwrap().len(), 5);
|
|
||||||
let r1_name = res1_value["name"].as_str().unwrap();
|
|
||||||
let r1_uid = res1_value["uid"].as_str().unwrap();
|
|
||||||
let r1_created_at = res1_value["createdAt"].as_str().unwrap();
|
|
||||||
let r1_updated_at = res1_value["updatedAt"].as_str().unwrap();
|
|
||||||
assert_eq!(r1_name, "Films");
|
|
||||||
assert_eq!(r1_uid, "fr_movies");
|
|
||||||
assert!(r1_created_at.len() > 1);
|
|
||||||
assert!(r1_updated_at.len() > 1);
|
|
||||||
|
|
||||||
// 2 - Check the list of indexes
|
|
||||||
|
|
||||||
let (res2_value, status_code) = server.list_indexes().await;
|
|
||||||
|
|
||||||
assert_eq!(status_code, 200);
|
|
||||||
assert_eq!(res2_value.as_array().unwrap().len(), 1);
|
|
||||||
assert_eq!(res2_value[0].as_object().unwrap().len(), 5);
|
|
||||||
let r2_name = res2_value[0]["name"].as_str().unwrap();
|
|
||||||
let r2_uid = res2_value[0]["uid"].as_str().unwrap();
|
|
||||||
let r2_created_at = res2_value[0]["createdAt"].as_str().unwrap();
|
|
||||||
let r2_updated_at = res2_value[0]["updatedAt"].as_str().unwrap();
|
|
||||||
assert_eq!(r2_name, r1_name);
|
|
||||||
assert_eq!(r2_uid, r1_uid);
|
|
||||||
assert_eq!(r2_created_at.len(), r1_created_at.len());
|
|
||||||
assert_eq!(r2_updated_at.len(), r1_updated_at.len());
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn rename_index() {
|
|
||||||
let mut server = common::Server::with_uid("movies");
|
|
||||||
|
|
||||||
// 1 - Create a new index
|
|
||||||
|
|
||||||
let body = json!({
|
|
||||||
"name": "movies",
|
|
||||||
"uid": "movies",
|
|
||||||
});
|
|
||||||
|
|
||||||
let (res1_value, status_code) = server.create_index(body).await;
|
|
||||||
|
|
||||||
assert_eq!(status_code, 201);
|
|
||||||
assert_eq!(res1_value.as_object().unwrap().len(), 5);
|
|
||||||
let r1_name = res1_value["name"].as_str().unwrap();
|
|
||||||
let r1_uid = res1_value["uid"].as_str().unwrap();
|
|
||||||
let r1_created_at = res1_value["createdAt"].as_str().unwrap();
|
|
||||||
let r1_updated_at = res1_value["updatedAt"].as_str().unwrap();
|
|
||||||
assert_eq!(r1_name, "movies");
|
|
||||||
assert_eq!(r1_uid.len(), 6);
|
|
||||||
assert!(r1_created_at.len() > 1);
|
|
||||||
assert!(r1_updated_at.len() > 1);
|
|
||||||
|
|
||||||
// 2 - Update an index name
|
|
||||||
|
|
||||||
let body = json!({
|
|
||||||
"name": "TV Shows",
|
|
||||||
});
|
|
||||||
|
|
||||||
let (res2_value, status_code) = server.update_index(body).await;
|
|
||||||
|
|
||||||
assert_eq!(status_code, 200);
|
|
||||||
assert_eq!(res2_value.as_object().unwrap().len(), 5);
|
|
||||||
let r2_name = res2_value["name"].as_str().unwrap();
|
|
||||||
let r2_uid = res2_value["uid"].as_str().unwrap();
|
|
||||||
let r2_created_at = res2_value["createdAt"].as_str().unwrap();
|
|
||||||
let r2_updated_at = res2_value["updatedAt"].as_str().unwrap();
|
|
||||||
assert_eq!(r2_name, "TV Shows");
|
|
||||||
assert_eq!(r2_uid, r1_uid);
|
|
||||||
assert_eq!(r2_created_at, r1_created_at);
|
|
||||||
assert!(r2_updated_at.len() > 1);
|
|
||||||
|
|
||||||
// 3 - Check the list of indexes
|
|
||||||
|
|
||||||
let (res3_value, status_code) = server.list_indexes().await;
|
|
||||||
|
|
||||||
assert_eq!(status_code, 200);
|
|
||||||
assert_eq!(res3_value.as_array().unwrap().len(), 1);
|
|
||||||
assert_eq!(res3_value[0].as_object().unwrap().len(), 5);
|
|
||||||
let r3_name = res3_value[0]["name"].as_str().unwrap();
|
|
||||||
let r3_uid = res3_value[0]["uid"].as_str().unwrap();
|
|
||||||
let r3_created_at = res3_value[0]["createdAt"].as_str().unwrap();
|
|
||||||
let r3_updated_at = res3_value[0]["updatedAt"].as_str().unwrap();
|
|
||||||
assert_eq!(r3_name, r2_name);
|
|
||||||
assert_eq!(r3_uid.len(), r1_uid.len());
|
|
||||||
assert_eq!(r3_created_at.len(), r1_created_at.len());
|
|
||||||
assert_eq!(r3_updated_at.len(), r2_updated_at.len());
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn delete_index_and_recreate_it() {
|
|
||||||
let mut server = common::Server::with_uid("movies");
|
|
||||||
|
|
||||||
// 0 - delete unexisting index is error
|
|
||||||
|
|
||||||
let (response, status_code) = server.delete_request("/indexes/test").await;
|
|
||||||
assert_eq!(status_code, 404);
|
|
||||||
assert_eq!(&response["errorCode"], "index_not_found");
|
|
||||||
|
|
||||||
// 1 - Create a new index
|
|
||||||
|
|
||||||
let body = json!({
|
|
||||||
"name": "movies",
|
|
||||||
"uid": "movies",
|
|
||||||
});
|
|
||||||
|
|
||||||
let (res1_value, status_code) = server.create_index(body).await;
|
|
||||||
|
|
||||||
assert_eq!(status_code, 201);
|
|
||||||
assert_eq!(res1_value.as_object().unwrap().len(), 5);
|
|
||||||
let r1_name = res1_value["name"].as_str().unwrap();
|
|
||||||
let r1_uid = res1_value["uid"].as_str().unwrap();
|
|
||||||
let r1_created_at = res1_value["createdAt"].as_str().unwrap();
|
|
||||||
let r1_updated_at = res1_value["updatedAt"].as_str().unwrap();
|
|
||||||
assert_eq!(r1_name, "movies");
|
|
||||||
assert_eq!(r1_uid.len(), 6);
|
|
||||||
assert!(r1_created_at.len() > 1);
|
|
||||||
assert!(r1_updated_at.len() > 1);
|
|
||||||
|
|
||||||
// 2 - Check the list of indexes
|
|
||||||
|
|
||||||
let (res2_value, status_code) = server.list_indexes().await;
|
|
||||||
|
|
||||||
assert_eq!(status_code, 200);
|
|
||||||
assert_eq!(res2_value.as_array().unwrap().len(), 1);
|
|
||||||
assert_eq!(res2_value[0].as_object().unwrap().len(), 5);
|
|
||||||
let r2_name = res2_value[0]["name"].as_str().unwrap();
|
|
||||||
let r2_uid = res2_value[0]["uid"].as_str().unwrap();
|
|
||||||
let r2_created_at = res2_value[0]["createdAt"].as_str().unwrap();
|
|
||||||
let r2_updated_at = res2_value[0]["updatedAt"].as_str().unwrap();
|
|
||||||
assert_eq!(r2_name, r1_name);
|
|
||||||
assert_eq!(r2_uid.len(), r1_uid.len());
|
|
||||||
assert_eq!(r2_created_at.len(), r1_created_at.len());
|
|
||||||
assert_eq!(r2_updated_at.len(), r1_updated_at.len());
|
|
||||||
|
|
||||||
// 3- Delete an index
|
|
||||||
|
|
||||||
let (_res2_value, status_code) = server.delete_index().await;
|
|
||||||
|
|
||||||
assert_eq!(status_code, 204);
|
|
||||||
|
|
||||||
// 4 - Check the list of indexes
|
|
||||||
|
|
||||||
let (res2_value, status_code) = server.list_indexes().await;
|
|
||||||
|
|
||||||
assert_eq!(status_code, 200);
|
|
||||||
assert_eq!(res2_value.as_array().unwrap().len(), 0);
|
|
||||||
|
|
||||||
// 5 - Create a new index
|
|
||||||
|
|
||||||
let body = json!({
|
|
||||||
"name": "movies",
|
|
||||||
});
|
|
||||||
|
|
||||||
let (res1_value, status_code) = server.create_index(body).await;
|
|
||||||
|
|
||||||
assert_eq!(status_code, 201);
|
|
||||||
assert_eq!(res1_value.as_object().unwrap().len(), 5);
|
|
||||||
let r1_name = res1_value["name"].as_str().unwrap();
|
|
||||||
let r1_uid = res1_value["uid"].as_str().unwrap();
|
|
||||||
let r1_created_at = res1_value["createdAt"].as_str().unwrap();
|
|
||||||
let r1_updated_at = res1_value["updatedAt"].as_str().unwrap();
|
|
||||||
assert_eq!(r1_name, "movies");
|
|
||||||
assert_eq!(r1_uid.len(), 8);
|
|
||||||
assert!(r1_created_at.len() > 1);
|
|
||||||
assert!(r1_updated_at.len() > 1);
|
|
||||||
|
|
||||||
// 6 - Check the list of indexes
|
|
||||||
|
|
||||||
let (res2_value, status_code) = server.list_indexes().await;
|
|
||||||
assert_eq!(status_code, 200);
|
|
||||||
assert_eq!(res2_value.as_array().unwrap().len(), 1);
|
|
||||||
assert_eq!(res2_value[0].as_object().unwrap().len(), 5);
|
|
||||||
let r2_name = res2_value[0]["name"].as_str().unwrap();
|
|
||||||
let r2_uid = res2_value[0]["uid"].as_str().unwrap();
|
|
||||||
let r2_created_at = res2_value[0]["createdAt"].as_str().unwrap();
|
|
||||||
let r2_updated_at = res2_value[0]["updatedAt"].as_str().unwrap();
|
|
||||||
assert_eq!(r2_name, r1_name);
|
|
||||||
assert_eq!(r2_uid.len(), r1_uid.len());
|
|
||||||
assert_eq!(r2_created_at.len(), r1_created_at.len());
|
|
||||||
assert_eq!(r2_updated_at.len(), r1_updated_at.len());
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn check_multiples_indexes() {
|
|
||||||
let mut server = common::Server::with_uid("movies");
|
|
||||||
|
|
||||||
// 1 - Create a new index
|
|
||||||
|
|
||||||
let body = json!({
|
|
||||||
"name": "movies",
|
|
||||||
});
|
|
||||||
|
|
||||||
let (res1_value, status_code) = server.create_index(body).await;
|
|
||||||
|
|
||||||
assert_eq!(status_code, 201);
|
|
||||||
assert_eq!(res1_value.as_object().unwrap().len(), 5);
|
|
||||||
let r1_name = res1_value["name"].as_str().unwrap();
|
|
||||||
let r1_uid = res1_value["uid"].as_str().unwrap();
|
|
||||||
let r1_created_at = res1_value["createdAt"].as_str().unwrap();
|
|
||||||
let r1_updated_at = res1_value["updatedAt"].as_str().unwrap();
|
|
||||||
assert_eq!(r1_name, "movies");
|
|
||||||
assert_eq!(r1_uid.len(), 8);
|
|
||||||
assert!(r1_created_at.len() > 1);
|
|
||||||
assert!(r1_updated_at.len() > 1);
|
|
||||||
|
|
||||||
// 2 - Check the list of indexes
|
|
||||||
|
|
||||||
let (res2_value, status_code) = server.list_indexes().await;
|
|
||||||
|
|
||||||
assert_eq!(status_code, 200);
|
|
||||||
assert_eq!(res2_value.as_array().unwrap().len(), 1);
|
|
||||||
assert_eq!(res2_value[0].as_object().unwrap().len(), 5);
|
|
||||||
let r2_0_name = res2_value[0]["name"].as_str().unwrap();
|
|
||||||
let r2_0_uid = res2_value[0]["uid"].as_str().unwrap();
|
|
||||||
let r2_0_created_at = res2_value[0]["createdAt"].as_str().unwrap();
|
|
||||||
let r2_0_updated_at = res2_value[0]["updatedAt"].as_str().unwrap();
|
|
||||||
assert_eq!(r2_0_name, r1_name);
|
|
||||||
assert_eq!(r2_0_uid.len(), r1_uid.len());
|
|
||||||
assert_eq!(r2_0_created_at.len(), r1_created_at.len());
|
|
||||||
assert_eq!(r2_0_updated_at.len(), r1_updated_at.len());
|
|
||||||
|
|
||||||
// 3 - Create a new index
|
|
||||||
|
|
||||||
let body = json!({
|
|
||||||
"name": "films",
|
|
||||||
});
|
|
||||||
|
|
||||||
let (res3_value, status_code) = server.create_index(body).await;
|
|
||||||
|
|
||||||
assert_eq!(status_code, 201);
|
|
||||||
assert_eq!(res3_value.as_object().unwrap().len(), 5);
|
|
||||||
let r3_name = res3_value["name"].as_str().unwrap();
|
|
||||||
let r3_uid = res3_value["uid"].as_str().unwrap();
|
|
||||||
let r3_created_at = res3_value["createdAt"].as_str().unwrap();
|
|
||||||
let r3_updated_at = res3_value["updatedAt"].as_str().unwrap();
|
|
||||||
assert_eq!(r3_name, "films");
|
|
||||||
assert_eq!(r3_uid.len(), 8);
|
|
||||||
assert!(r3_created_at.len() > 1);
|
|
||||||
assert!(r3_updated_at.len() > 1);
|
|
||||||
|
|
||||||
// 4 - Check the list of indexes
|
|
||||||
|
|
||||||
let (res4_value, status_code) = server.list_indexes().await;
|
|
||||||
|
|
||||||
assert_eq!(status_code, 200);
|
|
||||||
assert_eq!(res4_value.as_array().unwrap().len(), 2);
|
|
||||||
assert_eq!(res4_value[0].as_object().unwrap().len(), 5);
|
|
||||||
let r4_0_name = res4_value[0]["name"].as_str().unwrap();
|
|
||||||
let r4_0_uid = res4_value[0]["uid"].as_str().unwrap();
|
|
||||||
let r4_0_created_at = res4_value[0]["createdAt"].as_str().unwrap();
|
|
||||||
let r4_0_updated_at = res4_value[0]["updatedAt"].as_str().unwrap();
|
|
||||||
assert_eq!(res4_value[1].as_object().unwrap().len(), 5);
|
|
||||||
let r4_1_name = res4_value[1]["name"].as_str().unwrap();
|
|
||||||
let r4_1_uid = res4_value[1]["uid"].as_str().unwrap();
|
|
||||||
let r4_1_created_at = res4_value[1]["createdAt"].as_str().unwrap();
|
|
||||||
let r4_1_updated_at = res4_value[1]["updatedAt"].as_str().unwrap();
|
|
||||||
if r4_0_name == r1_name {
|
|
||||||
assert_eq!(r4_0_name, r1_name);
|
|
||||||
assert_eq!(r4_0_uid.len(), r1_uid.len());
|
|
||||||
assert_eq!(r4_0_created_at.len(), r1_created_at.len());
|
|
||||||
assert_eq!(r4_0_updated_at.len(), r1_updated_at.len());
|
|
||||||
} else {
|
|
||||||
assert_eq!(r4_0_name, r3_name);
|
|
||||||
assert_eq!(r4_0_uid.len(), r3_uid.len());
|
|
||||||
assert_eq!(r4_0_created_at.len(), r3_created_at.len());
|
|
||||||
assert_eq!(r4_0_updated_at.len(), r3_updated_at.len());
|
|
||||||
}
|
|
||||||
if r4_1_name == r1_name {
|
|
||||||
assert_eq!(r4_1_name, r1_name);
|
|
||||||
assert_eq!(r4_1_uid.len(), r1_uid.len());
|
|
||||||
assert_eq!(r4_1_created_at.len(), r1_created_at.len());
|
|
||||||
assert_eq!(r4_1_updated_at.len(), r1_updated_at.len());
|
|
||||||
} else {
|
|
||||||
assert_eq!(r4_1_name, r3_name);
|
|
||||||
assert_eq!(r4_1_uid.len(), r3_uid.len());
|
|
||||||
assert_eq!(r4_1_created_at.len(), r3_created_at.len());
|
|
||||||
assert_eq!(r4_1_updated_at.len(), r3_updated_at.len());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn create_index_failed() {
|
|
||||||
let mut server = common::Server::with_uid("movies");
|
|
||||||
|
|
||||||
// 2 - Push index creation with empty json body
|
|
||||||
|
|
||||||
let body = json!({});
|
|
||||||
|
|
||||||
let (res_value, status_code) = server.create_index(body).await;
|
|
||||||
|
|
||||||
assert_eq!(status_code, 400);
|
|
||||||
let message = res_value["message"].as_str().unwrap();
|
|
||||||
assert_eq!(res_value.as_object().unwrap().len(), 4);
|
|
||||||
assert_eq!(message, "Index creation must have an uid");
|
|
||||||
|
|
||||||
// 3 - Create a index with extra data
|
|
||||||
|
|
||||||
let body = json!({
|
|
||||||
"name": "movies",
|
|
||||||
"active": true
|
|
||||||
});
|
|
||||||
|
|
||||||
let (_res_value, status_code) = server.create_index(body).await;
|
|
||||||
|
|
||||||
assert_eq!(status_code, 400);
|
|
||||||
|
|
||||||
// 3 - Create a index with wrong data type
|
|
||||||
|
|
||||||
let body = json!({
|
|
||||||
"name": "movies",
|
|
||||||
"uid": 0
|
|
||||||
});
|
|
||||||
|
|
||||||
let (_res_value, status_code) = server.create_index(body).await;
|
|
||||||
|
|
||||||
assert_eq!(status_code, 400);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Resolve issue https://github.com/meilisearch/MeiliSearch/issues/492
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn create_index_with_primary_key_and_index() {
|
|
||||||
let mut server = common::Server::with_uid("movies");
|
|
||||||
|
|
||||||
// 1 - Create the index
|
|
||||||
|
|
||||||
let body = json!({
|
|
||||||
"uid": "movies",
|
|
||||||
"primaryKey": "id",
|
|
||||||
});
|
|
||||||
|
|
||||||
let (_response, status_code) = server.create_index(body).await;
|
|
||||||
assert_eq!(status_code, 201);
|
|
||||||
|
|
||||||
// 2 - Add content
|
|
||||||
|
|
||||||
let body = json!([{
|
|
||||||
"id": 123,
|
|
||||||
"text": "The mask"
|
|
||||||
}]);
|
|
||||||
|
|
||||||
server.add_or_replace_multiple_documents(body.clone()).await;
|
|
||||||
|
|
||||||
// 3 - Retreive document
|
|
||||||
|
|
||||||
let (response, _status_code) = server.get_document(123).await;
|
|
||||||
|
|
||||||
let expect = json!({
|
|
||||||
"id": 123,
|
|
||||||
"text": "The mask"
|
|
||||||
});
|
|
||||||
|
|
||||||
assert_json_eq!(response, expect, ordered: false);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Resolve issue https://github.com/meilisearch/MeiliSearch/issues/497
|
|
||||||
// Test when the given index uid is not valid
|
|
||||||
// Should have a 400 status code
|
|
||||||
// Should have the right error message
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn create_index_with_invalid_uid() {
|
|
||||||
let mut server = common::Server::with_uid("");
|
|
||||||
|
|
||||||
// 1 - Create the index with invalid uid
|
|
||||||
|
|
||||||
let body = json!({
|
|
||||||
"uid": "the movies"
|
|
||||||
});
|
|
||||||
|
|
||||||
let (response, status_code) = server.create_index(body).await;
|
|
||||||
|
|
||||||
assert_eq!(status_code, 400);
|
|
||||||
let message = response["message"].as_str().unwrap();
|
|
||||||
assert_eq!(response.as_object().unwrap().len(), 4);
|
|
||||||
assert_eq!(message, "Index must have a valid uid; Index uid can be of type integer or string only composed of alphanumeric characters, hyphens (-) and underscores (_).");
|
|
||||||
|
|
||||||
// 2 - Create the index with invalid uid
|
|
||||||
|
|
||||||
let body = json!({
|
|
||||||
"uid": "%$#"
|
|
||||||
});
|
|
||||||
|
|
||||||
let (response, status_code) = server.create_index(body).await;
|
|
||||||
|
|
||||||
assert_eq!(status_code, 400);
|
|
||||||
let message = response["message"].as_str().unwrap();
|
|
||||||
assert_eq!(response.as_object().unwrap().len(), 4);
|
|
||||||
assert_eq!(message, "Index must have a valid uid; Index uid can be of type integer or string only composed of alphanumeric characters, hyphens (-) and underscores (_).");
|
|
||||||
|
|
||||||
// 3 - Create the index with invalid uid
|
|
||||||
|
|
||||||
let body = json!({
|
|
||||||
"uid": "the~movies"
|
|
||||||
});
|
|
||||||
|
|
||||||
let (response, status_code) = server.create_index(body).await;
|
|
||||||
|
|
||||||
assert_eq!(status_code, 400);
|
|
||||||
let message = response["message"].as_str().unwrap();
|
|
||||||
assert_eq!(response.as_object().unwrap().len(), 4);
|
|
||||||
assert_eq!(message, "Index must have a valid uid; Index uid can be of type integer or string only composed of alphanumeric characters, hyphens (-) and underscores (_).");
|
|
||||||
|
|
||||||
// 4 - Create the index with invalid uid
|
|
||||||
|
|
||||||
let body = json!({
|
|
||||||
"uid": "🎉"
|
|
||||||
});
|
|
||||||
|
|
||||||
let (response, status_code) = server.create_index(body).await;
|
|
||||||
|
|
||||||
assert_eq!(status_code, 400);
|
|
||||||
let message = response["message"].as_str().unwrap();
|
|
||||||
assert_eq!(response.as_object().unwrap().len(), 4);
|
|
||||||
assert_eq!(message, "Index must have a valid uid; Index uid can be of type integer or string only composed of alphanumeric characters, hyphens (-) and underscores (_).");
|
|
||||||
}
|
|
||||||
|
|
||||||
// Test that it's possible to add primary_key if it's not already set on index creation
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn create_index_and_add_indentifier_after() {
|
|
||||||
let mut server = common::Server::with_uid("movies");
|
|
||||||
|
|
||||||
// 1 - Create the index with no primary_key
|
|
||||||
|
|
||||||
let body = json!({
|
|
||||||
"uid": "movies",
|
|
||||||
});
|
|
||||||
let (response, status_code) = server.create_index(body).await;
|
|
||||||
assert_eq!(status_code, 201);
|
|
||||||
assert_eq!(response["primaryKey"], json!(null));
|
|
||||||
|
|
||||||
// 2 - Update the index and add an primary_key.
|
|
||||||
|
|
||||||
let body = json!({
|
|
||||||
"primaryKey": "id",
|
|
||||||
});
|
|
||||||
|
|
||||||
let (response, status_code) = server.update_index(body).await;
|
|
||||||
assert_eq!(status_code, 200);
|
|
||||||
eprintln!("response: {:#?}", response);
|
|
||||||
assert_eq!(response["primaryKey"].as_str().unwrap(), "id");
|
|
||||||
|
|
||||||
// 3 - Get index to verify if the primary_key is good
|
|
||||||
|
|
||||||
let (response, status_code) = server.get_index().await;
|
|
||||||
assert_eq!(status_code, 200);
|
|
||||||
assert_eq!(response["primaryKey"].as_str().unwrap(), "id");
|
|
||||||
}
|
|
||||||
|
|
||||||
// Test that it's impossible to change the primary_key
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn create_index_and_update_indentifier_after() {
|
|
||||||
let mut server = common::Server::with_uid("movies");
|
|
||||||
|
|
||||||
// 1 - Create the index with no primary_key
|
|
||||||
|
|
||||||
let body = json!({
|
|
||||||
"uid": "movies",
|
|
||||||
"primaryKey": "id",
|
|
||||||
});
|
|
||||||
let (response, status_code) = server.create_index(body).await;
|
|
||||||
assert_eq!(status_code, 201);
|
|
||||||
assert_eq!(response["primaryKey"].as_str().unwrap(), "id");
|
|
||||||
|
|
||||||
// 2 - Update the index and add an primary_key.
|
|
||||||
|
|
||||||
let body = json!({
|
|
||||||
"primaryKey": "skuid",
|
|
||||||
});
|
|
||||||
|
|
||||||
let (_response, status_code) = server.update_index(body).await;
|
|
||||||
assert_eq!(status_code, 400);
|
|
||||||
|
|
||||||
// 3 - Get index to verify if the primary_key still the first one
|
|
||||||
|
|
||||||
let (response, status_code) = server.get_index().await;
|
|
||||||
assert_eq!(status_code, 200);
|
|
||||||
assert_eq!(response["primaryKey"].as_str().unwrap(), "id");
|
|
||||||
}
|
|
||||||
|
|
||||||
// Test that schema inference work well
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn create_index_without_primary_key_and_add_document() {
|
|
||||||
let mut server = common::Server::with_uid("movies");
|
|
||||||
|
|
||||||
// 1 - Create the index with no primary_key
|
|
||||||
|
|
||||||
let body = json!({
|
|
||||||
"uid": "movies",
|
|
||||||
});
|
|
||||||
let (response, status_code) = server.create_index(body).await;
|
|
||||||
assert_eq!(status_code, 201);
|
|
||||||
assert_eq!(response["primaryKey"], json!(null));
|
|
||||||
|
|
||||||
// 2 - Add a document
|
|
||||||
|
|
||||||
let body = json!([{
|
|
||||||
"id": 123,
|
|
||||||
"title": "I'm a legend",
|
|
||||||
}]);
|
|
||||||
|
|
||||||
server.add_or_update_multiple_documents(body).await;
|
|
||||||
|
|
||||||
// 3 - Get index to verify if the primary_key is good
|
|
||||||
|
|
||||||
let (response, status_code) = server.get_index().await;
|
|
||||||
assert_eq!(status_code, 200);
|
|
||||||
assert_eq!(response["primaryKey"].as_str().unwrap(), "id");
|
|
||||||
}
|
|
||||||
|
|
||||||
// Test search with no primary_key
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn create_index_without_primary_key_and_search() {
|
|
||||||
let mut server = common::Server::with_uid("movies");
|
|
||||||
|
|
||||||
// 1 - Create the index with no primary_key
|
|
||||||
|
|
||||||
let body = json!({
|
|
||||||
"uid": "movies",
|
|
||||||
});
|
|
||||||
let (response, status_code) = server.create_index(body).await;
|
|
||||||
assert_eq!(status_code, 201);
|
|
||||||
assert_eq!(response["primaryKey"], json!(null));
|
|
||||||
|
|
||||||
// 2 - Search
|
|
||||||
|
|
||||||
let query = "q=captain&limit=3";
|
|
||||||
|
|
||||||
let (response, status_code) = server.search_get(&query).await;
|
|
||||||
assert_eq!(status_code, 200);
|
|
||||||
assert_eq!(response["hits"].as_array().unwrap().len(), 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Test the error message when we push an document update and impossibility to find primary key
|
|
||||||
// Test issue https://github.com/meilisearch/MeiliSearch/issues/517
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn check_add_documents_without_primary_key() {
|
|
||||||
let mut server = common::Server::with_uid("movies");
|
|
||||||
|
|
||||||
// 1 - Create the index with no primary_key
|
|
||||||
|
|
||||||
let body = json!({
|
|
||||||
"uid": "movies",
|
|
||||||
});
|
|
||||||
let (response, status_code) = server.create_index(body).await;
|
|
||||||
assert_eq!(status_code, 201);
|
|
||||||
assert_eq!(response["primaryKey"], json!(null));
|
|
||||||
|
|
||||||
// 2- Add document
|
|
||||||
|
|
||||||
let body = json!([{
|
|
||||||
"title": "Test",
|
|
||||||
"comment": "comment test"
|
|
||||||
}]);
|
|
||||||
|
|
||||||
let (response, status_code) = server.add_or_replace_multiple_documents_sync(body).await;
|
|
||||||
|
|
||||||
assert_eq!(response.as_object().unwrap().len(), 4);
|
|
||||||
assert_eq!(response["errorCode"], "missing_primary_key");
|
|
||||||
assert_eq!(status_code, 400);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn check_first_update_should_bring_up_processed_status_after_first_docs_addition() {
|
|
||||||
let mut server = common::Server::with_uid("movies");
|
|
||||||
|
|
||||||
let body = json!({
|
|
||||||
"uid": "movies",
|
|
||||||
});
|
|
||||||
|
|
||||||
// 1. Create Index
|
|
||||||
let (response, status_code) = server.create_index(body).await;
|
|
||||||
assert_eq!(status_code, 201);
|
|
||||||
assert_eq!(response["primaryKey"], json!(null));
|
|
||||||
|
|
||||||
let dataset = include_bytes!("./assets/test_set.json");
|
|
||||||
|
|
||||||
let body: Value = serde_json::from_slice(dataset).unwrap();
|
|
||||||
|
|
||||||
// 2. Index the documents from movies.json, present inside of assets directory
|
|
||||||
server.add_or_replace_multiple_documents(body).await;
|
|
||||||
|
|
||||||
// 3. Fetch the status of the indexing done above.
|
|
||||||
let (response, status_code) = server.get_all_updates_status().await;
|
|
||||||
|
|
||||||
// 4. Verify the fetch is successful and indexing status is 'processed'
|
|
||||||
assert_eq!(status_code, 200);
|
|
||||||
assert_eq!(response[0]["status"], "processed");
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn get_empty_index() {
|
|
||||||
let mut server = common::Server::with_uid("test");
|
|
||||||
let (response, _status) = server.list_indexes().await;
|
|
||||||
assert!(response.as_array().unwrap().is_empty());
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn create_and_list_multiple_indices() {
|
|
||||||
let mut server = common::Server::with_uid("test");
|
|
||||||
for i in 0..10 {
|
|
||||||
server
|
|
||||||
.create_index(json!({ "uid": format!("test{}", i) }))
|
|
||||||
.await;
|
|
||||||
}
|
|
||||||
let (response, _status) = server.list_indexes().await;
|
|
||||||
assert_eq!(response.as_array().unwrap().len(), 10);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn get_unexisting_index_is_error() {
|
|
||||||
let mut server = common::Server::with_uid("test");
|
|
||||||
let (response, status) = server.get_index().await;
|
|
||||||
assert_eq!(status, StatusCode::NOT_FOUND);
|
|
||||||
assert_eq!(response["errorCode"], "index_not_found");
|
|
||||||
assert_eq!(response["errorType"], "invalid_request_error");
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn create_index_twice_is_error() {
|
|
||||||
let mut server = common::Server::with_uid("test");
|
|
||||||
server.create_index(json!({ "uid": "test" })).await;
|
|
||||||
let (response, status) = server.create_index(json!({ "uid": "test" })).await;
|
|
||||||
assert_eq!(status, StatusCode::BAD_REQUEST);
|
|
||||||
assert_eq!(response["errorCode"], "index_already_exists");
|
|
||||||
assert_eq!(response["errorType"], "invalid_request_error");
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn badly_formatted_index_name_is_error() {
|
|
||||||
let mut server = common::Server::with_uid("$__test");
|
|
||||||
let (response, status) = server.create_index(json!({ "uid": "$__test" })).await;
|
|
||||||
assert_eq!(status, StatusCode::BAD_REQUEST);
|
|
||||||
assert_eq!(response["errorCode"], "invalid_index_uid");
|
|
||||||
assert_eq!(response["errorType"], "invalid_request_error");
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn correct_response_no_primary_key_index() {
|
|
||||||
let mut server = common::Server::with_uid("test");
|
|
||||||
let (response, _status) = server.create_index(json!({ "uid": "test" })).await;
|
|
||||||
assert_eq!(response["primaryKey"], Value::Null);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn correct_response_with_primary_key_index() {
|
|
||||||
let mut server = common::Server::with_uid("test");
|
|
||||||
let (response, _status) = server
|
|
||||||
.create_index(json!({ "uid": "test", "primaryKey": "test" }))
|
|
||||||
.await;
|
|
||||||
assert_eq!(response["primaryKey"], "test");
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn udpate_unexisting_index_is_error() {
|
|
||||||
let mut server = common::Server::with_uid("test");
|
|
||||||
let (response, status) = server.update_index(json!({ "primaryKey": "foobar" })).await;
|
|
||||||
assert_eq!(status, StatusCode::NOT_FOUND);
|
|
||||||
assert_eq!(response["errorCode"], "index_not_found");
|
|
||||||
assert_eq!(response["errorType"], "invalid_request_error");
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn update_existing_primary_key_is_error() {
|
|
||||||
let mut server = common::Server::with_uid("test");
|
|
||||||
server
|
|
||||||
.create_index(json!({ "uid": "test", "primaryKey": "key" }))
|
|
||||||
.await;
|
|
||||||
let (response, status) = server.update_index(json!({ "primaryKey": "test2" })).await;
|
|
||||||
assert_eq!(status, StatusCode::BAD_REQUEST);
|
|
||||||
assert_eq!(response["errorCode"], "primary_key_already_present");
|
|
||||||
assert_eq!(response["errorType"], "invalid_request_error");
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn test_facets_distribution_attribute() {
|
|
||||||
let mut server = common::Server::test_server().await;
|
|
||||||
|
|
||||||
let (response, _status_code) = server.get_index_stats().await;
|
|
||||||
|
|
||||||
let expected = json!({
|
|
||||||
"isIndexing": false,
|
|
||||||
"numberOfDocuments":77,
|
|
||||||
"fieldsDistribution":{
|
|
||||||
"age":77,
|
|
||||||
"gender":77,
|
|
||||||
"phone":77,
|
|
||||||
"name":77,
|
|
||||||
"registered":77,
|
|
||||||
"latitude":77,
|
|
||||||
"email":77,
|
|
||||||
"tags":77,
|
|
||||||
"longitude":77,
|
|
||||||
"color":77,
|
|
||||||
"address":77,
|
|
||||||
"balance":77,
|
|
||||||
"about":77,
|
|
||||||
"picture":77,
|
|
||||||
},
|
|
||||||
});
|
|
||||||
|
|
||||||
assert_json_eq!(expected, response, ordered: true);
|
|
||||||
}
|
|
@ -1,200 +0,0 @@
|
|||||||
use serde_json::json;
|
|
||||||
use serde_json::Value;
|
|
||||||
use assert_json_diff::assert_json_include;
|
|
||||||
|
|
||||||
mod common;
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn check_first_update_should_bring_up_processed_status_after_first_docs_addition() {
|
|
||||||
let mut server = common::Server::with_uid("test");
|
|
||||||
|
|
||||||
let body = json!({
|
|
||||||
"uid": "test",
|
|
||||||
});
|
|
||||||
|
|
||||||
// 1. Create Index
|
|
||||||
let (response, status_code) = server.create_index(body).await;
|
|
||||||
assert_eq!(status_code, 201);
|
|
||||||
assert_eq!(response["primaryKey"], json!(null));
|
|
||||||
|
|
||||||
let dataset = include_bytes!("assets/test_set.json");
|
|
||||||
|
|
||||||
let body: Value = serde_json::from_slice(dataset).unwrap();
|
|
||||||
|
|
||||||
// 2. Index the documents from movies.json, present inside of assets directory
|
|
||||||
server.add_or_replace_multiple_documents(body).await;
|
|
||||||
|
|
||||||
// 3. Fetch the status of the indexing done above.
|
|
||||||
let (response, status_code) = server.get_all_updates_status().await;
|
|
||||||
|
|
||||||
// 4. Verify the fetch is successful and indexing status is 'processed'
|
|
||||||
assert_eq!(status_code, 200);
|
|
||||||
assert_eq!(response[0]["status"], "processed");
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn return_error_when_get_update_status_of_unexisting_index() {
|
|
||||||
let mut server = common::Server::with_uid("test");
|
|
||||||
|
|
||||||
// 1. Fetch the status of unexisting index.
|
|
||||||
let (_, status_code) = server.get_all_updates_status().await;
|
|
||||||
|
|
||||||
// 2. Verify the fetch returned 404
|
|
||||||
assert_eq!(status_code, 404);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn return_empty_when_get_update_status_of_empty_index() {
|
|
||||||
let mut server = common::Server::with_uid("test");
|
|
||||||
|
|
||||||
let body = json!({
|
|
||||||
"uid": "test",
|
|
||||||
});
|
|
||||||
|
|
||||||
// 1. Create Index
|
|
||||||
let (response, status_code) = server.create_index(body).await;
|
|
||||||
assert_eq!(status_code, 201);
|
|
||||||
assert_eq!(response["primaryKey"], json!(null));
|
|
||||||
|
|
||||||
// 2. Fetch the status of empty index.
|
|
||||||
let (response, status_code) = server.get_all_updates_status().await;
|
|
||||||
|
|
||||||
// 3. Verify the fetch is successful, and no document are returned
|
|
||||||
assert_eq!(status_code, 200);
|
|
||||||
assert_eq!(response, json!([]));
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn return_update_status_of_pushed_documents() {
|
|
||||||
let mut server = common::Server::with_uid("test");
|
|
||||||
|
|
||||||
let body = json!({
|
|
||||||
"uid": "test",
|
|
||||||
});
|
|
||||||
|
|
||||||
// 1. Create Index
|
|
||||||
let (response, status_code) = server.create_index(body).await;
|
|
||||||
assert_eq!(status_code, 201);
|
|
||||||
assert_eq!(response["primaryKey"], json!(null));
|
|
||||||
|
|
||||||
|
|
||||||
let bodies = vec![
|
|
||||||
json!([{
|
|
||||||
"title": "Test",
|
|
||||||
"comment": "comment test"
|
|
||||||
}]),
|
|
||||||
json!([{
|
|
||||||
"title": "Test1",
|
|
||||||
"comment": "comment test1"
|
|
||||||
}]),
|
|
||||||
json!([{
|
|
||||||
"title": "Test2",
|
|
||||||
"comment": "comment test2"
|
|
||||||
}]),
|
|
||||||
];
|
|
||||||
|
|
||||||
let mut update_ids = Vec::new();
|
|
||||||
|
|
||||||
let url = "/indexes/test/documents?primaryKey=title";
|
|
||||||
for body in bodies {
|
|
||||||
let (response, status_code) = server.post_request(&url, body).await;
|
|
||||||
assert_eq!(status_code, 202);
|
|
||||||
let update_id = response["updateId"].as_u64().unwrap();
|
|
||||||
update_ids.push(update_id);
|
|
||||||
}
|
|
||||||
|
|
||||||
// 2. Fetch the status of index.
|
|
||||||
let (response, status_code) = server.get_all_updates_status().await;
|
|
||||||
|
|
||||||
// 3. Verify the fetch is successful, and updates are returned
|
|
||||||
|
|
||||||
let expected = json!([{
|
|
||||||
"type": {
|
|
||||||
"name": "DocumentsAddition",
|
|
||||||
"number": 1,
|
|
||||||
},
|
|
||||||
"updateId": update_ids[0]
|
|
||||||
},{
|
|
||||||
"type": {
|
|
||||||
"name": "DocumentsAddition",
|
|
||||||
"number": 1,
|
|
||||||
},
|
|
||||||
"updateId": update_ids[1]
|
|
||||||
},{
|
|
||||||
"type": {
|
|
||||||
"name": "DocumentsAddition",
|
|
||||||
"number": 1,
|
|
||||||
},
|
|
||||||
"updateId": update_ids[2]
|
|
||||||
},]);
|
|
||||||
|
|
||||||
assert_eq!(status_code, 200);
|
|
||||||
assert_json_include!(actual: json!(response), expected: expected);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn return_error_if_index_does_not_exist() {
|
|
||||||
let mut server = common::Server::with_uid("test");
|
|
||||||
|
|
||||||
let (response, status_code) = server.get_update_status(42).await;
|
|
||||||
|
|
||||||
assert_eq!(status_code, 404);
|
|
||||||
assert_eq!(response["errorCode"], "index_not_found");
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn return_error_if_update_does_not_exist() {
|
|
||||||
let mut server = common::Server::with_uid("test");
|
|
||||||
|
|
||||||
let body = json!({
|
|
||||||
"uid": "test",
|
|
||||||
});
|
|
||||||
|
|
||||||
// 1. Create Index
|
|
||||||
let (response, status_code) = server.create_index(body).await;
|
|
||||||
assert_eq!(status_code, 201);
|
|
||||||
assert_eq!(response["primaryKey"], json!(null));
|
|
||||||
|
|
||||||
let (response, status_code) = server.get_update_status(42).await;
|
|
||||||
|
|
||||||
assert_eq!(status_code, 404);
|
|
||||||
assert_eq!(response["errorCode"], "not_found");
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn should_return_existing_update() {
|
|
||||||
let mut server = common::Server::with_uid("test");
|
|
||||||
|
|
||||||
let body = json!({
|
|
||||||
"uid": "test",
|
|
||||||
});
|
|
||||||
|
|
||||||
// 1. Create Index
|
|
||||||
let (response, status_code) = server.create_index(body).await;
|
|
||||||
assert_eq!(status_code, 201);
|
|
||||||
assert_eq!(response["primaryKey"], json!(null));
|
|
||||||
|
|
||||||
let body = json!([{
|
|
||||||
"title": "Test",
|
|
||||||
"comment": "comment test"
|
|
||||||
}]);
|
|
||||||
|
|
||||||
let url = "/indexes/test/documents?primaryKey=title";
|
|
||||||
let (response, status_code) = server.post_request(&url, body).await;
|
|
||||||
assert_eq!(status_code, 202);
|
|
||||||
|
|
||||||
let update_id = response["updateId"].as_u64().unwrap();
|
|
||||||
|
|
||||||
let expected = json!({
|
|
||||||
"type": {
|
|
||||||
"name": "DocumentsAddition",
|
|
||||||
"number": 1,
|
|
||||||
},
|
|
||||||
"updateId": update_id
|
|
||||||
});
|
|
||||||
|
|
||||||
let (response, status_code) = server.get_update_status(update_id).await;
|
|
||||||
|
|
||||||
assert_eq!(status_code, 200);
|
|
||||||
assert_json_include!(actual: json!(response), expected: expected);
|
|
||||||
}
|
|
@ -1,446 +0,0 @@
|
|||||||
use serde_json::json;
|
|
||||||
|
|
||||||
mod common;
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn create_index_lazy_by_pushing_documents() {
|
|
||||||
let mut server = common::Server::with_uid("movies");
|
|
||||||
|
|
||||||
// 1 - Add documents
|
|
||||||
|
|
||||||
let body = json!([{
|
|
||||||
"title": "Test",
|
|
||||||
"comment": "comment test"
|
|
||||||
}]);
|
|
||||||
|
|
||||||
let url = "/indexes/movies/documents?primaryKey=title";
|
|
||||||
let (response, status_code) = server.post_request(&url, body).await;
|
|
||||||
assert_eq!(status_code, 202);
|
|
||||||
let update_id = response["updateId"].as_u64().unwrap();
|
|
||||||
server.wait_update_id(update_id).await;
|
|
||||||
|
|
||||||
// 3 - Check update success
|
|
||||||
|
|
||||||
let (response, status_code) = server.get_update_status(update_id).await;
|
|
||||||
assert_eq!(status_code, 200);
|
|
||||||
assert_eq!(response["status"], "processed");
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn create_index_lazy_by_pushing_documents_and_discover_pk() {
|
|
||||||
let mut server = common::Server::with_uid("movies");
|
|
||||||
|
|
||||||
// 1 - Add documents
|
|
||||||
|
|
||||||
let body = json!([{
|
|
||||||
"id": 1,
|
|
||||||
"title": "Test",
|
|
||||||
"comment": "comment test"
|
|
||||||
}]);
|
|
||||||
|
|
||||||
let url = "/indexes/movies/documents";
|
|
||||||
let (response, status_code) = server.post_request(&url, body).await;
|
|
||||||
assert_eq!(status_code, 202);
|
|
||||||
let update_id = response["updateId"].as_u64().unwrap();
|
|
||||||
server.wait_update_id(update_id).await;
|
|
||||||
|
|
||||||
// 3 - Check update success
|
|
||||||
|
|
||||||
let (response, status_code) = server.get_update_status(update_id).await;
|
|
||||||
assert_eq!(status_code, 200);
|
|
||||||
assert_eq!(response["status"], "processed");
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn create_index_lazy_by_pushing_documents_with_wrong_name() {
|
|
||||||
let server = common::Server::with_uid("wrong&name");
|
|
||||||
|
|
||||||
let body = json!([{
|
|
||||||
"title": "Test",
|
|
||||||
"comment": "comment test"
|
|
||||||
}]);
|
|
||||||
|
|
||||||
let url = "/indexes/wrong&name/documents?primaryKey=title";
|
|
||||||
let (response, status_code) = server.post_request(&url, body).await;
|
|
||||||
assert_eq!(status_code, 400);
|
|
||||||
assert_eq!(response["errorCode"], "invalid_index_uid");
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn create_index_lazy_add_documents_failed() {
|
|
||||||
let mut server = common::Server::with_uid("wrong&name");
|
|
||||||
|
|
||||||
let body = json!([{
|
|
||||||
"title": "Test",
|
|
||||||
"comment": "comment test"
|
|
||||||
}]);
|
|
||||||
|
|
||||||
let url = "/indexes/wrong&name/documents";
|
|
||||||
let (response, status_code) = server.post_request(&url, body).await;
|
|
||||||
assert_eq!(status_code, 400);
|
|
||||||
assert_eq!(response["errorCode"], "invalid_index_uid");
|
|
||||||
|
|
||||||
let (_, status_code) = server.get_index().await;
|
|
||||||
assert_eq!(status_code, 404);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn create_index_lazy_by_sending_settings() {
|
|
||||||
let mut server = common::Server::with_uid("movies");
|
|
||||||
// 2 - Send the settings
|
|
||||||
|
|
||||||
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": [
|
|
||||||
"name",
|
|
||||||
"gender",
|
|
||||||
"email",
|
|
||||||
"registered",
|
|
||||||
"age",
|
|
||||||
],
|
|
||||||
"stopWords": [
|
|
||||||
"ad",
|
|
||||||
"in",
|
|
||||||
"ut",
|
|
||||||
],
|
|
||||||
"synonyms": {
|
|
||||||
"road": ["street", "avenue"],
|
|
||||||
"street": ["avenue"],
|
|
||||||
},
|
|
||||||
"attributesForFaceting": ["name"],
|
|
||||||
});
|
|
||||||
|
|
||||||
server.update_all_settings(body.clone()).await;
|
|
||||||
|
|
||||||
// 3 - Get all settings and compare to the previous one
|
|
||||||
|
|
||||||
let (_, status_code) = server.get_all_settings().await;
|
|
||||||
|
|
||||||
assert_eq!(status_code, 200);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn create_index_lazy_by_sending_settings_with_error() {
|
|
||||||
let mut server = common::Server::with_uid("movies");
|
|
||||||
// 2 - Send the settings
|
|
||||||
|
|
||||||
let body = json!({
|
|
||||||
"rankingRules": [
|
|
||||||
"other",
|
|
||||||
"words",
|
|
||||||
"proximity",
|
|
||||||
"attribute",
|
|
||||||
"wordsPosition",
|
|
||||||
"exactness",
|
|
||||||
"desc(registered)",
|
|
||||||
"desc(age)",
|
|
||||||
],
|
|
||||||
"distinctAttribute": "id",
|
|
||||||
"searchableAttributes": [
|
|
||||||
"id",
|
|
||||||
"name",
|
|
||||||
"color",
|
|
||||||
"gender",
|
|
||||||
"email",
|
|
||||||
"phone",
|
|
||||||
"address",
|
|
||||||
"registered",
|
|
||||||
"about"
|
|
||||||
],
|
|
||||||
"displayedAttributes": [
|
|
||||||
"name",
|
|
||||||
"gender",
|
|
||||||
"email",
|
|
||||||
"registered",
|
|
||||||
"age",
|
|
||||||
],
|
|
||||||
"stopWords": [
|
|
||||||
"ad",
|
|
||||||
"in",
|
|
||||||
"ut",
|
|
||||||
],
|
|
||||||
"synonyms": {
|
|
||||||
"road": ["street", "avenue"],
|
|
||||||
"street": ["avenue"],
|
|
||||||
},
|
|
||||||
"anotherSettings": ["name"],
|
|
||||||
});
|
|
||||||
|
|
||||||
let (_, status_code) = server.update_all_settings_sync(body.clone()).await;
|
|
||||||
assert_eq!(status_code, 400);
|
|
||||||
|
|
||||||
// 3 - Get all settings and compare to the previous one
|
|
||||||
|
|
||||||
let (_, status_code) = server.get_all_settings().await;
|
|
||||||
|
|
||||||
assert_eq!(status_code, 404);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn create_index_lazy_by_sending_ranking_rules() {
|
|
||||||
let mut server = common::Server::with_uid("movies");
|
|
||||||
// 2 - Send the settings
|
|
||||||
|
|
||||||
let body = json!([
|
|
||||||
"typo",
|
|
||||||
"words",
|
|
||||||
"proximity",
|
|
||||||
"attribute",
|
|
||||||
"wordsPosition",
|
|
||||||
"exactness",
|
|
||||||
"desc(registered)",
|
|
||||||
"desc(age)",
|
|
||||||
]);
|
|
||||||
|
|
||||||
server.update_ranking_rules(body.clone()).await;
|
|
||||||
|
|
||||||
// 3 - Get all settings and compare to the previous one
|
|
||||||
|
|
||||||
let (_, status_code) = server.get_all_settings().await;
|
|
||||||
|
|
||||||
assert_eq!(status_code, 200);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn create_index_lazy_by_sending_ranking_rules_with_error() {
|
|
||||||
let mut server = common::Server::with_uid("movies");
|
|
||||||
// 2 - Send the settings
|
|
||||||
|
|
||||||
let body = json!({
|
|
||||||
"rankingRules": 123,
|
|
||||||
});
|
|
||||||
|
|
||||||
let (_, status_code) = server.update_ranking_rules_sync(body.clone()).await;
|
|
||||||
assert_eq!(status_code, 400);
|
|
||||||
|
|
||||||
// 3 - Get all settings and compare to the previous one
|
|
||||||
|
|
||||||
let (_, status_code) = server.get_all_settings().await;
|
|
||||||
|
|
||||||
assert_eq!(status_code, 404);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn create_index_lazy_by_sending_distinct_attribute() {
|
|
||||||
let mut server = common::Server::with_uid("movies");
|
|
||||||
// 2 - Send the settings
|
|
||||||
|
|
||||||
let body = json!("type");
|
|
||||||
|
|
||||||
server.update_distinct_attribute(body.clone()).await;
|
|
||||||
|
|
||||||
// 3 - Get all settings and compare to the previous one
|
|
||||||
|
|
||||||
let (_, status_code) = server.get_all_settings().await;
|
|
||||||
|
|
||||||
assert_eq!(status_code, 200);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn create_index_lazy_by_sending_distinct_attribute_with_error() {
|
|
||||||
let mut server = common::Server::with_uid("movies");
|
|
||||||
// 2 - Send the settings
|
|
||||||
|
|
||||||
let body = json!(123);
|
|
||||||
|
|
||||||
let (resp, status_code) = server.update_distinct_attribute_sync(body.clone()).await;
|
|
||||||
eprintln!("resp: {:?}", resp);
|
|
||||||
assert_eq!(status_code, 400);
|
|
||||||
|
|
||||||
// 3 - Get all settings and compare to the previous one
|
|
||||||
|
|
||||||
let (resp, status_code) = server.get_all_settings().await;
|
|
||||||
eprintln!("resp: {:?}", resp);
|
|
||||||
assert_eq!(status_code, 404);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn create_index_lazy_by_sending_searchable_attributes() {
|
|
||||||
let mut server = common::Server::with_uid("movies");
|
|
||||||
// 2 - Send the settings
|
|
||||||
|
|
||||||
let body = json!(["title", "description"]);
|
|
||||||
|
|
||||||
server.update_searchable_attributes(body.clone()).await;
|
|
||||||
|
|
||||||
// 3 - Get all settings and compare to the previous one
|
|
||||||
|
|
||||||
let (_, status_code) = server.get_all_settings().await;
|
|
||||||
|
|
||||||
assert_eq!(status_code, 200);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn create_index_lazy_by_sending_searchable_attributes_with_error() {
|
|
||||||
let mut server = common::Server::with_uid("movies");
|
|
||||||
// 2 - Send the settings
|
|
||||||
|
|
||||||
let body = json!(123);
|
|
||||||
|
|
||||||
let (_, status_code) = server.update_searchable_attributes_sync(body.clone()).await;
|
|
||||||
assert_eq!(status_code, 400);
|
|
||||||
|
|
||||||
// 3 - Get all settings and compare to the previous one
|
|
||||||
|
|
||||||
let (_, status_code) = server.get_all_settings().await;
|
|
||||||
|
|
||||||
assert_eq!(status_code, 404);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn create_index_lazy_by_sending_displayed_attributes() {
|
|
||||||
let mut server = common::Server::with_uid("movies");
|
|
||||||
// 2 - Send the settings
|
|
||||||
|
|
||||||
let body = json!(["title", "description"]);
|
|
||||||
|
|
||||||
server.update_displayed_attributes(body.clone()).await;
|
|
||||||
|
|
||||||
// 3 - Get all settings and compare to the previous one
|
|
||||||
|
|
||||||
let (_, status_code) = server.get_all_settings().await;
|
|
||||||
|
|
||||||
assert_eq!(status_code, 200);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn create_index_lazy_by_sending_displayed_attributes_with_error() {
|
|
||||||
let mut server = common::Server::with_uid("movies");
|
|
||||||
// 2 - Send the settings
|
|
||||||
|
|
||||||
let body = json!(123);
|
|
||||||
|
|
||||||
let (_, status_code) = server.update_displayed_attributes_sync(body.clone()).await;
|
|
||||||
assert_eq!(status_code, 400);
|
|
||||||
|
|
||||||
// 3 - Get all settings and compare to the previous one
|
|
||||||
|
|
||||||
let (_, status_code) = server.get_all_settings().await;
|
|
||||||
|
|
||||||
assert_eq!(status_code, 404);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn create_index_lazy_by_sending_attributes_for_faceting() {
|
|
||||||
let mut server = common::Server::with_uid("movies");
|
|
||||||
// 2 - Send the settings
|
|
||||||
|
|
||||||
let body = json!(["title", "description"]);
|
|
||||||
|
|
||||||
server.update_attributes_for_faceting(body.clone()).await;
|
|
||||||
|
|
||||||
// 3 - Get all settings and compare to the previous one
|
|
||||||
|
|
||||||
let (_, status_code) = server.get_all_settings().await;
|
|
||||||
|
|
||||||
assert_eq!(status_code, 200);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn create_index_lazy_by_sending_attributes_for_faceting_with_error() {
|
|
||||||
let mut server = common::Server::with_uid("movies");
|
|
||||||
// 2 - Send the settings
|
|
||||||
|
|
||||||
let body = json!(123);
|
|
||||||
|
|
||||||
let (_, status_code) = server
|
|
||||||
.update_attributes_for_faceting_sync(body.clone())
|
|
||||||
.await;
|
|
||||||
assert_eq!(status_code, 400);
|
|
||||||
|
|
||||||
// 3 - Get all settings and compare to the previous one
|
|
||||||
|
|
||||||
let (_, status_code) = server.get_all_settings().await;
|
|
||||||
|
|
||||||
assert_eq!(status_code, 404);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn create_index_lazy_by_sending_synonyms() {
|
|
||||||
let mut server = common::Server::with_uid("movies");
|
|
||||||
// 2 - Send the settings
|
|
||||||
|
|
||||||
let body = json!({
|
|
||||||
"road": ["street", "avenue"],
|
|
||||||
"street": ["avenue"],
|
|
||||||
});
|
|
||||||
|
|
||||||
server.update_synonyms(body.clone()).await;
|
|
||||||
|
|
||||||
// 3 - Get all settings and compare to the previous one
|
|
||||||
|
|
||||||
let (_, status_code) = server.get_all_settings().await;
|
|
||||||
|
|
||||||
assert_eq!(status_code, 200);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn create_index_lazy_by_sending_synonyms_with_error() {
|
|
||||||
let mut server = common::Server::with_uid("movies");
|
|
||||||
// 2 - Send the settings
|
|
||||||
|
|
||||||
let body = json!(123);
|
|
||||||
|
|
||||||
let (_, status_code) = server.update_synonyms_sync(body.clone()).await;
|
|
||||||
assert_eq!(status_code, 400);
|
|
||||||
|
|
||||||
// 3 - Get all settings and compare to the previous one
|
|
||||||
|
|
||||||
let (_, status_code) = server.get_all_settings().await;
|
|
||||||
|
|
||||||
assert_eq!(status_code, 404);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn create_index_lazy_by_sending_stop_words() {
|
|
||||||
let mut server = common::Server::with_uid("movies");
|
|
||||||
// 2 - Send the settings
|
|
||||||
|
|
||||||
let body = json!(["le", "la", "les"]);
|
|
||||||
|
|
||||||
server.update_stop_words(body.clone()).await;
|
|
||||||
|
|
||||||
// 3 - Get all settings and compare to the previous one
|
|
||||||
|
|
||||||
let (_, status_code) = server.get_all_settings().await;
|
|
||||||
|
|
||||||
assert_eq!(status_code, 200);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn create_index_lazy_by_sending_stop_words_with_error() {
|
|
||||||
let mut server = common::Server::with_uid("movies");
|
|
||||||
// 2 - Send the settings
|
|
||||||
|
|
||||||
let body = json!(123);
|
|
||||||
|
|
||||||
let (_, status_code) = server.update_stop_words_sync(body.clone()).await;
|
|
||||||
assert_eq!(status_code, 400);
|
|
||||||
|
|
||||||
// 3 - Get all settings and compare to the previous one
|
|
||||||
|
|
||||||
let (_, status_code) = server.get_all_settings().await;
|
|
||||||
|
|
||||||
assert_eq!(status_code, 404);
|
|
||||||
}
|
|
@ -1,629 +0,0 @@
|
|||||||
use std::convert::Into;
|
|
||||||
|
|
||||||
use serde_json::json;
|
|
||||||
use serde_json::Value;
|
|
||||||
use std::cell::RefCell;
|
|
||||||
use std::sync::Mutex;
|
|
||||||
|
|
||||||
#[macro_use]
|
|
||||||
mod common;
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn placeholder_search_with_limit() {
|
|
||||||
let mut server = common::Server::test_server().await;
|
|
||||||
|
|
||||||
let query = json! ({
|
|
||||||
"limit": 3
|
|
||||||
});
|
|
||||||
|
|
||||||
test_post_get_search!(server, query, |response, status_code| {
|
|
||||||
assert_eq!(status_code, 200);
|
|
||||||
assert_eq!(response["hits"].as_array().unwrap().len(), 3);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn placeholder_search_with_offset() {
|
|
||||||
let mut server = common::Server::test_server().await;
|
|
||||||
|
|
||||||
let query = json!({
|
|
||||||
"limit": 6,
|
|
||||||
});
|
|
||||||
|
|
||||||
// hack to take a value out of macro (must implement UnwindSafe)
|
|
||||||
let expected = Mutex::new(RefCell::new(Vec::new()));
|
|
||||||
|
|
||||||
test_post_get_search!(server, query, |response, status_code| {
|
|
||||||
assert_eq!(status_code, 200);
|
|
||||||
// take results at offset 3 as reference
|
|
||||||
let lock = expected.lock().unwrap();
|
|
||||||
lock.replace(response["hits"].as_array().unwrap()[3..6].to_vec());
|
|
||||||
});
|
|
||||||
let expected = expected.into_inner().unwrap().into_inner();
|
|
||||||
|
|
||||||
let query = json!({
|
|
||||||
"limit": 3,
|
|
||||||
"offset": 3,
|
|
||||||
});
|
|
||||||
test_post_get_search!(server, query, |response, status_code| {
|
|
||||||
assert_eq!(status_code, 200);
|
|
||||||
let response = response["hits"].as_array().unwrap();
|
|
||||||
assert_eq!(&expected, response);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn placeholder_search_with_attribute_to_highlight_wildcard() {
|
|
||||||
// there should be no highlight in placeholder search
|
|
||||||
let mut server = common::Server::test_server().await;
|
|
||||||
|
|
||||||
let query = json!({
|
|
||||||
"limit": 1,
|
|
||||||
"attributesToHighlight": ["*"]
|
|
||||||
});
|
|
||||||
|
|
||||||
test_post_get_search!(server, query, |response, status_code| {
|
|
||||||
assert_eq!(status_code, 200);
|
|
||||||
let result = response["hits"].as_array().unwrap()[0].as_object().unwrap();
|
|
||||||
for value in result.values() {
|
|
||||||
assert!(value.to_string().find("<em>").is_none());
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn placeholder_search_with_matches() {
|
|
||||||
// matches is always empty
|
|
||||||
let mut server = common::Server::test_server().await;
|
|
||||||
|
|
||||||
let query = json!({
|
|
||||||
"matches": true
|
|
||||||
});
|
|
||||||
|
|
||||||
test_post_get_search!(server, query, |response, status_code| {
|
|
||||||
assert_eq!(status_code, 200);
|
|
||||||
let result = response["hits"]
|
|
||||||
.as_array()
|
|
||||||
.unwrap()
|
|
||||||
.iter()
|
|
||||||
.map(|v| v.as_object().unwrap()["_matchesInfo"].clone())
|
|
||||||
.all(|m| m.as_object().unwrap().is_empty());
|
|
||||||
assert!(result);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn placeholder_search_witch_crop() {
|
|
||||||
// placeholder search crop always crop from beggining
|
|
||||||
let mut server = common::Server::test_server().await;
|
|
||||||
|
|
||||||
let query = json!({
|
|
||||||
"attributesToCrop": ["about"],
|
|
||||||
"cropLength": 20
|
|
||||||
});
|
|
||||||
|
|
||||||
test_post_get_search!(server, query, |response, status_code| {
|
|
||||||
assert_eq!(status_code, 200);
|
|
||||||
|
|
||||||
let hits = response["hits"].as_array().unwrap();
|
|
||||||
|
|
||||||
for hit in hits {
|
|
||||||
let hit = hit.as_object().unwrap();
|
|
||||||
let formatted = hit["_formatted"].as_object().unwrap();
|
|
||||||
|
|
||||||
let about = hit["about"].as_str().unwrap();
|
|
||||||
let about_formatted = formatted["about"].as_str().unwrap();
|
|
||||||
// the formatted about length should be about 20 characters long
|
|
||||||
assert!(about_formatted.len() < 20 + 10);
|
|
||||||
// the formatted part should be located at the beginning of the original one
|
|
||||||
assert_eq!(about.find(&about_formatted).unwrap(), 0);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn placeholder_search_with_attributes_to_retrieve() {
|
|
||||||
let mut server = common::Server::test_server().await;
|
|
||||||
|
|
||||||
let query = json!({
|
|
||||||
"limit": 1,
|
|
||||||
"attributesToRetrieve": ["gender", "about"],
|
|
||||||
});
|
|
||||||
|
|
||||||
test_post_get_search!(server, query, |response, _status_code| {
|
|
||||||
let hit = response["hits"].as_array().unwrap()[0].as_object().unwrap();
|
|
||||||
assert_eq!(hit.values().count(), 2);
|
|
||||||
let _ = hit["gender"];
|
|
||||||
let _ = hit["about"];
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn placeholder_search_with_filter() {
|
|
||||||
let mut server = common::Server::test_server().await;
|
|
||||||
|
|
||||||
let query = json!({
|
|
||||||
"filters": "color='green'"
|
|
||||||
});
|
|
||||||
|
|
||||||
test_post_get_search!(server, query, |response, _status_code| {
|
|
||||||
let hits = response["hits"].as_array().unwrap();
|
|
||||||
assert!(hits.iter().all(|v| v["color"].as_str().unwrap() == "Green"));
|
|
||||||
});
|
|
||||||
|
|
||||||
let query = json!({
|
|
||||||
"filters": "tags=bug"
|
|
||||||
});
|
|
||||||
|
|
||||||
test_post_get_search!(server, query, |response, _status_code| {
|
|
||||||
let hits = response["hits"].as_array().unwrap();
|
|
||||||
let value = Value::String(String::from("bug"));
|
|
||||||
assert!(hits
|
|
||||||
.iter()
|
|
||||||
.all(|v| v["tags"].as_array().unwrap().contains(&value)));
|
|
||||||
});
|
|
||||||
|
|
||||||
let query = json!({
|
|
||||||
"filters": "color='green' AND (tags='bug' OR tags='wontfix')"
|
|
||||||
});
|
|
||||||
test_post_get_search!(server, query, |response, _status_code| {
|
|
||||||
let hits = response["hits"].as_array().unwrap();
|
|
||||||
let bug = Value::String(String::from("bug"));
|
|
||||||
let wontfix = Value::String(String::from("wontfix"));
|
|
||||||
assert!(hits.iter().all(|v| v["color"].as_str().unwrap() == "Green"
|
|
||||||
&& v["tags"].as_array().unwrap().contains(&bug)
|
|
||||||
|| v["tags"].as_array().unwrap().contains(&wontfix)));
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn placeholder_test_faceted_search_valid() {
|
|
||||||
let mut server = common::Server::test_server().await;
|
|
||||||
|
|
||||||
// simple tests on attributes with string value
|
|
||||||
let body = json!({
|
|
||||||
"attributesForFaceting": ["color"]
|
|
||||||
});
|
|
||||||
|
|
||||||
server.update_all_settings(body).await;
|
|
||||||
|
|
||||||
let query = json!({
|
|
||||||
"facetFilters": ["color:green"]
|
|
||||||
});
|
|
||||||
|
|
||||||
test_post_get_search!(server, query, |response, _status_code| {
|
|
||||||
assert!(!response.get("hits").unwrap().as_array().unwrap().is_empty());
|
|
||||||
assert!(response
|
|
||||||
.get("hits")
|
|
||||||
.unwrap()
|
|
||||||
.as_array()
|
|
||||||
.unwrap()
|
|
||||||
.iter()
|
|
||||||
.all(|value| value.get("color").unwrap() == "Green"));
|
|
||||||
});
|
|
||||||
|
|
||||||
let query = json!({
|
|
||||||
"facetFilters": [["color:blue"]]
|
|
||||||
});
|
|
||||||
|
|
||||||
test_post_get_search!(server, query, |response, _status_code| {
|
|
||||||
assert!(!response.get("hits").unwrap().as_array().unwrap().is_empty());
|
|
||||||
assert!(response
|
|
||||||
.get("hits")
|
|
||||||
.unwrap()
|
|
||||||
.as_array()
|
|
||||||
.unwrap()
|
|
||||||
.iter()
|
|
||||||
.all(|value| value.get("color").unwrap() == "blue"));
|
|
||||||
});
|
|
||||||
|
|
||||||
let query = json!({
|
|
||||||
"facetFilters": ["color:Blue"]
|
|
||||||
});
|
|
||||||
|
|
||||||
test_post_get_search!(server, query, |response, _status_code| {
|
|
||||||
assert!(!response.get("hits").unwrap().as_array().unwrap().is_empty());
|
|
||||||
assert!(response
|
|
||||||
.get("hits")
|
|
||||||
.unwrap()
|
|
||||||
.as_array()
|
|
||||||
.unwrap()
|
|
||||||
.iter()
|
|
||||||
.all(|value| value.get("color").unwrap() == "blue"));
|
|
||||||
});
|
|
||||||
|
|
||||||
// test on arrays: ["tags:bug"]
|
|
||||||
let body = json!({
|
|
||||||
"attributesForFaceting": ["color", "tags"]
|
|
||||||
});
|
|
||||||
|
|
||||||
server.update_all_settings(body).await;
|
|
||||||
|
|
||||||
let query = json!({
|
|
||||||
"facetFilters": ["tags:bug"]
|
|
||||||
});
|
|
||||||
test_post_get_search!(server, query, |response, _status_code| {
|
|
||||||
assert!(!response.get("hits").unwrap().as_array().unwrap().is_empty());
|
|
||||||
assert!(response
|
|
||||||
.get("hits")
|
|
||||||
.unwrap()
|
|
||||||
.as_array()
|
|
||||||
.unwrap()
|
|
||||||
.iter()
|
|
||||||
.all(|value| value
|
|
||||||
.get("tags")
|
|
||||||
.unwrap()
|
|
||||||
.as_array()
|
|
||||||
.unwrap()
|
|
||||||
.contains(&Value::String("bug".to_owned()))));
|
|
||||||
});
|
|
||||||
|
|
||||||
// test and: ["color:blue", "tags:bug"]
|
|
||||||
let query = json!({
|
|
||||||
"facetFilters": ["color:blue", "tags:bug"]
|
|
||||||
});
|
|
||||||
test_post_get_search!(server, query, |response, _status_code| {
|
|
||||||
assert!(!response.get("hits").unwrap().as_array().unwrap().is_empty());
|
|
||||||
assert!(response
|
|
||||||
.get("hits")
|
|
||||||
.unwrap()
|
|
||||||
.as_array()
|
|
||||||
.unwrap()
|
|
||||||
.iter()
|
|
||||||
.all(|value| value.get("color").unwrap() == "blue"
|
|
||||||
&& value
|
|
||||||
.get("tags")
|
|
||||||
.unwrap()
|
|
||||||
.as_array()
|
|
||||||
.unwrap()
|
|
||||||
.contains(&Value::String("bug".to_owned()))));
|
|
||||||
});
|
|
||||||
|
|
||||||
// test or: [["color:blue", "color:green"]]
|
|
||||||
let query = json!({
|
|
||||||
"facetFilters": [["color:blue", "color:green"]]
|
|
||||||
});
|
|
||||||
test_post_get_search!(server, query, |response, _status_code| {
|
|
||||||
assert!(!response.get("hits").unwrap().as_array().unwrap().is_empty());
|
|
||||||
assert!(response
|
|
||||||
.get("hits")
|
|
||||||
.unwrap()
|
|
||||||
.as_array()
|
|
||||||
.unwrap()
|
|
||||||
.iter()
|
|
||||||
.all(|value| value.get("color").unwrap() == "blue"
|
|
||||||
|| value.get("color").unwrap() == "Green"));
|
|
||||||
});
|
|
||||||
// test and-or: ["tags:bug", ["color:blue", "color:green"]]
|
|
||||||
let query = json!({
|
|
||||||
"facetFilters": ["tags:bug", ["color:blue", "color:green"]]
|
|
||||||
});
|
|
||||||
test_post_get_search!(server, query, |response, _status_code| {
|
|
||||||
assert!(!response.get("hits").unwrap().as_array().unwrap().is_empty());
|
|
||||||
assert!(response
|
|
||||||
.get("hits")
|
|
||||||
.unwrap()
|
|
||||||
.as_array()
|
|
||||||
.unwrap()
|
|
||||||
.iter()
|
|
||||||
.all(|value| value
|
|
||||||
.get("tags")
|
|
||||||
.unwrap()
|
|
||||||
.as_array()
|
|
||||||
.unwrap()
|
|
||||||
.contains(&Value::String("bug".to_owned()))
|
|
||||||
&& (value.get("color").unwrap() == "blue"
|
|
||||||
|| value.get("color").unwrap() == "Green")));
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn placeholder_test_faceted_search_invalid() {
|
|
||||||
let mut server = common::Server::test_server().await;
|
|
||||||
|
|
||||||
//no faceted attributes set
|
|
||||||
let query = json!({
|
|
||||||
"facetFilters": ["color:blue"]
|
|
||||||
});
|
|
||||||
test_post_get_search!(server, query, |_response, status_code| assert_ne!(
|
|
||||||
status_code,
|
|
||||||
202
|
|
||||||
));
|
|
||||||
|
|
||||||
let body = json!({
|
|
||||||
"attributesForFaceting": ["color", "tags"]
|
|
||||||
});
|
|
||||||
server.update_all_settings(body).await;
|
|
||||||
// empty arrays are error
|
|
||||||
// []
|
|
||||||
let query = json!({
|
|
||||||
"facetFilters": []
|
|
||||||
});
|
|
||||||
test_post_get_search!(server, query, |_response, status_code| assert_ne!(
|
|
||||||
status_code,
|
|
||||||
202
|
|
||||||
));
|
|
||||||
// [[]]
|
|
||||||
let query = json!({
|
|
||||||
"facetFilters": [[]]
|
|
||||||
});
|
|
||||||
test_post_get_search!(server, query, |_response, status_code| assert_ne!(
|
|
||||||
status_code,
|
|
||||||
202
|
|
||||||
));
|
|
||||||
// ["color:green", []]
|
|
||||||
let query = json!({
|
|
||||||
"facetFilters": ["color:green", []]
|
|
||||||
});
|
|
||||||
test_post_get_search!(server, query, |_response, status_code| assert_ne!(
|
|
||||||
status_code,
|
|
||||||
202
|
|
||||||
));
|
|
||||||
|
|
||||||
// too much depth
|
|
||||||
// [[[]]]
|
|
||||||
let query = json!({
|
|
||||||
"facetFilters": [[[]]]
|
|
||||||
});
|
|
||||||
test_post_get_search!(server, query, |_response, status_code| assert_ne!(
|
|
||||||
status_code,
|
|
||||||
202
|
|
||||||
));
|
|
||||||
// [["color:green", ["color:blue"]]]
|
|
||||||
let query = json!({
|
|
||||||
"facetFilters": [["color:green", ["color:blue"]]]
|
|
||||||
});
|
|
||||||
test_post_get_search!(server, query, |_response, status_code| assert_ne!(
|
|
||||||
status_code,
|
|
||||||
202
|
|
||||||
));
|
|
||||||
// "color:green"
|
|
||||||
let query = json!({
|
|
||||||
"facetFilters": "color:green"
|
|
||||||
});
|
|
||||||
test_post_get_search!(server, query, |_response, status_code| assert_ne!(
|
|
||||||
status_code,
|
|
||||||
202
|
|
||||||
));
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn placeholder_test_facet_count() {
|
|
||||||
let mut server = common::Server::test_server().await;
|
|
||||||
|
|
||||||
// test without facet distribution
|
|
||||||
let query = json!({});
|
|
||||||
test_post_get_search!(server, query, |response, _status_code| {
|
|
||||||
assert!(response.get("exhaustiveFacetsCount").is_none());
|
|
||||||
assert!(response.get("facetsDistribution").is_none());
|
|
||||||
});
|
|
||||||
|
|
||||||
// test no facets set, search on color
|
|
||||||
let query = json!({
|
|
||||||
"facetsDistribution": ["color"]
|
|
||||||
});
|
|
||||||
test_post_get_search!(server, query.clone(), |_response, status_code| {
|
|
||||||
assert_eq!(status_code, 400);
|
|
||||||
});
|
|
||||||
|
|
||||||
let body = json!({
|
|
||||||
"attributesForFaceting": ["color", "tags"]
|
|
||||||
});
|
|
||||||
server.update_all_settings(body).await;
|
|
||||||
// same as before, but now facets are set:
|
|
||||||
test_post_get_search!(server, query, |response, _status_code| {
|
|
||||||
println!("{}", response);
|
|
||||||
assert!(response.get("exhaustiveFacetsCount").is_some());
|
|
||||||
assert_eq!(
|
|
||||||
response
|
|
||||||
.get("facetsDistribution")
|
|
||||||
.unwrap()
|
|
||||||
.as_object()
|
|
||||||
.unwrap()
|
|
||||||
.values()
|
|
||||||
.count(),
|
|
||||||
1
|
|
||||||
);
|
|
||||||
});
|
|
||||||
// searching on color and tags
|
|
||||||
let query = json!({
|
|
||||||
"facetsDistribution": ["color", "tags"]
|
|
||||||
});
|
|
||||||
test_post_get_search!(server, query, |response, _status_code| {
|
|
||||||
let facets = response
|
|
||||||
.get("facetsDistribution")
|
|
||||||
.unwrap()
|
|
||||||
.as_object()
|
|
||||||
.unwrap();
|
|
||||||
assert_eq!(facets.values().count(), 2);
|
|
||||||
assert_ne!(
|
|
||||||
!facets
|
|
||||||
.get("color")
|
|
||||||
.unwrap()
|
|
||||||
.as_object()
|
|
||||||
.unwrap()
|
|
||||||
.values()
|
|
||||||
.count(),
|
|
||||||
0
|
|
||||||
);
|
|
||||||
assert_ne!(
|
|
||||||
!facets
|
|
||||||
.get("tags")
|
|
||||||
.unwrap()
|
|
||||||
.as_object()
|
|
||||||
.unwrap()
|
|
||||||
.values()
|
|
||||||
.count(),
|
|
||||||
0
|
|
||||||
);
|
|
||||||
});
|
|
||||||
// wildcard
|
|
||||||
let query = json!({
|
|
||||||
"facetsDistribution": ["*"]
|
|
||||||
});
|
|
||||||
test_post_get_search!(server, query, |response, _status_code| {
|
|
||||||
assert_eq!(
|
|
||||||
response
|
|
||||||
.get("facetsDistribution")
|
|
||||||
.unwrap()
|
|
||||||
.as_object()
|
|
||||||
.unwrap()
|
|
||||||
.values()
|
|
||||||
.count(),
|
|
||||||
2
|
|
||||||
);
|
|
||||||
});
|
|
||||||
// wildcard with other attributes:
|
|
||||||
let query = json!({
|
|
||||||
"facetsDistribution": ["color", "*"]
|
|
||||||
});
|
|
||||||
test_post_get_search!(server, query, |response, _status_code| {
|
|
||||||
assert_eq!(
|
|
||||||
response
|
|
||||||
.get("facetsDistribution")
|
|
||||||
.unwrap()
|
|
||||||
.as_object()
|
|
||||||
.unwrap()
|
|
||||||
.values()
|
|
||||||
.count(),
|
|
||||||
2
|
|
||||||
);
|
|
||||||
});
|
|
||||||
|
|
||||||
// empty facet list
|
|
||||||
let query = json!({
|
|
||||||
"facetsDistribution": []
|
|
||||||
});
|
|
||||||
test_post_get_search!(server, query, |response, _status_code| {
|
|
||||||
assert_eq!(
|
|
||||||
response
|
|
||||||
.get("facetsDistribution")
|
|
||||||
.unwrap()
|
|
||||||
.as_object()
|
|
||||||
.unwrap()
|
|
||||||
.values()
|
|
||||||
.count(),
|
|
||||||
0
|
|
||||||
);
|
|
||||||
});
|
|
||||||
|
|
||||||
// attr not set as facet passed:
|
|
||||||
let query = json!({
|
|
||||||
"facetsDistribution": ["gender"]
|
|
||||||
});
|
|
||||||
test_post_get_search!(server, query, |_response, status_code| {
|
|
||||||
assert_eq!(status_code, 400);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
#[should_panic]
|
|
||||||
async fn placeholder_test_bad_facet_distribution() {
|
|
||||||
let mut server = common::Server::test_server().await;
|
|
||||||
// string instead of array:
|
|
||||||
let query = json!({
|
|
||||||
"facetsDistribution": "color"
|
|
||||||
});
|
|
||||||
test_post_get_search!(server, query, |_response, _status_code| {});
|
|
||||||
|
|
||||||
// invalid value in array:
|
|
||||||
let query = json!({
|
|
||||||
"facetsDistribution": ["color", true]
|
|
||||||
});
|
|
||||||
test_post_get_search!(server, query, |_response, _status_code| {});
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn placeholder_test_sort() {
|
|
||||||
let mut server = common::Server::test_server().await;
|
|
||||||
|
|
||||||
let body = json!({
|
|
||||||
"rankingRules": ["asc(age)"],
|
|
||||||
"attributesForFaceting": ["color"]
|
|
||||||
});
|
|
||||||
server.update_all_settings(body).await;
|
|
||||||
let query = json!({});
|
|
||||||
test_post_get_search!(server, query, |response, _status_code| {
|
|
||||||
let hits = response["hits"].as_array().unwrap();
|
|
||||||
hits.iter()
|
|
||||||
.map(|v| v["age"].as_u64().unwrap())
|
|
||||||
.fold(0, |prev, cur| {
|
|
||||||
assert!(cur >= prev);
|
|
||||||
cur
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
let query = json!({
|
|
||||||
"facetFilters": ["color:green"]
|
|
||||||
});
|
|
||||||
test_post_get_search!(server, query, |response, _status_code| {
|
|
||||||
let hits = response["hits"].as_array().unwrap();
|
|
||||||
hits.iter()
|
|
||||||
.map(|v| v["age"].as_u64().unwrap())
|
|
||||||
.fold(0, |prev, cur| {
|
|
||||||
assert!(cur >= prev);
|
|
||||||
cur
|
|
||||||
});
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn placeholder_search_with_empty_query() {
|
|
||||||
let mut server = common::Server::test_server().await;
|
|
||||||
|
|
||||||
let query = json! ({
|
|
||||||
"q": "",
|
|
||||||
"limit": 3
|
|
||||||
});
|
|
||||||
|
|
||||||
test_post_get_search!(server, query, |response, status_code| {
|
|
||||||
eprintln!("{}", response);
|
|
||||||
assert_eq!(status_code, 200);
|
|
||||||
assert_eq!(response["hits"].as_array().unwrap().len(), 3);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn test_filter_nb_hits_search_placeholder() {
|
|
||||||
let mut server = common::Server::with_uid("test");
|
|
||||||
|
|
||||||
let body = json!({
|
|
||||||
"uid": "test",
|
|
||||||
"primaryKey": "id",
|
|
||||||
});
|
|
||||||
|
|
||||||
server.create_index(body).await;
|
|
||||||
let documents = json!([
|
|
||||||
{
|
|
||||||
"id": 1,
|
|
||||||
"content": "a",
|
|
||||||
"color": "green",
|
|
||||||
"size": 1,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": 2,
|
|
||||||
"content": "a",
|
|
||||||
"color": "green",
|
|
||||||
"size": 2,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": 3,
|
|
||||||
"content": "a",
|
|
||||||
"color": "blue",
|
|
||||||
"size": 3,
|
|
||||||
},
|
|
||||||
]);
|
|
||||||
|
|
||||||
server.add_or_update_multiple_documents(documents).await;
|
|
||||||
let (response, _) = server.search_post(json!({})).await;
|
|
||||||
assert_eq!(response["nbHits"], 3);
|
|
||||||
|
|
||||||
server.update_distinct_attribute(json!("color")).await;
|
|
||||||
|
|
||||||
let (response, _) = server.search_post(json!({})).await;
|
|
||||||
assert_eq!(response["nbHits"], 2);
|
|
||||||
|
|
||||||
let (response, _) = server.search_post(json!({"filters": "size < 3"})).await;
|
|
||||||
println!("result: {}", response);
|
|
||||||
assert_eq!(response["nbHits"], 1);
|
|
||||||
}
|
|
File diff suppressed because it is too large
Load Diff
@ -1,538 +0,0 @@
|
|||||||
use assert_json_diff::assert_json_eq;
|
|
||||||
use serde_json::json;
|
|
||||||
use std::convert::Into;
|
|
||||||
|
|
||||||
mod common;
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn search_with_settings_basic() {
|
|
||||||
let mut server = common::Server::test_server().await;
|
|
||||||
|
|
||||||
let config = json!({
|
|
||||||
"rankingRules": [
|
|
||||||
"typo",
|
|
||||||
"words",
|
|
||||||
"proximity",
|
|
||||||
"attribute",
|
|
||||||
"wordsPosition",
|
|
||||||
"desc(age)",
|
|
||||||
"exactness",
|
|
||||||
"desc(balance)"
|
|
||||||
],
|
|
||||||
"distinctAttribute": null,
|
|
||||||
"searchableAttributes": [
|
|
||||||
"name",
|
|
||||||
"age",
|
|
||||||
"color",
|
|
||||||
"gender",
|
|
||||||
"email",
|
|
||||||
"address",
|
|
||||||
"about"
|
|
||||||
],
|
|
||||||
"displayedAttributes": [
|
|
||||||
"name",
|
|
||||||
"age",
|
|
||||||
"gender",
|
|
||||||
"color",
|
|
||||||
"email",
|
|
||||||
"phone",
|
|
||||||
"address",
|
|
||||||
"balance"
|
|
||||||
],
|
|
||||||
"stopWords": null,
|
|
||||||
"synonyms": null,
|
|
||||||
});
|
|
||||||
|
|
||||||
server.update_all_settings(config).await;
|
|
||||||
|
|
||||||
let query = "q=ea%20exercitation&limit=3";
|
|
||||||
|
|
||||||
let expect = json!([
|
|
||||||
{
|
|
||||||
"balance": "$2,467.47",
|
|
||||||
"age": 34,
|
|
||||||
"color": "blue",
|
|
||||||
"name": "Patricia Goff",
|
|
||||||
"gender": "female",
|
|
||||||
"email": "patriciagoff@chorizon.com",
|
|
||||||
"phone": "+1 (864) 463-2277",
|
|
||||||
"address": "866 Hornell Loop, Cresaptown, Ohio, 1700"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"balance": "$3,344.40",
|
|
||||||
"age": 35,
|
|
||||||
"color": "blue",
|
|
||||||
"name": "Adeline Flynn",
|
|
||||||
"gender": "female",
|
|
||||||
"email": "adelineflynn@chorizon.com",
|
|
||||||
"phone": "+1 (994) 600-2840",
|
|
||||||
"address": "428 Paerdegat Avenue, Hollymead, Pennsylvania, 948"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"balance": "$3,394.96",
|
|
||||||
"age": 25,
|
|
||||||
"color": "blue",
|
|
||||||
"name": "Aida Kirby",
|
|
||||||
"gender": "female",
|
|
||||||
"email": "aidakirby@chorizon.com",
|
|
||||||
"phone": "+1 (942) 532-2325",
|
|
||||||
"address": "797 Engert Avenue, Wilsonia, Idaho, 6532"
|
|
||||||
}
|
|
||||||
]);
|
|
||||||
|
|
||||||
let (response, _status_code) = server.search_get(query).await;
|
|
||||||
assert_json_eq!(expect, response["hits"].clone(), ordered: false);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn search_with_settings_stop_words() {
|
|
||||||
let mut server = common::Server::test_server().await;
|
|
||||||
|
|
||||||
let config = json!({
|
|
||||||
"rankingRules": [
|
|
||||||
"typo",
|
|
||||||
"words",
|
|
||||||
"proximity",
|
|
||||||
"attribute",
|
|
||||||
"wordsPosition",
|
|
||||||
"desc(age)",
|
|
||||||
"exactness",
|
|
||||||
"desc(balance)"
|
|
||||||
],
|
|
||||||
"distinctAttribute": null,
|
|
||||||
"searchableAttributes": [
|
|
||||||
"name",
|
|
||||||
"age",
|
|
||||||
"color",
|
|
||||||
"gender",
|
|
||||||
"email",
|
|
||||||
"address",
|
|
||||||
"about"
|
|
||||||
],
|
|
||||||
"displayedAttributes": [
|
|
||||||
"name",
|
|
||||||
"age",
|
|
||||||
"gender",
|
|
||||||
"color",
|
|
||||||
"email",
|
|
||||||
"phone",
|
|
||||||
"address",
|
|
||||||
"balance"
|
|
||||||
],
|
|
||||||
"stopWords": ["ea"],
|
|
||||||
"synonyms": null,
|
|
||||||
});
|
|
||||||
|
|
||||||
server.update_all_settings(config).await;
|
|
||||||
|
|
||||||
let query = "q=ea%20exercitation&limit=3";
|
|
||||||
let expect = json!([
|
|
||||||
{
|
|
||||||
"balance": "$1,921.58",
|
|
||||||
"age": 31,
|
|
||||||
"color": "Green",
|
|
||||||
"name": "Harper Carson",
|
|
||||||
"gender": "male",
|
|
||||||
"email": "harpercarson@chorizon.com",
|
|
||||||
"phone": "+1 (912) 430-3243",
|
|
||||||
"address": "883 Dennett Place, Knowlton, New Mexico, 9219"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"balance": "$1,706.13",
|
|
||||||
"age": 27,
|
|
||||||
"color": "Green",
|
|
||||||
"name": "Cherry Orr",
|
|
||||||
"gender": "female",
|
|
||||||
"email": "cherryorr@chorizon.com",
|
|
||||||
"phone": "+1 (995) 479-3174",
|
|
||||||
"address": "442 Beverly Road, Ventress, New Mexico, 3361"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"balance": "$1,476.39",
|
|
||||||
"age": 28,
|
|
||||||
"color": "brown",
|
|
||||||
"name": "Maureen Dale",
|
|
||||||
"gender": "female",
|
|
||||||
"email": "maureendale@chorizon.com",
|
|
||||||
"phone": "+1 (984) 538-3684",
|
|
||||||
"address": "817 Newton Street, Bannock, Wyoming, 1468"
|
|
||||||
}
|
|
||||||
]);
|
|
||||||
|
|
||||||
let (response, _status_code) = server.search_get(query).await;
|
|
||||||
assert_json_eq!(expect, response["hits"].clone(), ordered: false);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn search_with_settings_synonyms() {
|
|
||||||
let mut server = common::Server::test_server().await;
|
|
||||||
|
|
||||||
let config = json!({
|
|
||||||
"rankingRules": [
|
|
||||||
"typo",
|
|
||||||
"words",
|
|
||||||
"proximity",
|
|
||||||
"attribute",
|
|
||||||
"wordsPosition",
|
|
||||||
"desc(age)",
|
|
||||||
"exactness",
|
|
||||||
"desc(balance)"
|
|
||||||
],
|
|
||||||
"distinctAttribute": null,
|
|
||||||
"searchableAttributes": [
|
|
||||||
"name",
|
|
||||||
"age",
|
|
||||||
"color",
|
|
||||||
"gender",
|
|
||||||
"email",
|
|
||||||
"address",
|
|
||||||
"about"
|
|
||||||
],
|
|
||||||
"displayedAttributes": [
|
|
||||||
"name",
|
|
||||||
"age",
|
|
||||||
"gender",
|
|
||||||
"color",
|
|
||||||
"email",
|
|
||||||
"phone",
|
|
||||||
"address",
|
|
||||||
"balance"
|
|
||||||
],
|
|
||||||
"stopWords": null,
|
|
||||||
"synonyms": {
|
|
||||||
"application": [
|
|
||||||
"exercitation"
|
|
||||||
]
|
|
||||||
},
|
|
||||||
});
|
|
||||||
|
|
||||||
server.update_all_settings(config).await;
|
|
||||||
|
|
||||||
let query = "q=application&limit=3";
|
|
||||||
let expect = json!([
|
|
||||||
{
|
|
||||||
"balance": "$1,921.58",
|
|
||||||
"age": 31,
|
|
||||||
"color": "Green",
|
|
||||||
"name": "Harper Carson",
|
|
||||||
"gender": "male",
|
|
||||||
"email": "harpercarson@chorizon.com",
|
|
||||||
"phone": "+1 (912) 430-3243",
|
|
||||||
"address": "883 Dennett Place, Knowlton, New Mexico, 9219"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"balance": "$1,706.13",
|
|
||||||
"age": 27,
|
|
||||||
"color": "Green",
|
|
||||||
"name": "Cherry Orr",
|
|
||||||
"gender": "female",
|
|
||||||
"email": "cherryorr@chorizon.com",
|
|
||||||
"phone": "+1 (995) 479-3174",
|
|
||||||
"address": "442 Beverly Road, Ventress, New Mexico, 3361"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"balance": "$1,476.39",
|
|
||||||
"age": 28,
|
|
||||||
"color": "brown",
|
|
||||||
"name": "Maureen Dale",
|
|
||||||
"gender": "female",
|
|
||||||
"email": "maureendale@chorizon.com",
|
|
||||||
"phone": "+1 (984) 538-3684",
|
|
||||||
"address": "817 Newton Street, Bannock, Wyoming, 1468"
|
|
||||||
}
|
|
||||||
]);
|
|
||||||
|
|
||||||
let (response, _status_code) = server.search_get(query).await;
|
|
||||||
assert_json_eq!(expect, response["hits"].clone(), ordered: false);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn search_with_settings_ranking_rules() {
|
|
||||||
let mut server = common::Server::test_server().await;
|
|
||||||
|
|
||||||
let config = json!({
|
|
||||||
"rankingRules": [
|
|
||||||
"typo",
|
|
||||||
"words",
|
|
||||||
"proximity",
|
|
||||||
"attribute",
|
|
||||||
"wordsPosition",
|
|
||||||
"desc(age)",
|
|
||||||
"exactness",
|
|
||||||
"desc(balance)"
|
|
||||||
],
|
|
||||||
"distinctAttribute": null,
|
|
||||||
"searchableAttributes": [
|
|
||||||
"name",
|
|
||||||
"age",
|
|
||||||
"color",
|
|
||||||
"gender",
|
|
||||||
"email",
|
|
||||||
"address",
|
|
||||||
"about"
|
|
||||||
],
|
|
||||||
"displayedAttributes": [
|
|
||||||
"name",
|
|
||||||
"age",
|
|
||||||
"gender",
|
|
||||||
"color",
|
|
||||||
"email",
|
|
||||||
"phone",
|
|
||||||
"address",
|
|
||||||
"balance"
|
|
||||||
],
|
|
||||||
"stopWords": null,
|
|
||||||
"synonyms": null,
|
|
||||||
});
|
|
||||||
|
|
||||||
server.update_all_settings(config).await;
|
|
||||||
|
|
||||||
let query = "q=exarcitation&limit=3";
|
|
||||||
let expect = json!([
|
|
||||||
{
|
|
||||||
"balance": "$1,921.58",
|
|
||||||
"age": 31,
|
|
||||||
"color": "Green",
|
|
||||||
"name": "Harper Carson",
|
|
||||||
"gender": "male",
|
|
||||||
"email": "harpercarson@chorizon.com",
|
|
||||||
"phone": "+1 (912) 430-3243",
|
|
||||||
"address": "883 Dennett Place, Knowlton, New Mexico, 9219"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"balance": "$1,706.13",
|
|
||||||
"age": 27,
|
|
||||||
"color": "Green",
|
|
||||||
"name": "Cherry Orr",
|
|
||||||
"gender": "female",
|
|
||||||
"email": "cherryorr@chorizon.com",
|
|
||||||
"phone": "+1 (995) 479-3174",
|
|
||||||
"address": "442 Beverly Road, Ventress, New Mexico, 3361"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"balance": "$1,476.39",
|
|
||||||
"age": 28,
|
|
||||||
"color": "brown",
|
|
||||||
"name": "Maureen Dale",
|
|
||||||
"gender": "female",
|
|
||||||
"email": "maureendale@chorizon.com",
|
|
||||||
"phone": "+1 (984) 538-3684",
|
|
||||||
"address": "817 Newton Street, Bannock, Wyoming, 1468"
|
|
||||||
}
|
|
||||||
]);
|
|
||||||
|
|
||||||
let (response, _status_code) = server.search_get(query).await;
|
|
||||||
println!("{}", response["hits"].clone());
|
|
||||||
assert_json_eq!(expect, response["hits"].clone(), ordered: false);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn search_with_settings_searchable_attributes() {
|
|
||||||
let mut server = common::Server::test_server().await;
|
|
||||||
|
|
||||||
let config = json!({
|
|
||||||
"rankingRules": [
|
|
||||||
"typo",
|
|
||||||
"words",
|
|
||||||
"proximity",
|
|
||||||
"attribute",
|
|
||||||
"wordsPosition",
|
|
||||||
"desc(age)",
|
|
||||||
"exactness",
|
|
||||||
"desc(balance)"
|
|
||||||
],
|
|
||||||
"distinctAttribute": null,
|
|
||||||
"searchableAttributes": [
|
|
||||||
"age",
|
|
||||||
"color",
|
|
||||||
"gender",
|
|
||||||
"address",
|
|
||||||
"about"
|
|
||||||
],
|
|
||||||
"displayedAttributes": [
|
|
||||||
"name",
|
|
||||||
"age",
|
|
||||||
"gender",
|
|
||||||
"color",
|
|
||||||
"email",
|
|
||||||
"phone",
|
|
||||||
"address",
|
|
||||||
"balance"
|
|
||||||
],
|
|
||||||
"stopWords": null,
|
|
||||||
"synonyms": {
|
|
||||||
"exarcitation": [
|
|
||||||
"exercitation"
|
|
||||||
]
|
|
||||||
},
|
|
||||||
});
|
|
||||||
|
|
||||||
server.update_all_settings(config).await;
|
|
||||||
|
|
||||||
let query = "q=Carol&limit=3";
|
|
||||||
let expect = json!([
|
|
||||||
{
|
|
||||||
"balance": "$1,440.09",
|
|
||||||
"age": 40,
|
|
||||||
"color": "blue",
|
|
||||||
"name": "Levy Whitley",
|
|
||||||
"gender": "male",
|
|
||||||
"email": "levywhitley@chorizon.com",
|
|
||||||
"phone": "+1 (911) 458-2411",
|
|
||||||
"address": "187 Thomas Street, Hachita, North Carolina, 2989"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"balance": "$1,977.66",
|
|
||||||
"age": 36,
|
|
||||||
"color": "brown",
|
|
||||||
"name": "Combs Stanley",
|
|
||||||
"gender": "male",
|
|
||||||
"email": "combsstanley@chorizon.com",
|
|
||||||
"phone": "+1 (827) 419-2053",
|
|
||||||
"address": "153 Beverley Road, Siglerville, South Carolina, 3666"
|
|
||||||
}
|
|
||||||
]);
|
|
||||||
|
|
||||||
let (response, _status_code) = server.search_get(query).await;
|
|
||||||
assert_json_eq!(expect, response["hits"].clone(), ordered: false);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn search_with_settings_displayed_attributes() {
|
|
||||||
let mut server = common::Server::test_server().await;
|
|
||||||
|
|
||||||
let config = json!({
|
|
||||||
"rankingRules": [
|
|
||||||
"typo",
|
|
||||||
"words",
|
|
||||||
"proximity",
|
|
||||||
"attribute",
|
|
||||||
"wordsPosition",
|
|
||||||
"desc(age)",
|
|
||||||
"exactness",
|
|
||||||
"desc(balance)"
|
|
||||||
],
|
|
||||||
"distinctAttribute": null,
|
|
||||||
"searchableAttributes": [
|
|
||||||
"age",
|
|
||||||
"color",
|
|
||||||
"gender",
|
|
||||||
"address",
|
|
||||||
"about"
|
|
||||||
],
|
|
||||||
"displayedAttributes": [
|
|
||||||
"name",
|
|
||||||
"age",
|
|
||||||
"gender",
|
|
||||||
"color",
|
|
||||||
"email",
|
|
||||||
"phone"
|
|
||||||
],
|
|
||||||
"stopWords": null,
|
|
||||||
"synonyms": null,
|
|
||||||
});
|
|
||||||
|
|
||||||
server.update_all_settings(config).await;
|
|
||||||
|
|
||||||
let query = "q=exercitation&limit=3";
|
|
||||||
let expect = json!([
|
|
||||||
{
|
|
||||||
"age": 31,
|
|
||||||
"color": "Green",
|
|
||||||
"name": "Harper Carson",
|
|
||||||
"gender": "male",
|
|
||||||
"email": "harpercarson@chorizon.com",
|
|
||||||
"phone": "+1 (912) 430-3243"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"age": 27,
|
|
||||||
"color": "Green",
|
|
||||||
"name": "Cherry Orr",
|
|
||||||
"gender": "female",
|
|
||||||
"email": "cherryorr@chorizon.com",
|
|
||||||
"phone": "+1 (995) 479-3174"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"age": 28,
|
|
||||||
"color": "brown",
|
|
||||||
"name": "Maureen Dale",
|
|
||||||
"gender": "female",
|
|
||||||
"email": "maureendale@chorizon.com",
|
|
||||||
"phone": "+1 (984) 538-3684"
|
|
||||||
}
|
|
||||||
]);
|
|
||||||
|
|
||||||
let (response, _status_code) = server.search_get(query).await;
|
|
||||||
assert_json_eq!(expect, response["hits"].clone(), ordered: false);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn search_with_settings_searchable_attributes_2() {
|
|
||||||
let mut server = common::Server::test_server().await;
|
|
||||||
|
|
||||||
let config = json!({
|
|
||||||
"rankingRules": [
|
|
||||||
"typo",
|
|
||||||
"words",
|
|
||||||
"proximity",
|
|
||||||
"attribute",
|
|
||||||
"wordsPosition",
|
|
||||||
"desc(age)",
|
|
||||||
"exactness",
|
|
||||||
"desc(balance)"
|
|
||||||
],
|
|
||||||
"distinctAttribute": null,
|
|
||||||
"searchableAttributes": [
|
|
||||||
"age",
|
|
||||||
"color",
|
|
||||||
"gender",
|
|
||||||
"address",
|
|
||||||
"about"
|
|
||||||
],
|
|
||||||
"displayedAttributes": [
|
|
||||||
"name",
|
|
||||||
"age",
|
|
||||||
"gender"
|
|
||||||
],
|
|
||||||
"stopWords": null,
|
|
||||||
"synonyms": null,
|
|
||||||
});
|
|
||||||
|
|
||||||
server.update_all_settings(config).await;
|
|
||||||
|
|
||||||
let query = "q=exercitation&limit=3";
|
|
||||||
let expect = json!([
|
|
||||||
{
|
|
||||||
"age": 31,
|
|
||||||
"name": "Harper Carson",
|
|
||||||
"gender": "male"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"age": 27,
|
|
||||||
"name": "Cherry Orr",
|
|
||||||
"gender": "female"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"age": 28,
|
|
||||||
"name": "Maureen Dale",
|
|
||||||
"gender": "female"
|
|
||||||
}
|
|
||||||
]);
|
|
||||||
|
|
||||||
let (response, _status_code) = server.search_get(query).await;
|
|
||||||
assert_json_eq!(expect, response["hits"].clone(), ordered: false);
|
|
||||||
}
|
|
||||||
|
|
||||||
// issue #798
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn distinct_attributes_returns_name_not_id() {
|
|
||||||
let mut server = common::Server::test_server().await;
|
|
||||||
let settings = json!({
|
|
||||||
"distinctAttribute": "color",
|
|
||||||
});
|
|
||||||
server.update_all_settings(settings).await;
|
|
||||||
let (response, _) = server.get_all_settings().await;
|
|
||||||
assert_eq!(response["distinctAttribute"], "color");
|
|
||||||
let (response, _) = server.get_distinct_attribute().await;
|
|
||||||
assert_eq!(response, "color");
|
|
||||||
}
|
|
@ -1,523 +0,0 @@
|
|||||||
use assert_json_diff::assert_json_eq;
|
|
||||||
use serde_json::json;
|
|
||||||
use std::convert::Into;
|
|
||||||
mod common;
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn write_all_and_delete() {
|
|
||||||
let mut server = common::Server::test_server().await;
|
|
||||||
// 2 - Send the settings
|
|
||||||
|
|
||||||
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": [
|
|
||||||
"name",
|
|
||||||
"gender",
|
|
||||||
"email",
|
|
||||||
"registered",
|
|
||||||
"age",
|
|
||||||
],
|
|
||||||
"stopWords": [
|
|
||||||
"ad",
|
|
||||||
"in",
|
|
||||||
"ut",
|
|
||||||
],
|
|
||||||
"synonyms": {
|
|
||||||
"road": ["street", "avenue"],
|
|
||||||
"street": ["avenue"],
|
|
||||||
},
|
|
||||||
"attributesForFaceting": ["name"],
|
|
||||||
});
|
|
||||||
|
|
||||||
server.update_all_settings(body.clone()).await;
|
|
||||||
|
|
||||||
// 3 - Get all settings and compare to the previous one
|
|
||||||
|
|
||||||
let (response, _status_code) = server.get_all_settings().await;
|
|
||||||
|
|
||||||
assert_json_eq!(body, response, ordered: false);
|
|
||||||
|
|
||||||
// 4 - Delete all settings
|
|
||||||
|
|
||||||
server.delete_all_settings().await;
|
|
||||||
|
|
||||||
// 5 - Get all settings and check if they are set to default values
|
|
||||||
|
|
||||||
let (response, _status_code) = server.get_all_settings().await;
|
|
||||||
|
|
||||||
let expect = json!({
|
|
||||||
"rankingRules": [
|
|
||||||
"typo",
|
|
||||||
"words",
|
|
||||||
"proximity",
|
|
||||||
"attribute",
|
|
||||||
"wordsPosition",
|
|
||||||
"exactness"
|
|
||||||
],
|
|
||||||
"distinctAttribute": null,
|
|
||||||
"searchableAttributes": ["*"],
|
|
||||||
"displayedAttributes": ["*"],
|
|
||||||
"stopWords": [],
|
|
||||||
"synonyms": {},
|
|
||||||
"attributesForFaceting": [],
|
|
||||||
});
|
|
||||||
|
|
||||||
assert_json_eq!(expect, response, ordered: false);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn write_all_and_update() {
|
|
||||||
let mut server = common::Server::test_server().await;
|
|
||||||
|
|
||||||
// 2 - Send the settings
|
|
||||||
|
|
||||||
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": [
|
|
||||||
"name",
|
|
||||||
"gender",
|
|
||||||
"email",
|
|
||||||
"registered",
|
|
||||||
"age",
|
|
||||||
],
|
|
||||||
"stopWords": [
|
|
||||||
"ad",
|
|
||||||
"in",
|
|
||||||
"ut",
|
|
||||||
],
|
|
||||||
"synonyms": {
|
|
||||||
"road": ["street", "avenue"],
|
|
||||||
"street": ["avenue"],
|
|
||||||
},
|
|
||||||
"attributesForFaceting": ["name"],
|
|
||||||
});
|
|
||||||
|
|
||||||
server.update_all_settings(body.clone()).await;
|
|
||||||
|
|
||||||
// 3 - Get all settings and compare to the previous one
|
|
||||||
|
|
||||||
let (response, _status_code) = server.get_all_settings().await;
|
|
||||||
|
|
||||||
assert_json_eq!(body, response, ordered: false);
|
|
||||||
|
|
||||||
// 4 - Update all settings
|
|
||||||
|
|
||||||
let body = json!({
|
|
||||||
"rankingRules": [
|
|
||||||
"typo",
|
|
||||||
"words",
|
|
||||||
"proximity",
|
|
||||||
"attribute",
|
|
||||||
"wordsPosition",
|
|
||||||
"exactness",
|
|
||||||
"desc(age)",
|
|
||||||
],
|
|
||||||
"distinctAttribute": null,
|
|
||||||
"searchableAttributes": [
|
|
||||||
"name",
|
|
||||||
"color",
|
|
||||||
"age",
|
|
||||||
],
|
|
||||||
"displayedAttributes": [
|
|
||||||
"name",
|
|
||||||
"color",
|
|
||||||
"age",
|
|
||||||
"registered",
|
|
||||||
"picture",
|
|
||||||
],
|
|
||||||
"stopWords": [],
|
|
||||||
"synonyms": {
|
|
||||||
"road": ["street", "avenue"],
|
|
||||||
"street": ["avenue"],
|
|
||||||
},
|
|
||||||
"attributesForFaceting": ["title"],
|
|
||||||
});
|
|
||||||
|
|
||||||
server.update_all_settings(body).await;
|
|
||||||
|
|
||||||
// 5 - Get all settings and check if the content is the same of (4)
|
|
||||||
|
|
||||||
let (response, _status_code) = server.get_all_settings().await;
|
|
||||||
|
|
||||||
let expected = json!({
|
|
||||||
"rankingRules": [
|
|
||||||
"typo",
|
|
||||||
"words",
|
|
||||||
"proximity",
|
|
||||||
"attribute",
|
|
||||||
"wordsPosition",
|
|
||||||
"exactness",
|
|
||||||
"desc(age)",
|
|
||||||
],
|
|
||||||
"distinctAttribute": null,
|
|
||||||
"searchableAttributes": [
|
|
||||||
"name",
|
|
||||||
"color",
|
|
||||||
"age",
|
|
||||||
],
|
|
||||||
"displayedAttributes": [
|
|
||||||
"name",
|
|
||||||
"color",
|
|
||||||
"age",
|
|
||||||
"registered",
|
|
||||||
"picture",
|
|
||||||
],
|
|
||||||
"stopWords": [],
|
|
||||||
"synonyms": {
|
|
||||||
"road": ["street", "avenue"],
|
|
||||||
"street": ["avenue"],
|
|
||||||
},
|
|
||||||
"attributesForFaceting": ["title"],
|
|
||||||
});
|
|
||||||
|
|
||||||
assert_json_eq!(expected, response, ordered: false);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn test_default_settings() {
|
|
||||||
let mut server = common::Server::with_uid("test");
|
|
||||||
let body = json!({
|
|
||||||
"uid": "test",
|
|
||||||
});
|
|
||||||
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,
|
|
||||||
"searchableAttributes": ["*"],
|
|
||||||
"displayedAttributes": ["*"],
|
|
||||||
"stopWords": [],
|
|
||||||
"synonyms": {},
|
|
||||||
"attributesForFaceting": [],
|
|
||||||
});
|
|
||||||
|
|
||||||
let (response, _status_code) = server.get_all_settings().await;
|
|
||||||
|
|
||||||
assert_json_eq!(body, response, ordered: false);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn test_default_settings_2() {
|
|
||||||
let mut server = common::Server::with_uid("test");
|
|
||||||
let body = json!({
|
|
||||||
"uid": "test",
|
|
||||||
"primaryKey": "id",
|
|
||||||
});
|
|
||||||
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,
|
|
||||||
"searchableAttributes": ["*"],
|
|
||||||
"displayedAttributes": ["*"],
|
|
||||||
"stopWords": [],
|
|
||||||
"synonyms": {},
|
|
||||||
"attributesForFaceting": [],
|
|
||||||
});
|
|
||||||
|
|
||||||
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
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn write_setting_and_update_partial() {
|
|
||||||
let mut server = common::Server::with_uid("test");
|
|
||||||
let body = json!({
|
|
||||||
"uid": "test",
|
|
||||||
});
|
|
||||||
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",
|
|
||||||
]
|
|
||||||
});
|
|
||||||
|
|
||||||
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"],
|
|
||||||
},
|
|
||||||
});
|
|
||||||
|
|
||||||
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"],
|
|
||||||
},
|
|
||||||
"attributesForFaceting": [],
|
|
||||||
});
|
|
||||||
|
|
||||||
let (response, _status_code) = server.get_all_settings().await;
|
|
||||||
|
|
||||||
assert_json_eq!(expected, response, ordered: false);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[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!([]));
|
|
||||||
}
|
|
||||||
|
|
||||||
#[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"));
|
|
||||||
}
|
|
||||||
|
|
||||||
#[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;
|
|
||||||
|
|
||||||
assert_eq!(response["searchableAttributes"].as_array().unwrap()[0], "color");
|
|
||||||
assert_eq!(response["displayedAttributes"].as_array().unwrap()[0], "color");
|
|
||||||
|
|
||||||
server.delete_searchable_attributes().await;
|
|
||||||
server.delete_displayed_attributes().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);
|
|
||||||
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;
|
|
||||||
|
|
||||||
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);
|
|
||||||
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);
|
|
||||||
assert_eq!(response["searchableAttributes"].as_array().unwrap()[0], "*");
|
|
||||||
assert_eq!(response["displayedAttributes"].as_array().unwrap()[0], "*");
|
|
||||||
}
|
|
||||||
|
|
||||||
#[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);
|
|
||||||
}
|
|
@ -1,182 +0,0 @@
|
|||||||
use assert_json_diff::assert_json_eq;
|
|
||||||
use serde_json::json;
|
|
||||||
|
|
||||||
mod common;
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn write_all_and_delete() {
|
|
||||||
let mut server = common::Server::test_server().await;
|
|
||||||
|
|
||||||
// 2 - Send the settings
|
|
||||||
|
|
||||||
let body = json!([
|
|
||||||
"typo",
|
|
||||||
"words",
|
|
||||||
"proximity",
|
|
||||||
"attribute",
|
|
||||||
"wordsPosition",
|
|
||||||
"exactness",
|
|
||||||
"desc(registered)",
|
|
||||||
"desc(age)",
|
|
||||||
]);
|
|
||||||
|
|
||||||
server.update_ranking_rules(body.clone()).await;
|
|
||||||
|
|
||||||
// 3 - Get all settings and compare to the previous one
|
|
||||||
|
|
||||||
let (response, _status_code) = server.get_ranking_rules().await;
|
|
||||||
|
|
||||||
assert_json_eq!(body, response, ordered: false);
|
|
||||||
|
|
||||||
// 4 - Delete all settings
|
|
||||||
|
|
||||||
server.delete_ranking_rules().await;
|
|
||||||
|
|
||||||
// 5 - Get all settings and check if they are empty
|
|
||||||
|
|
||||||
let (response, _status_code) = server.get_ranking_rules().await;
|
|
||||||
|
|
||||||
let expected = json!([
|
|
||||||
"typo",
|
|
||||||
"words",
|
|
||||||
"proximity",
|
|
||||||
"attribute",
|
|
||||||
"wordsPosition",
|
|
||||||
"exactness"
|
|
||||||
]);
|
|
||||||
|
|
||||||
assert_json_eq!(expected, response, ordered: false);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn write_all_and_update() {
|
|
||||||
let mut server = common::Server::test_server().await;
|
|
||||||
|
|
||||||
// 2 - Send the settings
|
|
||||||
|
|
||||||
let body = json!([
|
|
||||||
"typo",
|
|
||||||
"words",
|
|
||||||
"proximity",
|
|
||||||
"attribute",
|
|
||||||
"wordsPosition",
|
|
||||||
"exactness",
|
|
||||||
"desc(registered)",
|
|
||||||
"desc(age)",
|
|
||||||
]);
|
|
||||||
|
|
||||||
server.update_ranking_rules(body.clone()).await;
|
|
||||||
|
|
||||||
// 3 - Get all settings and compare to the previous one
|
|
||||||
|
|
||||||
let (response, _status_code) = server.get_ranking_rules().await;
|
|
||||||
|
|
||||||
assert_json_eq!(body, response, ordered: false);
|
|
||||||
|
|
||||||
// 4 - Update all settings
|
|
||||||
|
|
||||||
let body = json!([
|
|
||||||
"typo",
|
|
||||||
"words",
|
|
||||||
"proximity",
|
|
||||||
"attribute",
|
|
||||||
"wordsPosition",
|
|
||||||
"exactness",
|
|
||||||
"desc(registered)",
|
|
||||||
]);
|
|
||||||
|
|
||||||
server.update_ranking_rules(body).await;
|
|
||||||
|
|
||||||
// 5 - Get all settings and check if the content is the same of (4)
|
|
||||||
|
|
||||||
let (response, _status_code) = server.get_ranking_rules().await;
|
|
||||||
|
|
||||||
let expected = json!([
|
|
||||||
"typo",
|
|
||||||
"words",
|
|
||||||
"proximity",
|
|
||||||
"attribute",
|
|
||||||
"wordsPosition",
|
|
||||||
"exactness",
|
|
||||||
"desc(registered)",
|
|
||||||
]);
|
|
||||||
|
|
||||||
assert_json_eq!(expected, response, ordered: false);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn send_undefined_rule() {
|
|
||||||
let mut server = common::Server::with_uid("test");
|
|
||||||
let body = json!({
|
|
||||||
"uid": "test",
|
|
||||||
"primaryKey": "id",
|
|
||||||
});
|
|
||||||
server.create_index(body).await;
|
|
||||||
|
|
||||||
let body = json!(["typos",]);
|
|
||||||
|
|
||||||
let (_response, status_code) = server.update_ranking_rules_sync(body).await;
|
|
||||||
assert_eq!(status_code, 400);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn send_malformed_custom_rule() {
|
|
||||||
let mut server = common::Server::with_uid("test");
|
|
||||||
let body = json!({
|
|
||||||
"uid": "test",
|
|
||||||
"primaryKey": "id",
|
|
||||||
});
|
|
||||||
server.create_index(body).await;
|
|
||||||
|
|
||||||
let body = json!(["dsc(truc)",]);
|
|
||||||
|
|
||||||
let (_response, status_code) = server.update_ranking_rules_sync(body).await;
|
|
||||||
assert_eq!(status_code, 400);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Test issue https://github.com/meilisearch/MeiliSearch/issues/521
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn write_custom_ranking_and_index_documents() {
|
|
||||||
let mut server = common::Server::with_uid("test");
|
|
||||||
let body = json!({
|
|
||||||
"uid": "test",
|
|
||||||
"primaryKey": "id",
|
|
||||||
});
|
|
||||||
server.create_index(body).await;
|
|
||||||
|
|
||||||
// 1 - Add ranking rules with one custom ranking on a string
|
|
||||||
|
|
||||||
let body = json!(["asc(name)", "typo"]);
|
|
||||||
|
|
||||||
server.update_ranking_rules(body).await;
|
|
||||||
|
|
||||||
// 2 - Add documents
|
|
||||||
|
|
||||||
let body = json!([
|
|
||||||
{
|
|
||||||
"id": 1,
|
|
||||||
"name": "Cherry Orr",
|
|
||||||
"color": "green"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"id": 2,
|
|
||||||
"name": "Lucas Hess",
|
|
||||||
"color": "yellow"
|
|
||||||
}
|
|
||||||
]);
|
|
||||||
|
|
||||||
server.add_or_replace_multiple_documents(body).await;
|
|
||||||
|
|
||||||
// 3 - Get the first document and compare
|
|
||||||
|
|
||||||
let expected = json!({
|
|
||||||
"id": 1,
|
|
||||||
"name": "Cherry Orr",
|
|
||||||
"color": "green"
|
|
||||||
});
|
|
||||||
|
|
||||||
let (response, status_code) = server.get_document(1).await;
|
|
||||||
assert_eq!(status_code, 200);
|
|
||||||
|
|
||||||
assert_json_eq!(response, expected, ordered: false);
|
|
||||||
}
|
|
@ -1,61 +0,0 @@
|
|||||||
use assert_json_diff::assert_json_eq;
|
|
||||||
use serde_json::json;
|
|
||||||
|
|
||||||
mod common;
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn update_stop_words() {
|
|
||||||
let mut server = common::Server::test_server().await;
|
|
||||||
|
|
||||||
// 1 - Get stop words
|
|
||||||
|
|
||||||
let (response, _status_code) = server.get_stop_words().await;
|
|
||||||
assert_eq!(response.as_array().unwrap().is_empty(), true);
|
|
||||||
|
|
||||||
// 2 - Update stop words
|
|
||||||
|
|
||||||
let body = json!(["ut", "ea"]);
|
|
||||||
server.update_stop_words(body.clone()).await;
|
|
||||||
|
|
||||||
// 3 - Get all stop words and compare to the previous one
|
|
||||||
|
|
||||||
let (response, _status_code) = server.get_stop_words().await;
|
|
||||||
assert_json_eq!(body, response, ordered: false);
|
|
||||||
|
|
||||||
// 4 - Delete all stop words
|
|
||||||
|
|
||||||
server.delete_stop_words().await;
|
|
||||||
|
|
||||||
// 5 - Get all stop words and check if they are empty
|
|
||||||
|
|
||||||
let (response, _status_code) = server.get_stop_words().await;
|
|
||||||
assert_eq!(response.as_array().unwrap().is_empty(), true);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn add_documents_and_stop_words() {
|
|
||||||
let mut server = common::Server::test_server().await;
|
|
||||||
|
|
||||||
// 2 - Update stop words
|
|
||||||
|
|
||||||
let body = json!(["ad", "in"]);
|
|
||||||
server.update_stop_words(body.clone()).await;
|
|
||||||
|
|
||||||
// 3 - Search for a document with stop words
|
|
||||||
|
|
||||||
let (response, _status_code) = server.search_get("q=in%20exercitation").await;
|
|
||||||
assert!(!response["hits"].as_array().unwrap().is_empty());
|
|
||||||
|
|
||||||
// 4 - Search for documents with *only* stop words
|
|
||||||
|
|
||||||
let (response, _status_code) = server.search_get("q=ad%20in").await;
|
|
||||||
assert!(response["hits"].as_array().unwrap().is_empty());
|
|
||||||
|
|
||||||
// 5 - Delete all stop words
|
|
||||||
|
|
||||||
// server.delete_stop_words();
|
|
||||||
|
|
||||||
// // 6 - Search for a document with one stop word
|
|
||||||
|
|
||||||
// assert!(!response["hits"].as_array().unwrap().is_empty());
|
|
||||||
}
|
|
@ -1,18 +0,0 @@
|
|||||||
mod common;
|
|
||||||
|
|
||||||
#[actix_rt::test]
|
|
||||||
async fn url_normalizer() {
|
|
||||||
let mut server = common::Server::with_uid("movies");
|
|
||||||
|
|
||||||
let (_response, status_code) = server.get_request("/version").await;
|
|
||||||
assert_eq!(status_code, 200);
|
|
||||||
|
|
||||||
let (_response, status_code) = server.get_request("//version").await;
|
|
||||||
assert_eq!(status_code, 200);
|
|
||||||
|
|
||||||
let (_response, status_code) = server.get_request("/version/").await;
|
|
||||||
assert_eq!(status_code, 200);
|
|
||||||
|
|
||||||
let (_response, status_code) = server.get_request("//version/").await;
|
|
||||||
assert_eq!(status_code, 200);
|
|
||||||
}
|
|
Loading…
Reference in New Issue
Block a user