Wrap triggering of a watch inside an assertBusy(...) invocation

This test replaces the watch index after watcher got started.
This triggers watches being reloaded and while this happens the
trigger engine is paused, which disallows watches from being
triggered. At this time there are no watches in the .watches
index and I think this is just unlucky timing.

Reloading of watches happens in the background and
the watch state can be started when that happens.
For normal schedule trigger engines this is not an issue,
because watches that are meant to be triggered are triggered
when the engine triggers the next time. However for the
mock scheduled trigger engine this is different,
because watches are triggered programatically and
there is no retry in this test.

I think just adding `timeWarp().trigger("mywatch");` inside
a `assertBusy(...)`` is the right fix here.  If it fails
because the mock schedule trigger engine is paused then
the test will try again. In the mean time the the watches
can be reloaded, which then resumes the mock scheduled trigger engine.

Closes #50658
This commit is contained in:
Martijn van Groningen 2020-01-09 09:01:55 +01:00
parent d2189b9d80
commit f75d99149b
No known key found for this signature in database
GPG Key ID: AB236F4FCF2AF12A
1 changed files with 1 additions and 1 deletions

View File

@ -43,7 +43,7 @@ public class WatcherConcreteIndexTests extends AbstractWatcherIntegrationTestCas
assertTrue(putWatchResponse.isCreated());
refresh();
timeWarp().trigger("mywatch");
assertBusy(() -> timeWarp().trigger("mywatch"));
assertBusy(() -> {
SearchResponse searchResult = client().prepareSearch(watchResultsIndex).setTrackTotalHits(true).get();