Stubbing External APIs
WireMock is a tool which mimics the behaviour of an HTTP API, it captures the HTTP requests and sends it to WireMock HTTP server, which is started and as a result, we can setup expectations, call the service and then verify its behaviour.
Below are three situations when we should use WireMock:
An engineering team needs to implement a feature which uses an HTTP API that is not ready, this occurs often in an microservice based architecture.
To avoid engineering waste, you can mimic the behaviour of the HTTP API using WireMock and then replace the call to WireMock API to the actual API.
Scenario: Class A -> depends on -> Class B -> depends on -> HTTP API
We want to unit test for Class A.
Option1: Replace depend Class B with a MockObject when unit testing Class A.
However, if the API client is written by you, using a mock object is not a good choice because it does not allow us to verify that our code can communicate with the HTTP API.
Sociable Tests
Therefore, Class A & Class B should be tested as one unit and as a result we can verify that the correct information is send to the HTTP API and ensure that all legal responses can be processed by both Class A & Class B.
Dependency Down
External HTTP API cannot initialise into a known state before the tests are run. Therefore, we cannot write tests which use the data returned by the external HTTP API, as it can differ.
Slow tests
External HTTP API takes longer than getting the same response from WireMock and we cannot use a short timeout because the test will fail, when the call is timed out.
API Requests Blocked
Wrong network connection, the API request which does not come from a known IP address is blocked.
The WireMock tests will ensure
- Our application sends the expected requests to the used HTTP API.
- Our application is working as expected when it receives an expected response from the HTTP API. It is important that our expectations are correct otherwise those tests can be false positive.
- Configure the response returned by the HTTP API when it receives a specific request.
- Capture the incoming HTTP requests and write assertions for that requests.
- Identify the stubbed or captured HTTP requests by using request matching
- Configure request matchers by comparing the request.
- URL, request method, request headers, cookies and request body
- Run it as a standalone process. (flexible deployments)
- Redirect HTTP Requests to another location.
- Record and Playbacks
- Support edge case failures & reduce build times