mirror of
https://github.com/meilisearch/meilisearch.git
synced 2025-01-18 08:48:32 +08:00
add tests for error codes
This commit is contained in:
parent
6445eea946
commit
7d3e937134
126
meilisearch-http/tests/errors.rs
Normal file
126
meilisearch-http/tests/errors.rs
Normal file
@ -0,0 +1,126 @@
|
|||||||
|
mod common;
|
||||||
|
|
||||||
|
use serde_json::json;
|
||||||
|
use actix_http::http::StatusCode;
|
||||||
|
|
||||||
|
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);
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
#[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);
|
||||||
|
assert_error!(
|
||||||
|
"index_already_exists",
|
||||||
|
"invalid_request_error",
|
||||||
|
StatusCode::BAD_REQUEST,
|
||||||
|
server.create_index(body).await);
|
||||||
|
}
|
||||||
|
|
||||||
|
#[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]
|
||||||
|
#[ignore]
|
||||||
|
async fn max_field_limit_exceeded_error() {
|
||||||
|
todo!("error reported in update")
|
||||||
|
}
|
||||||
|
|
||||||
|
#[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);
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user