|
31 | 31 | import org.elasticsearch.common.UUIDs; |
32 | 32 | import org.elasticsearch.common.bytes.BytesArray; |
33 | 33 | import org.elasticsearch.common.bytes.BytesReference; |
| 34 | +import org.elasticsearch.common.lease.Releasable; |
34 | 35 | import org.elasticsearch.common.lucene.uid.Versions; |
35 | 36 | import org.elasticsearch.common.settings.Settings; |
36 | 37 | import org.elasticsearch.common.unit.TimeValue; |
@@ -342,6 +343,40 @@ public void testLotsOfThreads() throws Exception { |
342 | 343 | refresher.cancel(); |
343 | 344 | } |
344 | 345 |
|
| 346 | + public void testDisallowAddListeners() throws Exception { |
| 347 | + assertEquals(0, listeners.pendingCount()); |
| 348 | + DummyRefreshListener listener = new DummyRefreshListener(); |
| 349 | + assertFalse(listeners.addOrNotify(index("1").getTranslogLocation(), listener)); |
| 350 | + engine.refresh("I said so"); |
| 351 | + assertFalse(listener.forcedRefresh.get()); |
| 352 | + listener.assertNoError(); |
| 353 | + |
| 354 | + try (Releasable releaseable1 = listeners.forceRefreshes()) { |
| 355 | + listener = new DummyRefreshListener(); |
| 356 | + assertTrue(listeners.addOrNotify(index("1").getTranslogLocation(), listener)); |
| 357 | + assertTrue(listener.forcedRefresh.get()); |
| 358 | + listener.assertNoError(); |
| 359 | + assertEquals(0, listeners.pendingCount()); |
| 360 | + |
| 361 | + try (Releasable releaseable2 = listeners.forceRefreshes()) { |
| 362 | + listener = new DummyRefreshListener(); |
| 363 | + assertTrue(listeners.addOrNotify(index("1").getTranslogLocation(), listener)); |
| 364 | + assertTrue(listener.forcedRefresh.get()); |
| 365 | + listener.assertNoError(); |
| 366 | + assertEquals(0, listeners.pendingCount()); |
| 367 | + } |
| 368 | + |
| 369 | + listener = new DummyRefreshListener(); |
| 370 | + assertTrue(listeners.addOrNotify(index("1").getTranslogLocation(), listener)); |
| 371 | + assertTrue(listener.forcedRefresh.get()); |
| 372 | + listener.assertNoError(); |
| 373 | + assertEquals(0, listeners.pendingCount()); |
| 374 | + } |
| 375 | + |
| 376 | + assertFalse(listeners.addOrNotify(index("1").getTranslogLocation(), new DummyRefreshListener())); |
| 377 | + assertEquals(1, listeners.pendingCount()); |
| 378 | + } |
| 379 | + |
345 | 380 | private Engine.IndexResult index(String id) throws IOException { |
346 | 381 | return index(id, "test"); |
347 | 382 | } |
|
0 commit comments