Merge pull request #587 from sgummaluri/fix_first_all_updates_call_after_indexing

Fix for 'Update Status after the first update comes up to be empty (#542)'
This commit is contained in:
Clément Renault 2020-04-05 10:32:27 +02:00 committed by GitHub
commit 83d8dc0d2b
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 32 additions and 2 deletions

View File

@ -6,3 +6,4 @@
- Add support of nested null, boolean and seq values (#571 and #568, #574) - Add support of nested null, boolean and seq values (#571 and #568, #574)
- Fixed the core benchmark (#576) - Fixed the core benchmark (#576)
- Publish an ARMv7 and ARMv8 binaries on releases (#540 and #581) - Publish an ARMv7 and ARMv8 binaries on releases (#540 and #581)
- Fixing a bug where the result of the update status after the first update was empty (#542)

View File

@ -334,14 +334,14 @@ impl Index {
for id in 0..=last_id { for id in 0..=last_id {
if let Some(update) = self.update_status(reader, id)? { if let Some(update) = self.update_status(reader, id)? {
updates.push(update); updates.push(update);
last_update_result_id = id; last_update_result_id = id + 1;
} }
} }
} }
// retrieve all enqueued updates // retrieve all enqueued updates
if let Some((last_id, _)) = self.updates.last_update(reader)? { if let Some((last_id, _)) = self.updates.last_update(reader)? {
for id in last_update_result_id + 1..=last_id { for id in last_update_result_id..=last_id {
if let Some(update) = self.update_status(reader, id)? { if let Some(update) = self.update_status(reader, id)? {
updates.push(update); updates.push(update);
} }

View File

@ -1,5 +1,6 @@
use assert_json_diff::assert_json_eq; use assert_json_diff::assert_json_eq;
use serde_json::json; use serde_json::json;
use serde_json::Value;
mod common; mod common;
@ -657,3 +658,31 @@ fn check_add_documents_without_primary_key() {
assert_eq!(status_code, 400); assert_eq!(status_code, 400);
assert_json_eq!(response, expected, ordered: false); assert_json_eq!(response, expected, ordered: false);
} }
#[test]
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);
assert_eq!(status_code, 201);
assert_eq!(response["primaryKey"], json!(null));
let dataset = include_bytes!("assets/movies.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);
// 3. Fetch the status of the indexing done above.
let (response, status_code) = server.get_all_updates_status();
// 4. Verify the fetch is successful and indexing status is 'processed'
assert_eq!(status_code, 200);
assert_eq!(response[0]["status"], "processed");
}