X-Git-Url: http://juplo.de/gitweb/?a=blobdiff_plain;f=src%2Ftest%2Fjava%2Fde%2Fjuplo%2Fkafka%2Fchat%2Fbackend%2FTestWriter.java;h=0d2c41e728e8d7dc214149b6c74dd5c97d890842;hb=bce5ce999de007bb43c28f908fceef0646ac513c;hp=5c6f7abd8f915418bb61352e62d9a9d4b48119c3;hpb=7131724ef1486c13fc32bf44fe0df31287600581;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 5c6f7abd..0d2c41e7 100644 --- a/src/test/java/de/juplo/kafka/chat/backend/TestWriter.java +++ b/src/test/java/de/juplo/kafka/chat/backend/TestWriter.java @@ -42,9 +42,9 @@ 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)))) .doOnNext(message -> { @@ -63,7 +63,10 @@ public class TestWriter user, e.getResponseBodyAsString(Charset.defaultCharset())); }) - .parallel() + .limitRate(1) + .takeUntil(message -> !running) + .doOnComplete(() -> log.info("TestWriter {} is done", user)) + .parallel(1) .runOn(Schedulers.parallel()) .then(); } @@ -98,8 +101,8 @@ public class TestWriter private final WebClient webClient; private final ChatRoomInfoTo chatRoom; - private final User user; + final User user; final List sentMessages = new LinkedList<>(); volatile boolean running = true;