Reindex: Wait for deletion in test
The test failure tracked by #28053 occurs because we fail to get the failure response from the reindex on the first try and on our second try the delete index API call that was supposed to trigger the failure actually deletes the index during document creation. This causes the test to fail catastrophically. This PR attempts to wait for the failure to finish before the test moves on to the second attempt. The failure doesn't reproduce locally for me so I can't be sure that this helps at all with the failure, but it certainly feels like it should help some. Here is hoping this prevents similar failures in the future.
This commit is contained in:
parent
049f29710e
commit
eded5bc4f3
|
@ -107,6 +107,14 @@ public class ReindexFailureTests extends ReindexTestCase {
|
||||||
response.get();
|
response.get();
|
||||||
logger.info("Didn't trigger a reindex failure on the {} attempt", attempt);
|
logger.info("Didn't trigger a reindex failure on the {} attempt", attempt);
|
||||||
attempt++;
|
attempt++;
|
||||||
|
/*
|
||||||
|
* In the past we've seen the delete of the source index
|
||||||
|
* actually take effect *during* the `indexDocs` call in
|
||||||
|
* the next step. This breaks things pretty disasterously
|
||||||
|
* so we *try* and wait for the delete to be fully
|
||||||
|
* complete here.
|
||||||
|
*/
|
||||||
|
assertBusy(() -> assertFalse(client().admin().indices().prepareExists("source").get().isExists()));
|
||||||
} catch (ExecutionException e) {
|
} catch (ExecutionException e) {
|
||||||
logger.info("Triggered a reindex failure on the {} attempt: {}", attempt, e.getMessage());
|
logger.info("Triggered a reindex failure on the {} attempt: {}", attempt, e.getMessage());
|
||||||
assertThat(e.getMessage(),
|
assertThat(e.getMessage(),
|
||||||
|
|
Loading…
Reference in New Issue