From a46e2c0b2799dada65ccb47ad0a33e448cd88c9e Mon Sep 17 00:00:00 2001 From: anhefti Date: Wed, 12 May 2021 08:11:41 +0200 Subject: [PATCH] made CircuitBreaker thread safe --- .../java/ch/ethz/seb/sebserver/gbl/async/CircuitBreaker.java | 2 +- .../ethz/seb/sebserver/gbl/async/MemoizingCircuitBreaker.java | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/src/main/java/ch/ethz/seb/sebserver/gbl/async/CircuitBreaker.java b/src/main/java/ch/ethz/seb/sebserver/gbl/async/CircuitBreaker.java index 9d214d52..3f13ea72 100644 --- a/src/main/java/ch/ethz/seb/sebserver/gbl/async/CircuitBreaker.java +++ b/src/main/java/ch/ethz/seb/sebserver/gbl/async/CircuitBreaker.java @@ -121,7 +121,7 @@ public final class CircuitBreaker { return this.lastSuccessTime; } - public Result protectedRun(final Supplier supplier) { + public synchronized Result protectedRun(final Supplier supplier) { final long currentTime = System.currentTimeMillis(); if (log.isDebugEnabled()) { diff --git a/src/main/java/ch/ethz/seb/sebserver/gbl/async/MemoizingCircuitBreaker.java b/src/main/java/ch/ethz/seb/sebserver/gbl/async/MemoizingCircuitBreaker.java index 3c78c65c..5a236a5d 100644 --- a/src/main/java/ch/ethz/seb/sebserver/gbl/async/MemoizingCircuitBreaker.java +++ b/src/main/java/ch/ethz/seb/sebserver/gbl/async/MemoizingCircuitBreaker.java @@ -124,7 +124,7 @@ public final class MemoizingCircuitBreaker implements Supplier> { } @Override - public Result get() { + public synchronized Result get() { final Result result = this.delegate.protectedRun(this.supplier); if (result.hasError()) { if (this.memoizing && this.cached != null) {