- Thread.sleep(ThreadLocalRandom.current().nextLong(700, 1000));
- }
- catch (Exception e)
- {
- throw new RuntimeException(e);
- }
- }
+ @Override
+ public Integer next()
+ {
+ return i++;
+ }
+ })
+ .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 -> log.info(
+ "{} sent a message to {}: {}",
+ user,
+ chatRoom,
+ message))
+ .doOnError(throwable ->
+ {
+ WebClientResponseException e = (WebClientResponseException)throwable.getCause();
+ log.error(
+ "{} failed sending a message: {}",
+ user,
+ e.getResponseBodyAsString(Charset.defaultCharset()));
+ })
+ .then()
+ .block();