Wiremock + spring boot

Wiremock + spring boot
WA
  • Rejestracja:ponad 9 lat
  • Ostatnio:ponad 5 lat
  • Postów:56
0

Mam do wykonania "proxy" z użyciem spring boota + web oraz wiremocka.
Działać ma to tak, że pobierany jest request od nadawcy i w zależności od tego, jakiego typu http jest żądanie, ma wysłać do odpowiedniego systemu - wiremock (np. GET - system1), który zwróci mu jakąś odpowiedź.
Wykorzystać należy RestController i RestTemplate.

Nigdy nie miałem do czynienia z WireMockiem, ale rozumiem to tak, że stawiam sobie standardowy kontroler w springu, mapuje żądania przy użyciu @RequestMapping (wcześniej @RestController), następnie w ciele tego kontrolera rozpoznaję metodę i wysyłam jakieś żądanie do np. System 1(symulowanego za pomocą WireMock), który następnie coś mi tam zwraca i to np. zwracam klientowi do przeglądarki. Czy dobrze to rozumiem? Wczytuję się już którąś godzinę, w jaki sposób przy użyciu tego WireMocka to zrobić. Wszędzie poruszane są kwestie testów, ale to chyba nie o to chodzi, skoro ja chcę tylko pobrać żądanie i coś zwrócić?

Kopiuj
public class WireMockEx {
    RestTemplate restTemplate;
    ResponseEntity response;

    @Rule
    public WireMockRule wireMockRule = new WireMockRule(wireMockConfig().port(8080).httpsPort(8443));

    @Before
    public void setup() throws Exception {
        restTemplate = new RestTemplate();
        response = null;
    }
    
    public void exactUrlOnly() {
        stubFor(get(urlEqualTo("/")).willReturn(
                aResponse()
                        .withStatus(200)
                        .withHeader("Content-Type", "text/plain")
                        .withBody("response!")));
    }
}

Ale w takim razie, jak z samego kontrolera wysłać żądanie do tego WireMocka, w jaki sposób przetworzyć je i zwrócić coś do klienta (czyli zwrócić do kontrolera javy i wyświetlić użytkownikowi)?
Bardzo proszę o jakieś wskazówki, może przykład na Githubie, bo przeglądam całego guida Wiremocka i nie mogę tam znaleźć rzeczy, która mi takie coś umożliwi.

edytowany 1x, ostatnio: Warmix
TY
  • Rejestracja:ponad 8 lat
  • Ostatnio:około 2 lata
  • Postów:204
1

Średnio cię rozumiem.
Chodzi o to, żeby użyć RestTemplate i wysłać żądanie na serwer, który zamockowałeś wiremockiem?

EDIT:
Rozumiem, że masz aplikacje SpringBootową. Ktoś używający tej aplikacji wysyła do ciebie RESTA GET /magic-stuff i chce dostać magiczny proszek.
Niestety twoja aplikacja, nie ma magicznego proszku, więc musisz uderzyć do innej aplikacji która go ma też po REŚCIE GET /magic-powder.
Więc masz dwie aplikacje: jedna Spring-Boota działająca na przykład pod 127.0.0.1:8080, a druga działająca pod 127.0.0.1:8081. Druga nie może działać pod 8080, bo ten socket jest już zajęty.
Czyli użytkownik do ciebie uderza pod GET 127.0.0.1:8080/magic-stuff, więc ty uderzasz pod GET 127.0.0.1:8081/magic-powder, dostajesz magiczny proszek i zwracasz go użytkownikowi?

Pewnie ta druga aplikacja jeszcze nie istnieje, ale serwis chcesz napisać już teraz. Więc chcesz sobie zamockować WireMockiem tą drugą aplikację i do niej bić po RESCIE? A potem jak druga już będzie istniała, to tylko zmienisz adres ip i port i wszystko będzie działać?

edytowany 3x, ostatnio: Tyvrel
Zobacz pozostały 1 komentarz
TY
Eee... Serio? Przecież wystarczy obejrzeć dokumentacje RestTemplate: restTemplate.getForEntity("http://localhost:8080/", String.class). Zastubowany serwer wiremockiem już masz
WA
aha, okej, już chyba rozumiem. Jeszcze 2 pytania: 1. port(8080)? Czy winien on być taki sam czy może być inni od tego zdefiniowanego dla aplikacji springowej? 2. Zdaje się, że są jakieś adnotacje springowe, żeby wraz z uruchomieniem aplikacji springowej startowały mi te serwery z wiremocka. Rozumiem, że mogę te adnotacje dodać nad klasę WireMockEx i powinno zadziałać czy zastosować sposób manualny? I jeśli manualny, to gdzie konkretnie?
TY
Czekaj, czekaj. Chcesz w trakcie uruchamiania aplikacji spring bootwej odpalić drugi serwer zastubowany WireMockiem? W WireMockEx widze adnotacje testowe, więc wyszedlem z zalożenia, że to początek testu
WA
No to chyba ostatecznie coś nie rozumiem w całej tej idei. Ale generalnie możliwe jest, by odpalać jednocześnie drugi serwer Wiremocka? Czy lepiej będzie to mieć osobno - więc Wiremocka manualnie odpalić?
TY
Zedytowalem post. Cięzko w komentarzach napisać coś dłuższego...
WA
  • Rejestracja:ponad 9 lat
  • Ostatnio:ponad 5 lat
  • Postów:56
