mirror of
https://github.com/meilisearch/MeiliSearch
synced 2024-11-22 21:04:27 +01:00
add tests to IndexResolver BatchHandler
This commit is contained in:
parent
3c85b29865
commit
92d86ce6aa
@ -56,3 +56,101 @@ where
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[cfg(test)]
|
||||||
|
mod test {
|
||||||
|
use crate::index_resolver::{index_store::MockIndexStore, meta_store::MockIndexMetaStore};
|
||||||
|
use crate::tasks::{
|
||||||
|
handlers::test::task_to_batch,
|
||||||
|
task::{Task, TaskContent},
|
||||||
|
};
|
||||||
|
use crate::update_file_store::{Result as FileStoreResult, UpdateFileStore};
|
||||||
|
|
||||||
|
use super::*;
|
||||||
|
use milli::update::IndexDocumentsMethod;
|
||||||
|
use nelson::Mocker;
|
||||||
|
use proptest::prelude::*;
|
||||||
|
use uuid::Uuid;
|
||||||
|
|
||||||
|
proptest! {
|
||||||
|
#[test]
|
||||||
|
fn test_accept_task(
|
||||||
|
task in any::<Task>(),
|
||||||
|
) {
|
||||||
|
let batch = task_to_batch(task);
|
||||||
|
|
||||||
|
let index_store = MockIndexStore::new();
|
||||||
|
let meta_store = MockIndexMetaStore::new();
|
||||||
|
let mocker = Mocker::default();
|
||||||
|
let update_file_store = UpdateFileStore::mock(mocker);
|
||||||
|
let index_resolver = IndexResolver::new(meta_store, index_store, update_file_store);
|
||||||
|
|
||||||
|
match batch.content {
|
||||||
|
BatchContent::DocumentAddtitionBatch(_)
|
||||||
|
| BatchContent::IndexUpdate(_) => assert!(index_resolver.accept(&batch)),
|
||||||
|
BatchContent::Dump(_)
|
||||||
|
| BatchContent::Snapshot(_)
|
||||||
|
| BatchContent::Empty => assert!(!index_resolver.accept(&batch)),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[actix_rt::test]
|
||||||
|
async fn finisher_called_on_document_update() {
|
||||||
|
let index_store = MockIndexStore::new();
|
||||||
|
let meta_store = MockIndexMetaStore::new();
|
||||||
|
let mocker = Mocker::default();
|
||||||
|
let content_uuid = Uuid::new_v4();
|
||||||
|
mocker
|
||||||
|
.when::<Uuid, FileStoreResult<()>>("delete")
|
||||||
|
.once()
|
||||||
|
.then(move |uuid| {
|
||||||
|
assert_eq!(uuid, content_uuid);
|
||||||
|
Ok(())
|
||||||
|
});
|
||||||
|
let update_file_store = UpdateFileStore::mock(mocker);
|
||||||
|
let index_resolver = IndexResolver::new(meta_store, index_store, update_file_store);
|
||||||
|
|
||||||
|
let task = Task {
|
||||||
|
id: 1,
|
||||||
|
index_uid: None,
|
||||||
|
content: TaskContent::DocumentAddition {
|
||||||
|
content_uuid,
|
||||||
|
merge_strategy: IndexDocumentsMethod::ReplaceDocuments,
|
||||||
|
primary_key: None,
|
||||||
|
documents_count: 100,
|
||||||
|
allow_index_creation: true,
|
||||||
|
},
|
||||||
|
events: Vec::new(),
|
||||||
|
};
|
||||||
|
|
||||||
|
let batch = task_to_batch(task);
|
||||||
|
|
||||||
|
index_resolver.finish(&batch).await;
|
||||||
|
}
|
||||||
|
|
||||||
|
#[actix_rt::test]
|
||||||
|
#[should_panic]
|
||||||
|
async fn panic_when_passed_unsupported_batch() {
|
||||||
|
let index_store = MockIndexStore::new();
|
||||||
|
let meta_store = MockIndexMetaStore::new();
|
||||||
|
let mocker = Mocker::default();
|
||||||
|
let update_file_store = UpdateFileStore::mock(mocker);
|
||||||
|
let index_resolver = IndexResolver::new(meta_store, index_store, update_file_store);
|
||||||
|
|
||||||
|
let task = Task {
|
||||||
|
id: 1,
|
||||||
|
index_uid: None,
|
||||||
|
content: TaskContent::Dump {
|
||||||
|
uid: String::from("hello"),
|
||||||
|
},
|
||||||
|
events: Vec::new(),
|
||||||
|
};
|
||||||
|
|
||||||
|
let batch = task_to_batch(task);
|
||||||
|
|
||||||
|
index_resolver.process_batch(batch).await;
|
||||||
|
}
|
||||||
|
|
||||||
|
// TODO: test perform_batch. We need a Mocker for IndexResolver.
|
||||||
|
}
|
||||||
|
@ -2,3 +2,33 @@ pub mod dump_handler;
|
|||||||
pub mod empty_handler;
|
pub mod empty_handler;
|
||||||
mod index_resolver_handler;
|
mod index_resolver_handler;
|
||||||
pub mod snapshot_handler;
|
pub mod snapshot_handler;
|
||||||
|
|
||||||
|
#[cfg(test)]
|
||||||
|
mod test {
|
||||||
|
use time::OffsetDateTime;
|
||||||
|
|
||||||
|
use crate::tasks::{
|
||||||
|
batch::{Batch, BatchContent},
|
||||||
|
task::{Task, TaskContent},
|
||||||
|
};
|
||||||
|
|
||||||
|
pub fn task_to_batch(task: Task) -> Batch {
|
||||||
|
let content = match task.content {
|
||||||
|
TaskContent::DocumentAddition { .. } => {
|
||||||
|
BatchContent::DocumentAddtitionBatch(vec![task])
|
||||||
|
}
|
||||||
|
TaskContent::DocumentDeletion(_)
|
||||||
|
| TaskContent::SettingsUpdate { .. }
|
||||||
|
| TaskContent::IndexDeletion
|
||||||
|
| TaskContent::IndexCreation { .. }
|
||||||
|
| TaskContent::IndexUpdate { .. } => BatchContent::IndexUpdate(task),
|
||||||
|
TaskContent::Dump { .. } => BatchContent::Dump(task),
|
||||||
|
};
|
||||||
|
|
||||||
|
Batch {
|
||||||
|
id: Some(1),
|
||||||
|
created_at: OffsetDateTime::now_utc(),
|
||||||
|
content,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@ -26,7 +26,7 @@ pub struct UpdateFile {
|
|||||||
#[error("Error while persisting update to disk: {0}")]
|
#[error("Error while persisting update to disk: {0}")]
|
||||||
pub struct UpdateFileStoreError(Box<dyn std::error::Error + Sync + Send + 'static>);
|
pub struct UpdateFileStoreError(Box<dyn std::error::Error + Sync + Send + 'static>);
|
||||||
|
|
||||||
type Result<T> = std::result::Result<T, UpdateFileStoreError>;
|
pub type Result<T> = std::result::Result<T, UpdateFileStoreError>;
|
||||||
|
|
||||||
macro_rules! into_update_store_error {
|
macro_rules! into_update_store_error {
|
||||||
($($other:path),*) => {
|
($($other:path),*) => {
|
||||||
@ -249,7 +249,7 @@ mod test {
|
|||||||
pub async fn delete(&self, uuid: Uuid) -> Result<()> {
|
pub async fn delete(&self, uuid: Uuid) -> Result<()> {
|
||||||
match self {
|
match self {
|
||||||
MockUpdateFileStore::Real(s) => s.delete(uuid).await,
|
MockUpdateFileStore::Real(s) => s.delete(uuid).await,
|
||||||
MockUpdateFileStore::Mock(_) => todo!(),
|
MockUpdateFileStore::Mock(mocker) => unsafe { mocker.get("delete").call(uuid) },
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user