MeiliSearch/meilisearch/tests/common/mod.rs

125 lines
3.5 KiB
Rust
Raw Normal View History

pub mod encoder;
2021-03-24 11:03:01 +01:00
pub mod index;
pub mod server;
pub mod service;
2021-02-18 19:50:52 +01:00
2023-09-11 16:50:53 +02:00
use std::fmt::{self, Display};
2023-10-30 11:00:46 +01:00
#[allow(unused)]
pub use index::GetAllDocumentsOptions;
2023-09-11 16:50:53 +02:00
use meili_snap::json_string;
use serde::{Deserialize, Serialize};
2023-10-30 11:00:46 +01:00
#[allow(unused)]
2022-04-28 10:48:57 +02:00
pub use server::{default_settings, Server};
2021-02-18 19:50:52 +01:00
2023-09-11 16:50:53 +02:00
#[derive(Debug, Clone, Default, Serialize, Deserialize, PartialEq, Eq)]
pub struct Value(pub serde_json::Value);
impl Value {
#[track_caller]
2023-09-11 16:50:53 +02:00
pub fn uid(&self) -> u64 {
if let Some(uid) = self["uid"].as_u64() {
uid
} else if let Some(uid) = self["taskUid"].as_u64() {
uid
} else {
panic!("Didn't find any task id in: {self}");
}
}
// Panic if the json doesn't contain the `status` field set to "succeeded"
#[track_caller]
pub fn succeeded(&self) -> &Self {
if self["status"] != serde_json::Value::String(String::from("succeeded")) {
panic!("Called succeeded on {}", serde_json::to_string_pretty(&self.0).unwrap());
}
self
}
2023-09-11 16:50:53 +02:00
}
2023-09-11 17:02:01 +02:00
impl From<serde_json::Value> for Value {
fn from(value: serde_json::Value) -> Self {
Value(value)
2023-09-11 16:50:53 +02:00
}
}
impl std::ops::Deref for Value {
type Target = serde_json::Value;
fn deref(&self) -> &Self::Target {
&self.0
}
}
impl std::ops::DerefMut for Value {
fn deref_mut(&mut self) -> &mut Self::Target {
&mut self.0
}
}
2023-09-11 16:50:53 +02:00
impl PartialEq<serde_json::Value> for Value {
fn eq(&self, other: &serde_json::Value) -> bool {
&self.0 == other
}
}
impl PartialEq<Value> for serde_json::Value {
fn eq(&self, other: &Value) -> bool {
self == &other.0
}
}
impl PartialEq<&str> for Value {
fn eq(&self, other: &&str) -> bool {
self.0.eq(other)
}
}
impl Display for Value {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
write!(
f,
"{}",
2024-06-12 18:27:03 +02:00
json_string!(self, {
2024-07-31 17:57:13 +02:00
".uid" => "[uid]",
2024-06-12 18:27:03 +02:00
".enqueuedAt" => "[date]",
".startedAt" => "[date]",
".finishedAt" => "[date]",
".duration" => "[duration]",
".processingTimeMs" => "[duration]",
".details.embedders.*.url" => "[url]"
})
2023-09-11 16:50:53 +02:00
)
}
}
impl From<Vec<Value>> for Value {
fn from(value: Vec<Value>) -> Self {
Self(value.into_iter().map(|value| value.0).collect::<serde_json::Value>())
}
}
#[macro_export]
macro_rules! json {
($($json:tt)+) => {
$crate::common::Value(serde_json::json!($($json)+))
};
}
2021-02-18 19:50:52 +01:00
/// Performs a search test on both post and get routes
#[macro_export]
macro_rules! test_post_get_search {
($server:expr, $query:expr, |$response:ident, $status_code:ident | $block:expr) => {
let post_query: meilisearch::routes::search::SearchQueryPost =
2021-02-18 19:50:52 +01:00
serde_json::from_str(&$query.clone().to_string()).unwrap();
let get_query: meilisearch::routes::search::SearchQuery = post_query.into();
2021-02-18 19:50:52 +01:00
let get_query = ::serde_url_params::to_string(&get_query).unwrap();
let ($response, $status_code) = $server.search_get(&get_query).await;
2022-10-20 18:00:07 +02:00
let _ = ::std::panic::catch_unwind(|| $block)
.map_err(|e| panic!("panic in get route: {:?}", e.downcast_ref::<&str>().unwrap()));
2021-02-18 19:50:52 +01:00
let ($response, $status_code) = $server.search_post($query).await;
2022-10-20 18:00:07 +02:00
let _ = ::std::panic::catch_unwind(|| $block)
.map_err(|e| panic!("panic in post route: {:?}", e.downcast_ref::<&str>().unwrap()));
2021-02-18 19:50:52 +01:00
};
}