X-Git-Url: https://juplo.de/gitweb/?a=blobdiff_plain;f=src%2Ftest%2Fjava%2Fde%2Fjuplo%2Fkafka%2Fchat%2Fbackend%2FTestWriter.java;h=c21acda10d5866f12bccdc3e00bb3bdfb514e2dd;hb=64ede95835a496e84857c38213dbf8ea451878e0;hp=8f7bc816129c65fb1cf7e38c011b5af7c1bbeee6;hpb=099e03f7805f3c05b94be4e5d074bfb2c47943ce;p=demos%2Fkafka%2Fchat diff --git a/src/test/java/de/juplo/kafka/chat/backend/TestWriter.java b/src/test/java/de/juplo/kafka/chat/backend/TestWriter.java index 8f7bc816..c21acda1 100644 --- a/src/test/java/de/juplo/kafka/chat/backend/TestWriter.java +++ b/src/test/java/de/juplo/kafka/chat/backend/TestWriter.java @@ -42,10 +42,10 @@ public class TestWriter return i++; } }) + .delayElements(Duration.ofMillis(ThreadLocalRandom.current().nextLong(500, 1500))) .map(i -> "Message #" + i) .flatMap(message -> sendMessage(chatRoom, message) - .delayElement(Duration.ofMillis(ThreadLocalRandom.current().nextLong(500, 1500))) - .retryWhen(Retry.fixedDelay(10, Duration.ofSeconds(1)))) + .retryWhen(Retry.backoff(10, Duration.ofSeconds(1)))) .doOnNext(message -> { sentMessages.add(message); @@ -63,6 +63,7 @@ public class TestWriter user, e.getResponseBodyAsString(Charset.defaultCharset())); }) + .limitRate(1) .takeUntil(message -> !running) .doOnComplete(() -> log.info("TestWriter {} is done", user)) .parallel(1) @@ -99,8 +100,8 @@ public class TestWriter private final WebClient webClient; - private final ChatRoomInfoTo chatRoom; + final ChatRoomInfoTo chatRoom; final User user; final List sentMessages = new LinkedList<>();