====== Mock Server ====== * http://www.mock-server.com/ * [[network:test|Network simulation test]] * refer [[java:wiremock|java:wiremock]] * refer [[network:toxiproxy|toxiproxy]] * [[network:hoverfly|hoverfly]] * [[rest_api:json_server|Json Server]] * [[http://www.baeldung.com/mockserver|Introduction to MockServer]] * [[https://www.mock-server.com/mock_server/getting_started.html|Getting Started]] * [[https://www.mock-server.com/mock_server/running_mock_server.html|Mock Server 의 다양할 실행방법]] JUnit 으로 띄우기등. ===== 기본 개념 ===== * 별도의 Mock Server를 별도로 띄워놓고 Application에서 가상의 요청/응답 스펙을 작성한 뒤에 테스트를 진행하거나, * 혹은 Java Application의 경우 아예 테스트 코드 시작시 Mock 서버를 띄우고 테스트 진행후 서버도 내려버릴 수 있다. * 또한 Mock Server에 일부는 가상 요청/응답으로 하고, 나머지 일부는 실제 API 서버로 요청을 Proxy 하도록 처리도 가능하다. ===== Server ===== * 기본적으로 Netty 기반 Java application 이며 * 이를 통합 jar 실행, Maven plugin, npm, war(Tomcat에 올려 띄우기), Java Test code내에서 띄웠다 테스트 끝나면 종료, docker 등을 통한 서버 띄우기가 가능하다. * 간단한 Jar를 통한 실행 - 사이트에서 jar 다운로드 받고서 java -Dmockserver.logLevel=INFO -jar mockserver-netty-5.3.0-jar-with-dependencies.jar -serverPort 1080 ===== Client ===== * Java, node.js, REST API 등을 지원한다. * client로 expectation 정의, verification, reset(cleansing) 등을 수행할 수 있다. ==== Java Client ==== * ''org.mockserver.client.server.MockServerClient'' : 원격 MockServer 인스턴스에 접속하여 expectation을 선언하는 Client Class * ''org.mockserver.integration.ClientAndServer'': 로컬 MockServer 인스턴스를 생성하고 여기에 expectation을 선언하고 요청을 날린다. * 간단한 expectation 작성 - Mock Server를 띄우고 아래 코드를 실행한 뒤에 http://localhost:1080/hello 요청을 하면 3초 뒤에 "World!!시간" 응답이 온다. import static org.mockserver.model.HttpRequest.request; org.mockserver.model.HttpResponse#response() new MockServerClient("localhost", 1080) .when( request() .withMethod("GET") .withPath("/hello") ) .respond( response() .withDelay(TimeUnit.SECONDS, 3) .withBody("World!!" + LocalDateTime.now()) ); ==== 참조 ==== * [[https://www.baeldung.com/mockserver|Introduction to MockServer | Baeldung]]