From: Kai Moritz Date: Sat, 11 Jan 2020 15:30:26 +0000 (+0100) Subject: Implemented a seemingly pure and clean unit-test X-Git-Tag: wip-it~28 X-Git-Url: http://juplo.de/gitweb/?a=commitdiff_plain;h=2fdb94987eb514c06661ac7a7b07efbf6e9e83d6;p=demos%2Ftesting Implemented a seemingly pure and clean unit-test --- diff --git a/src/test/java/de/juplo/demo/RemoteContentServiceTest.java b/src/test/java/de/juplo/demo/RemoteContentServiceTest.java new file mode 100644 index 0000000..60d1c5d --- /dev/null +++ b/src/test/java/de/juplo/demo/RemoteContentServiceTest.java @@ -0,0 +1,57 @@ +package de.juplo.demo; + + +import org.junit.jupiter.api.BeforeEach; +import org.junit.jupiter.api.Test; +import org.junit.jupiter.api.extension.ExtendWith; +import static org.mockito.ArgumentMatchers.eq; +import static org.mockito.Mockito.when; +import org.springframework.boot.test.mock.mockito.MockBean; +import org.springframework.test.context.junit.jupiter.SpringExtension; +import org.springframework.web.reactive.function.client.WebClient; +import org.springframework.web.reactive.function.client.WebClient.RequestHeadersUriSpec; +import org.springframework.web.reactive.function.client.WebClient.ResponseSpec; +import reactor.core.publisher.Mono; +import reactor.test.StepVerifier; + + +/** + * Unit-Test for class {@link RemoteContentService}. + * @author Kai Moritz + */ +@ExtendWith(SpringExtension.class) +public class RemoteContentServiceTest +{ + RemoteContentService service; + + @MockBean + WebClient webClient; + @MockBean + RequestHeadersUriSpec uriSpec; + @MockBean + ResponseSpec responseSpec; + + + @BeforeEach + void setUp() + { + service = new RemoteContentService(webClient); + } + + + @Test + void test() + { + when(webClient.get()).thenReturn(uriSpec); + when(uriSpec.uri(eq("/foo"))).thenReturn(uriSpec); + when(uriSpec.retrieve()).thenReturn(responseSpec); + when(responseSpec.bodyToMono(String.class)).thenReturn(Mono.just("bar")); + + Mono result = service.getRemoteText("/foo"); + + StepVerifier + .create(result) + .expectNext("bar") + .verifyComplete(); + } +}