1 package de.juplo.kafka.chat.backend;
3 import com.fasterxml.jackson.databind.ObjectMapper;
4 import com.fasterxml.jackson.databind.SerializationFeature;
5 import com.fasterxml.jackson.datatype.jsr310.JavaTimeModule;
6 import de.juplo.kafka.chat.backend.api.ChatRoomInfoTo;
7 import de.juplo.kafka.chat.backend.api.MessageTo;
8 import lombok.extern.slf4j.Slf4j;
9 import org.springframework.core.ParameterizedTypeReference;
10 import org.springframework.http.MediaType;
11 import org.springframework.http.codec.ServerSentEvent;
12 import org.springframework.web.reactive.function.client.WebClient;
13 import reactor.core.publisher.Flux;
14 import reactor.core.publisher.Mono;
20 public class TestListener
22 static final ParameterizedTypeReference<ServerSentEvent<String>> SSE_TYPE = new ParameterizedTypeReference<>() {};
25 public Flux<MessageTo> run()
31 log.info("Requesting messages from chat-room {}", chatRoom);
32 List<MessageTo> list = new LinkedList<>();
33 receivedMessages.put(chatRoom.getId(), list);
34 return receiveMessages(chatRoom)
39 return Mono.just(objectMapper.readValue(sse.data(), MessageTo.class));
49 Flux<ServerSentEvent<String>> receiveMessages(ChatRoomInfoTo chatRoom)
54 "/{chatRoomId}/listen",
56 .accept(MediaType.TEXT_EVENT_STREAM)
58 .bodyToFlux(SSE_TYPE);
62 private final WebClient webClient;
63 private final ChatRoomInfoTo[] chatRooms;
64 private final ObjectMapper objectMapper;
66 final Map<UUID, List<MessageTo>> receivedMessages = new HashMap<>();
69 TestListener(Integer port, ChatRoomInfoTo[] chatRooms)
71 webClient = WebClient.create("http://localhost:" + port);
72 this.chatRooms = chatRooms;
73 objectMapper = new ObjectMapper();
74 objectMapper.registerModule(new JavaTimeModule());
75 objectMapper.disable(SerializationFeature.WRITE_DATES_AS_TIMESTAMPS);