0
Tyvrel napisał(a):

Pewnie ta druga aplikacja jeszcze nie istnieje, ale serwis chcesz napisać już teraz. Więc chcesz sobie zamockować WireMockiem tą drugą aplikację i do niej bić po RESCIE? A potem jak druga już będzie istniała, to tylko zmienisz adres ip i port i wszystko będzie działać?

Tak, dokładnie takie coś chciałbym uzyskać. Nakierujesz na jakiś przykład wykonania czegoś takiego?

TY
  • Rejestracja:ponad 8 lat
  • Ostatnio:około 2 lata
  • Postów:204
2

Oczywiście, że mogę cię nakierować jak to zrobić: nie rób tego.
Załóżmy, że twój MagicStuffService korzysta z RestTemplate, żeby dobierać się do Tej-Drugiej-Aplikacji.

Kopiuj
class MagicStuffService {
	MagicStuff getMagicStuff() {
		return restTemplate.get(restTemplate.getForEntity("http://localhost:8081/magic-powder", MagicStuff.class));
	}
}

Zamiast tego zrób warstwę pośrednią i zamiast RestTemplate używaj TheOtherApplicationClient:

Kopiuj
class MagicStuffService {
	MagicStuff getMagicStuff() {
		return theOtherApplicationClient.getMagicStuff();
	}
}

Oraz zrób dwie implementacje, jednego stuba, który nic nie robi:

Kopiuj
class TheOtherApplicationMockedClient {
	MagicStuff getMagicStuff() {
		return mockedMagicStuff;
	}
}

A jak już aplikacja będzie, to możesz zaimplementować clienta na podstawie istniejącego api:

Kopiuj
class TheOtherApplicationClient {
	MagicStuff getMagicStuff() {
		return restTemplate.get(restTemplate.getForEntity("http://localhost:8081/magic-powder", MagicStuff.class));
	}
}

I użyj springowych czarów (np. profili), żeby sobie podmieniać implementacje.
Tak w sumie, to prawdziwego TheOtherApplicationClient możesz już napisać. Tylko go nie podpinaj pod aplikację, niech póki co będzie nieużywany.
Możesz też napisać do niego testy (testy testujące tylko TheOtherApplicationClient) używając WireMocka. Do tego służy WireMock - testowania. Używanie go do mockowania zewnętrznego serwisu odpalanego z działającej aplikacji to zbrodnia!

WA
Rozumiem sens tego, że Wiremocka używa się do testowania - i rzeczywiście, w dalszej części muszę wykonać testy automatyczne. Problem w tym, że zgodnie z poleceniem, stworzyć musze aplikację w spring boot, która przekazywać będzie requesty do mockowanych serwerów. Wydaje mi się, że to coś na zasadzie: http://wiremock.org/docs/running-standalone/ -> Configuring WireMock using the Java client
WA
Dlatego ja sobie wyobrażam to tak, że tworzę moją aplikację, która przejmuje na danym endpoicie żądanie. Gdzieś tam wcześniej tworzę obiekt Wiremocka, który daje mi możliwość komunikacji z serwerem zmockowanym przez Wiremocka (np. ten standalone, jeśli nie da się na zywca z spring boota odpalić tego serwera wiremocka). Przekazuje do tego serwera to żądanie i Wiremock zwraca mi jakiś tam response.
WA
Całą sprawę już chyba rozumiem. Tylko ciekawi mnie własnie to, że jak mogę zmockować ten serwer przy użyciu Wiremocka, ale nie jako standalone, czyli nie tak, że odzielnie go odpalę i potem moją aplikację, tylko by właśnie gdzieś wykorzystać "wireMockServer.start()". Tylko właśnie pytanie, czy tak powinienem robić i jeśli tak, to w którym miejscu powinienem inicjalizować włączenie serverów mockowych w restowej aplikacji?
WA
Ok, wystartowałem serwer mockowy w mainie po prostu przed odpalaniem mojej spring botowej aplikacji. Trochę to zajęło, ale już wiem mniej więcej o co chodzi i jak to całe mockowanie działa. Dzięki. Jeszcze mogę mieć pewnie jakieś pytania w czasie testów, ale to w praniu wyjdzie. Jeszcze raz dzięki.
TY
Możesz też stworzyć beana, który w konstruktorze albo postConstruct będzie tworzył ten. Ciężko mi powiedzieć, który sposób jest architektonicznie lepszy, ale przynajmniej w ten sposób będziesz miał do serwera dostęp przez kontest kontenera, żeby na przykład zrobić lazy initialization

Zarejestruj się i dołącz do największej społeczności programistów w Polsce.

Otrzymaj wsparcie, dziel się wiedzą i rozwijaj swoje umiejętności z najlepszymi.