Skip to content

Commit

Permalink
Fixes flaky unit test.
Browse files Browse the repository at this point in the history
This also adds extra detail to service unavailable ingest errors.
The error was likely cause by the lag between the nodes being detected
as ready and servers being added to the ingester pool.

Ideally we should have a concept of readiness associated to routers:
"I am ready to rest ingest requests".

Closes #4213
  • Loading branch information
fulmicoton committed May 24, 2024
1 parent 374a0f4 commit 54871e2
Showing 1 changed file with 34 additions and 11 deletions.
45 changes: 34 additions & 11 deletions quickwit/quickwit-integration-tests/src/tests/index_tests.rs
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@
use std::collections::HashSet;
use std::time::Duration;

use hyper::StatusCode;
use quickwit_config::service::QuickwitService;
use quickwit_config::ConfigFormat;
use quickwit_metastore::SplitState;
Expand Down Expand Up @@ -299,17 +300,39 @@ async fn test_ingest_v2_happy_path() {
.toggle("_ingest-source", true)
.await
.unwrap();
sandbox
.indexer_rest_client
.ingest(
"test_index",
ingest_json!({"body": "doc1"}),
None,
None,
CommitType::WaitFor,
)
.await
.unwrap();

// The server have been detected as ready. Unfortunately, they may not have been added
// to the ingester pool yet.
//
// If we get an unavailable error, we retry up to 10 times.
// See #4213
const MAX_NUM_RETRIES: usize = 10;
for i in 1..=MAX_NUM_RETRIES {
let ingest_res = sandbox
.indexer_rest_client
.ingest(
"test_index",
ingest_json!({"body": "doc1"}),
None,
None,
CommitType::WaitFor,
)
.await;
let Some(ingest_error) = ingest_res.err() else {
// Success
break;
};
assert_eq!(
ingest_error.status_code(),
Some(StatusCode::SERVICE_UNAVAILABLE)
);
assert!(
i < MAX_NUM_RETRIES,
"service not available after {MAX_NUM_RETRIES} tries"
);
tokio::time::sleep(Duration::from_millis(200)).await;
}

sandbox
.wait_for_splits("test_index", Some(vec![SplitState::Published]), 1)
.await
Expand Down

0 comments on commit 54871e2

Please sign in to comment.