From 82309b79a93acc87fabb247328be4db1331c09d2 Mon Sep 17 00:00:00 2001 From: buildmaster Date: Fri, 1 Dec 2023 05:16:12 +0000 Subject: [PATCH] Bumping versions --- .../ReactiveResilience4JCircuitBreaker.java | 26 +++-- ...tiveResilience4JCircuitBreakerFactory.java | 4 +- .../Resilience4JCircuitBreaker.java | 41 ++++---- .../Resilience4JConfigurationProperties.java | 2 +- .../Resilience4jBulkheadProvider.java | 3 +- ...eactiveResilience4JCircuitBreakerTest.java | 98 +++++++++---------- .../Resilience4JCircuitBreakerTest.java | 29 +++--- 7 files changed, 99 insertions(+), 104 deletions(-) diff --git a/spring-cloud-circuitbreaker-resilience4j/src/main/java/org/springframework/cloud/circuitbreaker/resilience4j/ReactiveResilience4JCircuitBreaker.java b/spring-cloud-circuitbreaker-resilience4j/src/main/java/org/springframework/cloud/circuitbreaker/resilience4j/ReactiveResilience4JCircuitBreaker.java index af340e4c..11bd5b56 100644 --- a/spring-cloud-circuitbreaker-resilience4j/src/main/java/org/springframework/cloud/circuitbreaker/resilience4j/ReactiveResilience4JCircuitBreaker.java +++ b/spring-cloud-circuitbreaker-resilience4j/src/main/java/org/springframework/cloud/circuitbreaker/resilience4j/ReactiveResilience4JCircuitBreaker.java @@ -64,17 +64,16 @@ public class ReactiveResilience4JCircuitBreaker implements ReactiveCircuitBreake @Deprecated public ReactiveResilience4JCircuitBreaker(String id, String groupName, - Resilience4JConfigBuilder.Resilience4JCircuitBreakerConfiguration config, - CircuitBreakerRegistry circuitBreakerRegistry, TimeLimiterRegistry timeLimiterRegistry, - Optional> circuitBreakerCustomizer) { + Resilience4JConfigBuilder.Resilience4JCircuitBreakerConfiguration config, + CircuitBreakerRegistry circuitBreakerRegistry, TimeLimiterRegistry timeLimiterRegistry, + Optional> circuitBreakerCustomizer) { this(id, groupName, config, circuitBreakerRegistry, timeLimiterRegistry, circuitBreakerCustomizer, false); } public ReactiveResilience4JCircuitBreaker(String id, String groupName, Resilience4JConfigBuilder.Resilience4JCircuitBreakerConfiguration config, CircuitBreakerRegistry circuitBreakerRegistry, TimeLimiterRegistry timeLimiterRegistry, - Optional> circuitBreakerCustomizer, - boolean disableTimeLimiter) { + Optional> circuitBreakerCustomizer, boolean disableTimeLimiter) { this.id = id; this.groupName = groupName; this.circuitBreakerConfig = config.getCircuitBreakerConfig(); @@ -91,14 +90,12 @@ public Mono run(Mono toRun, Function> fallback) { Mono toReturn = toRun.transform(CircuitBreakerOperator.of(tuple.getT1())); if (tuple.getT2().isPresent()) { final Duration timeoutDuration = tuple.getT2().get().getTimeLimiterConfig().getTimeoutDuration(); - toReturn = toReturn - .timeout(timeoutDuration) - // Since we are using the Mono timeout we need to tell the circuit breaker + toReturn = toReturn.timeout(timeoutDuration) + // Since we are using the Mono timeout we need to tell the circuit + // breaker // about the error .doOnError(TimeoutException.class, - t -> tuple.getT1() - .onError(timeoutDuration.toMillis(), - TimeUnit.MILLISECONDS, t)); + t -> tuple.getT1().onError(timeoutDuration.toMillis(), TimeUnit.MILLISECONDS, t)); } if (fallback != null) { toReturn = toReturn.onErrorResume(fallback); @@ -113,12 +110,11 @@ public Flux run(Flux toRun, Function> fallback) { if (tuple.getT2().isPresent()) { final Duration timeoutDuration = tuple.getT2().get().getTimeLimiterConfig().getTimeoutDuration(); toReturn = toReturn.timeout(timeoutDuration) - // Since we are using the Flux timeout we need to tell the circuit breaker + // Since we are using the Flux timeout we need to tell the circuit + // breaker // about the error .doOnError(TimeoutException.class, - t -> tuple.getT1() - .onError(timeoutDuration.toMillis(), - TimeUnit.MILLISECONDS, t)); + t -> tuple.getT1().onError(timeoutDuration.toMillis(), TimeUnit.MILLISECONDS, t)); } if (fallback != null) { toReturn = toReturn.onErrorResume(fallback); diff --git a/spring-cloud-circuitbreaker-resilience4j/src/main/java/org/springframework/cloud/circuitbreaker/resilience4j/ReactiveResilience4JCircuitBreakerFactory.java b/spring-cloud-circuitbreaker-resilience4j/src/main/java/org/springframework/cloud/circuitbreaker/resilience4j/ReactiveResilience4JCircuitBreakerFactory.java index 5c9eeef5..db709939 100644 --- a/spring-cloud-circuitbreaker-resilience4j/src/main/java/org/springframework/cloud/circuitbreaker/resilience4j/ReactiveResilience4JCircuitBreakerFactory.java +++ b/spring-cloud-circuitbreaker-resilience4j/src/main/java/org/springframework/cloud/circuitbreaker/resilience4j/ReactiveResilience4JCircuitBreakerFactory.java @@ -52,7 +52,7 @@ public class ReactiveResilience4JCircuitBreakerFactory extends @Deprecated public ReactiveResilience4JCircuitBreakerFactory(CircuitBreakerRegistry circuitBreakerRegistry, - TimeLimiterRegistry timeLimiterRegistry) { + TimeLimiterRegistry timeLimiterRegistry) { this(circuitBreakerRegistry, timeLimiterRegistry, null); } @@ -101,7 +101,7 @@ public ReactiveCircuitBreaker create(String id, String groupName) { Resilience4JConfigBuilder.Resilience4JCircuitBreakerConfiguration config = new Resilience4JConfigBuilder(id) .circuitBreakerConfig(circuitBreakerConfig).timeLimiterConfig(timeLimiterConfig).build(); return new ReactiveResilience4JCircuitBreaker(id, groupName, config, circuitBreakerRegistry, - timeLimiterRegistry, Optional.ofNullable(circuitBreakerCustomizers.get(id)), isDisableTimeLimiter()); + timeLimiterRegistry, Optional.ofNullable(circuitBreakerCustomizers.get(id)), isDisableTimeLimiter()); } private boolean isDisableTimeLimiter() { diff --git a/spring-cloud-circuitbreaker-resilience4j/src/main/java/org/springframework/cloud/circuitbreaker/resilience4j/Resilience4JCircuitBreaker.java b/spring-cloud-circuitbreaker-resilience4j/src/main/java/org/springframework/cloud/circuitbreaker/resilience4j/Resilience4JCircuitBreaker.java index fe9e3d16..882a3145 100644 --- a/spring-cloud-circuitbreaker-resilience4j/src/main/java/org/springframework/cloud/circuitbreaker/resilience4j/Resilience4JCircuitBreaker.java +++ b/spring-cloud-circuitbreaker-resilience4j/src/main/java/org/springframework/cloud/circuitbreaker/resilience4j/Resilience4JCircuitBreaker.java @@ -45,6 +45,7 @@ public class Resilience4JCircuitBreaker implements CircuitBreaker { private final String id; private final String groupName; + private final Map tags; private Resilience4jBulkheadProvider bulkheadProvider; @@ -65,13 +66,13 @@ public class Resilience4JCircuitBreaker implements CircuitBreaker { @Deprecated public Resilience4JCircuitBreaker(String id, String groupName, - io.github.resilience4j.circuitbreaker.CircuitBreakerConfig circuitBreakerConfig, - TimeLimiterConfig timeLimiterConfig, CircuitBreakerRegistry circuitBreakerRegistry, - TimeLimiterRegistry timeLimiterRegistry, ExecutorService executorService, - Optional> circuitBreakerCustomizer, - Resilience4jBulkheadProvider bulkheadProvider) { + io.github.resilience4j.circuitbreaker.CircuitBreakerConfig circuitBreakerConfig, + TimeLimiterConfig timeLimiterConfig, CircuitBreakerRegistry circuitBreakerRegistry, + TimeLimiterRegistry timeLimiterRegistry, ExecutorService executorService, + Optional> circuitBreakerCustomizer, + Resilience4jBulkheadProvider bulkheadProvider) { this(id, groupName, circuitBreakerConfig, timeLimiterConfig, circuitBreakerRegistry, timeLimiterRegistry, - executorService, circuitBreakerCustomizer, bulkheadProvider, false); + executorService, circuitBreakerCustomizer, bulkheadProvider, false); } public Resilience4JCircuitBreaker(String id, String groupName, @@ -79,8 +80,7 @@ public Resilience4JCircuitBreaker(String id, String groupName, TimeLimiterConfig timeLimiterConfig, CircuitBreakerRegistry circuitBreakerRegistry, TimeLimiterRegistry timeLimiterRegistry, ExecutorService executorService, Optional> circuitBreakerCustomizer, - Resilience4jBulkheadProvider bulkheadProvider, - boolean disableTimeLimiter) { + Resilience4jBulkheadProvider bulkheadProvider, boolean disableTimeLimiter) { this.id = id; this.groupName = groupName; this.circuitBreakerConfig = circuitBreakerConfig; @@ -109,24 +109,25 @@ public T run(Supplier toRun, Function fallback) { final Map tags = Map.of(CIRCUIT_BREAKER_GROUP_TAG, this.groupName); Optional timeLimiter = loadTimeLimiter(); io.github.resilience4j.circuitbreaker.CircuitBreaker defaultCircuitBreaker = registry.circuitBreaker(this.id, - this.circuitBreakerConfig, tags); + this.circuitBreakerConfig, tags); circuitBreakerCustomizer.ifPresent(customizer -> customizer.customize(defaultCircuitBreaker)); if (bulkheadProvider != null) { if (executorService != null) { Supplier> futureSupplier = () -> executorService.submit(toRun::get); /* conditionally wrap in time-limiter */ - Callable timeLimitedCall = timeLimiter.map(tl -> TimeLimiter.decorateFutureSupplier(tl, futureSupplier)) - .orElse(() -> futureSupplier.get().get()); + Callable timeLimitedCall = timeLimiter + .map(tl -> TimeLimiter.decorateFutureSupplier(tl, futureSupplier)) + .orElse(() -> futureSupplier.get().get()); Callable bulkheadCall = bulkheadProvider.decorateCallable(this.groupName, tags, timeLimitedCall); Callable circuitBreakerCall = io.github.resilience4j.circuitbreaker.CircuitBreaker - .decorateCallable(defaultCircuitBreaker, bulkheadCall); + .decorateCallable(defaultCircuitBreaker, bulkheadCall); return getAndApplyFallback(circuitBreakerCall, fallback); } else { Callable bulkheadCall = bulkheadProvider.decorateCallable(this.groupName, tags, toRun::get); Callable circuitBreakerCall = io.github.resilience4j.circuitbreaker.CircuitBreaker - .decorateCallable(defaultCircuitBreaker, bulkheadCall); + .decorateCallable(defaultCircuitBreaker, bulkheadCall); return getAndApplyFallback(circuitBreakerCall, fallback); } } @@ -134,15 +135,16 @@ public T run(Supplier toRun, Function fallback) { if (executorService != null) { Supplier> futureSupplier = () -> executorService.submit(toRun::get); /* conditionally wrap in time-limiter */ - Callable restrictedCall = timeLimiter.map(tl -> TimeLimiter.decorateFutureSupplier(tl, futureSupplier)) - .orElse(() -> futureSupplier.get().get()); + Callable restrictedCall = timeLimiter + .map(tl -> TimeLimiter.decorateFutureSupplier(tl, futureSupplier)) + .orElse(() -> futureSupplier.get().get()); Callable callable = io.github.resilience4j.circuitbreaker.CircuitBreaker - .decorateCallable(defaultCircuitBreaker, restrictedCall); + .decorateCallable(defaultCircuitBreaker, restrictedCall); return getAndApplyFallback(callable, fallback); } else { Supplier decorator = io.github.resilience4j.circuitbreaker.CircuitBreaker - .decorateSupplier(defaultCircuitBreaker, toRun); + .decorateSupplier(defaultCircuitBreaker, toRun); return getAndApplyFallback(decorator, fallback); } } @@ -171,7 +173,8 @@ private Optional loadTimeLimiter() { return Optional.empty(); } return Optional.of(this.timeLimiterRegistry.find(this.id) - .orElseGet(() -> this.timeLimiterRegistry.find(this.groupName) - .orElseGet(() -> this.timeLimiterRegistry.timeLimiter(this.id, this.timeLimiterConfig, this.tags)))); + .orElseGet(() -> this.timeLimiterRegistry.find(this.groupName).orElseGet( + () -> this.timeLimiterRegistry.timeLimiter(this.id, this.timeLimiterConfig, this.tags)))); } + } diff --git a/spring-cloud-circuitbreaker-resilience4j/src/main/java/org/springframework/cloud/circuitbreaker/resilience4j/Resilience4JConfigurationProperties.java b/spring-cloud-circuitbreaker-resilience4j/src/main/java/org/springframework/cloud/circuitbreaker/resilience4j/Resilience4JConfigurationProperties.java index d04701d7..8a00e218 100644 --- a/spring-cloud-circuitbreaker-resilience4j/src/main/java/org/springframework/cloud/circuitbreaker/resilience4j/Resilience4JConfigurationProperties.java +++ b/spring-cloud-circuitbreaker-resilience4j/src/main/java/org/springframework/cloud/circuitbreaker/resilience4j/Resilience4JConfigurationProperties.java @@ -66,7 +66,6 @@ public void setDisableThreadPool(boolean disableThreadPool) { this.disableThreadPool = disableThreadPool; } - boolean isDisableTimeLimiter() { return disableTimeLimiter; } @@ -74,4 +73,5 @@ boolean isDisableTimeLimiter() { void setDisableTimeLimiter(boolean disableTimeLimiter) { this.disableTimeLimiter = disableTimeLimiter; } + } diff --git a/spring-cloud-circuitbreaker-resilience4j/src/main/java/org/springframework/cloud/circuitbreaker/resilience4j/Resilience4jBulkheadProvider.java b/spring-cloud-circuitbreaker-resilience4j/src/main/java/org/springframework/cloud/circuitbreaker/resilience4j/Resilience4jBulkheadProvider.java index ea426469..4cb84488 100644 --- a/spring-cloud-circuitbreaker-resilience4j/src/main/java/org/springframework/cloud/circuitbreaker/resilience4j/Resilience4jBulkheadProvider.java +++ b/spring-cloud-circuitbreaker-resilience4j/src/main/java/org/springframework/cloud/circuitbreaker/resilience4j/Resilience4jBulkheadProvider.java @@ -154,7 +154,8 @@ private boolean useSemaphoreBulkhead(String id) { || (bulkheadRegistry.find(id).isPresent() && threadPoolBulkheadRegistry.find(id).isEmpty()); } - private static Callable decorateTimeLimiter(final Supplier> supplier, TimeLimiter timeLimiter) { + private static Callable decorateTimeLimiter(final Supplier> supplier, + TimeLimiter timeLimiter) { final Supplier> futureSupplier = () -> supplier.get().toCompletableFuture(); if (timeLimiter == null) { /* execute without time-limiter */ diff --git a/spring-cloud-circuitbreaker-resilience4j/src/test/java/org/springframework/cloud/circuitbreaker/resilience4j/ReactiveResilience4JCircuitBreakerTest.java b/spring-cloud-circuitbreaker-resilience4j/src/test/java/org/springframework/cloud/circuitbreaker/resilience4j/ReactiveResilience4JCircuitBreakerTest.java index 0a10dee9..243fc8af 100644 --- a/spring-cloud-circuitbreaker-resilience4j/src/test/java/org/springframework/cloud/circuitbreaker/resilience4j/ReactiveResilience4JCircuitBreakerTest.java +++ b/spring-cloud-circuitbreaker-resilience4j/src/test/java/org/springframework/cloud/circuitbreaker/resilience4j/ReactiveResilience4JCircuitBreakerTest.java @@ -71,65 +71,60 @@ public void runFluxWithFallback() { } /** - * Run circuit breaker with default time limiter and expects everything to run without errors. + * Run circuit breaker with default time limiter and expects everything to run without + * errors. */ @Test public void runWithDefaultTimeLimiter() { final TimeLimiterRegistry timeLimiterRegistry = TimeLimiterRegistry.ofDefaults(); ReactiveCircuitBreaker cb = new ReactiveResilience4JCircuitBreakerFactory(CircuitBreakerRegistry.ofDefaults(), - timeLimiterRegistry, new Resilience4JConfigurationProperties()).create("foo"); + timeLimiterRegistry, new Resilience4JConfigurationProperties()).create("foo"); assertThat(Mono.fromCallable(() -> { - try { - /* sleep less than time limit allows us to */ - TimeUnit.MILLISECONDS.sleep(Math.min(timeLimiterRegistry.getDefaultConfig().getTimeoutDuration() - .toMillis() / 2L, 0L)); - } - catch (InterruptedException e) { - Thread.currentThread().interrupt(); - throw new RuntimeException("thread got interrupted", e); - } - return "foobar"; - }) - .subscribeOn(Schedulers.single()) - .transform(cb::run) - .block() - ).isEqualTo("foobar"); + try { + /* sleep less than time limit allows us to */ + TimeUnit.MILLISECONDS.sleep( + Math.min(timeLimiterRegistry.getDefaultConfig().getTimeoutDuration().toMillis() / 2L, 0L)); + } + catch (InterruptedException e) { + Thread.currentThread().interrupt(); + throw new RuntimeException("thread got interrupted", e); + } + return "foobar"; + }).subscribeOn(Schedulers.single()).transform(cb::run).block()).isEqualTo("foobar"); } /** - * Run circuit breaker with default time limiter and expects the time limit to get exceeded. + * Run circuit breaker with default time limiter and expects the time limit to get + * exceeded. */ @Test(expected = NoFallbackAvailableException.class) public void runWithDefaultTimeLimiterTooSlow() { final TimeLimiterRegistry timeLimiterRegistry = TimeLimiterRegistry.ofDefaults(); ReactiveCircuitBreaker cb = new ReactiveResilience4JCircuitBreakerFactory(CircuitBreakerRegistry.ofDefaults(), - timeLimiterRegistry, new Resilience4JConfigurationProperties()).create("foo"); + timeLimiterRegistry, new Resilience4JConfigurationProperties()).create("foo"); Mono.fromCallable(() -> { - try { - /* sleep longer than time limit allows us to */ - TimeUnit.MILLISECONDS.sleep(Math.max(timeLimiterRegistry.getDefaultConfig().getTimeoutDuration().toMillis(), 100L) * 2); - } - catch (InterruptedException e) { - Thread.currentThread().interrupt(); - throw new RuntimeException("thread got interrupted", e); - } - return "foobar"; - }) - .subscribeOn(Schedulers.single()) - .transform(cb::run) - .doOnSuccess(s -> { - throw new AssertionError("timeout did not occur"); - }) - .block(); + try { + /* sleep longer than time limit allows us to */ + TimeUnit.MILLISECONDS.sleep( + Math.max(timeLimiterRegistry.getDefaultConfig().getTimeoutDuration().toMillis(), 100L) * 2); + } + catch (InterruptedException e) { + Thread.currentThread().interrupt(); + throw new RuntimeException("thread got interrupted", e); + } + return "foobar"; + }).subscribeOn(Schedulers.single()).transform(cb::run).doOnSuccess(s -> { + throw new AssertionError("timeout did not occur"); + }).block(); Assert.fail("execution did not cause exception"); } /** - * Run circuit breaker with default time limiter and exceed time limit. Due to the disabled time limiter execution, - * everything should finish without errors. + * Run circuit breaker with default time limiter and exceed time limit. Due to the + * disabled time limiter execution, everything should finish without errors. */ @Test public void runWithDisabledTimeLimiter() { @@ -137,23 +132,20 @@ public void runWithDisabledTimeLimiter() { final Resilience4JConfigurationProperties resilience4JConfigurationProperties = new Resilience4JConfigurationProperties(); resilience4JConfigurationProperties.setDisableTimeLimiter(true); ReactiveCircuitBreaker cb = new ReactiveResilience4JCircuitBreakerFactory(CircuitBreakerRegistry.ofDefaults(), - timeLimiterRegistry, resilience4JConfigurationProperties).create("foo"); + timeLimiterRegistry, resilience4JConfigurationProperties).create("foo"); assertThat(Mono.fromCallable(() -> { - try { - /* sleep longer than timit limit allows us to */ - TimeUnit.MILLISECONDS.sleep(Math.max(timeLimiterRegistry.getDefaultConfig().getTimeoutDuration() - .toMillis(), 100L) * 2); - } - catch (InterruptedException e) { - Thread.currentThread().interrupt(); - throw new RuntimeException("thread got interrupted", e); - } - return "foobar"; - }) - .subscribeOn(Schedulers.single()) - .transform(cb::run) - .block() - ).isEqualTo("foobar"); + try { + /* sleep longer than timit limit allows us to */ + TimeUnit.MILLISECONDS.sleep( + Math.max(timeLimiterRegistry.getDefaultConfig().getTimeoutDuration().toMillis(), 100L) * 2); + } + catch (InterruptedException e) { + Thread.currentThread().interrupt(); + throw new RuntimeException("thread got interrupted", e); + } + return "foobar"; + }).subscribeOn(Schedulers.single()).transform(cb::run).block()).isEqualTo("foobar"); } + } diff --git a/spring-cloud-circuitbreaker-resilience4j/src/test/java/org/springframework/cloud/circuitbreaker/resilience4j/Resilience4JCircuitBreakerTest.java b/spring-cloud-circuitbreaker-resilience4j/src/test/java/org/springframework/cloud/circuitbreaker/resilience4j/Resilience4JCircuitBreakerTest.java index 7d6ed1f0..bf019577 100644 --- a/spring-cloud-circuitbreaker-resilience4j/src/test/java/org/springframework/cloud/circuitbreaker/resilience4j/Resilience4JCircuitBreakerTest.java +++ b/spring-cloud-circuitbreaker-resilience4j/src/test/java/org/springframework/cloud/circuitbreaker/resilience4j/Resilience4JCircuitBreakerTest.java @@ -160,18 +160,19 @@ public void runWithFallbackBulkheadProviderAndGroupName() { } /** - * Run circuit breaker with default time limiter and expects everything to run without errors. + * Run circuit breaker with default time limiter and expects everything to run without + * errors. */ @Test public void runWithDefaultTimeLimiter() { final TimeLimiterRegistry timeLimiterRegistry = TimeLimiterRegistry.ofDefaults(); CircuitBreaker cb = new Resilience4JCircuitBreakerFactory(CircuitBreakerRegistry.ofDefaults(), - timeLimiterRegistry, null, properties).create("foo"); + timeLimiterRegistry, null, properties).create("foo"); assertThat(cb.run(() -> { try { /* sleep less than time limit allows us to */ - TimeUnit.MILLISECONDS.sleep(Math.min(timeLimiterRegistry.getDefaultConfig().getTimeoutDuration() - .toMillis() / 2L, 0L)); + TimeUnit.MILLISECONDS.sleep( + Math.min(timeLimiterRegistry.getDefaultConfig().getTimeoutDuration().toMillis() / 2L, 0L)); } catch (InterruptedException e) { Thread.currentThread().interrupt(); @@ -182,18 +183,19 @@ public void runWithDefaultTimeLimiter() { } /** - * Run circuit breaker with default time limiter and expects the time limit to get exceeded. + * Run circuit breaker with default time limiter and expects the time limit to get + * exceeded. */ @Test(expected = NoFallbackAvailableException.class) public void runWithDefaultTimeLimiterTooSlow() { final TimeLimiterRegistry timeLimiterRegistry = TimeLimiterRegistry.ofDefaults(); CircuitBreaker cb = new Resilience4JCircuitBreakerFactory(CircuitBreakerRegistry.ofDefaults(), - timeLimiterRegistry, null, properties).create("foo"); + timeLimiterRegistry, null, properties).create("foo"); cb.run(() -> { try { /* sleep longer than time limit allows us to */ - TimeUnit.MILLISECONDS.sleep(Math.max(timeLimiterRegistry.getDefaultConfig().getTimeoutDuration() - .toMillis(), 100L) * 2); + TimeUnit.MILLISECONDS.sleep( + Math.max(timeLimiterRegistry.getDefaultConfig().getTimeoutDuration().toMillis(), 100L) * 2); } catch (InterruptedException e) { Thread.currentThread().interrupt(); @@ -205,20 +207,20 @@ public void runWithDefaultTimeLimiterTooSlow() { } /** - * Run circuit breaker with default time limiter and exceed time limit. Due to the disabled time limiter execution, - * everything should finish without errors. + * Run circuit breaker with default time limiter and exceed time limit. Due to the + * disabled time limiter execution, everything should finish without errors. */ @Test public void runWithDisabledTimeLimiter() { properties.setDisableTimeLimiter(true); final TimeLimiterRegistry timeLimiterRegistry = TimeLimiterRegistry.ofDefaults(); CircuitBreaker cb = new Resilience4JCircuitBreakerFactory(CircuitBreakerRegistry.ofDefaults(), - timeLimiterRegistry, null, properties).create("foo"); + timeLimiterRegistry, null, properties).create("foo"); assertThat(cb.run(() -> { try { /* sleep longer than limit limit allows us to */ - TimeUnit.MILLISECONDS.sleep(Math.max(timeLimiterRegistry.getDefaultConfig().getTimeoutDuration() - .toMillis(), 100L) * 2); + TimeUnit.MILLISECONDS.sleep( + Math.max(timeLimiterRegistry.getDefaultConfig().getTimeoutDuration().toMillis(), 100L) * 2); } catch (InterruptedException e) { Thread.currentThread().interrupt(); @@ -227,4 +229,5 @@ public void runWithDisabledTimeLimiter() { return "foobar"; })).isEqualTo("foobar"); } + }