Skip to content

Commit

Permalink
Separate blocking shutdown
Browse files Browse the repository at this point in the history
Separate unlocking CountDownLatch to shutdownBlocking() to avoid
interaction with CountDownLatch for users who do not call blocking
start.

JIRA: LIGHTY-299
Signed-off-by: Ivan Hrasko <[email protected]>
(cherry picked from commit 473bb06)
  • Loading branch information
ihrasko committed Oct 31, 2024
1 parent 4495546 commit 7c84af3
Showing 1 changed file with 17 additions and 1 deletion.
Original file line number Diff line number Diff line change
Expand Up @@ -192,7 +192,6 @@ public synchronized ListenableFuture<Boolean> shutdown() {
@Override
public final boolean shutdown(final long duration, final TimeUnit unit) {
try {
shutdownLatch.countDown();
final var stopSuccess = shutdown().get(duration, unit);
if (stopSuccess) {
LOG.info("LightyModule {} stopped successfully!", getClass().getSimpleName());
Expand All @@ -208,4 +207,21 @@ public final boolean shutdown(final long duration, final TimeUnit unit) {
}
return false;
}

/**
* Invoke blocking shutdown after blocking start.
*
* <p>
* Release CountDownLatch locking this thread and shutdown.
* @param duration duration to wait for shutdown to complete
* @param unit {@link TimeUnit} of {@code duration}
* @return {@code boolean} indicating shutdown sucess
* @deprecated Use {@code shutdown()} or {@code shutdown(duration, unit)} instead in case you want
* blocking shutdown.
*/
@Deprecated(forRemoval = true)
public final boolean shutdownBlocking(final long duration, final TimeUnit unit) {
shutdownLatch.countDown();
return shutdown(duration, unit);
}
}

0 comments on commit 7c84af3

Please sign in to comment.