wiremock-client
Useful common functions to easily use wiremock
Install
yarn add --dev @osskit/wiremock-client
Usage
basic usage
import { setGlobalConfiguration, reset, createMapping, hasMadeCalls, waitForCalls } from '@osskit/wiremock-client';
setGlobalConfiguration({ baseUrl: 'http://localhost:9090' });
describe('tests', () => {
beforeEach(async () => {
await reset();
});
it('hasMadeCalls', async () => {
const request = await createMapping({ request: { urlPathPattern: '/someUrl', method: HttpMethod.Post } });
await fetch('http://localhost:9090/someUrl', { method: HttpMethod.Post, body: '{}' });
await expect(hasMadeCalls(request)).resolves.toBeTruthy();
});
it('Simulating errors', async () => {
await createMapping({
request: { urlPathPattern: '/someUrl', method: HttpMethod.Post },
response: { fault: 'CONNECTION_RESET_BY_PEER' },
});
await fetch('http://localhost:9090/someUrl', { method: HttpMethod.Post, body: '{}' });
});
it('waitForCalls', async () => {
const request = await createMapping({ request: { urlPathPattern: '/someUrl', method: HttpMethod.Post } });
await fetch('http://localhost:9090/someUrl', { method: HttpMethod.Post, body: '{}' });
const calls = await waitForCalls(request);
expect(calls).toHaveLength(1);
expect(calls[0]).toHaveProperty('body', {});
});
});
creating multiple clients
useful for parallel tests
import { WireMockClient } from '@osskit/wiremock-client';
const client = new WireMockClient('http://localhost:9090');
const client2 = new WireMockClient('http://localhost:8080');
describe('tests', () => {
beforeEach(async () => {
await client.reset();
await client2.reset();
});
it('hasMadeCalls', async () => {
const request = await client.createMapping({ request: { urlPathPattern: '/someUrl', method: HttpMethod.Post } });
await fetch('http://localhost:9090/someUrl', { method: HttpMethod.Post, body: '{}' });
await expect(client.hasMadeCalls(request)).resolves.toBeTruthy();
});
it('waitForCalls', async () => {
const request = await client2.createMapping({ request: { urlPathPattern: '/someUrl', method: HttpMethod.Post } });
await fetch('http://localhost:8080/someUrl', { method: HttpMethod.Post, body: '{}' });
const calls = await client2.waitForCalls(request);
expect(calls).toHaveLength(1);
expect(calls[0]).toHaveProperty('body', {});
});
});
API
setGlobalConfiguration(configuration)
Overrides the global configuration for the wiremock client.
Usually called once at the start of the tests.
configuration
Type: Configuration
baseUrl?
Type: string
Default: http://localhost:8080
The url to the wiremock
server.
reset()
Resets the requests' mapping.
Returns a Promise<void>
.
createMapping(mapping)
Creates mapping between request and response for the mocks to return.
Returns a Promise
to the request, so it can later be used to get the calls or check if the request was made.
mapping
Type: Mapping
request
Type: RequestPattern
The pattern to match requests
url?
Type: string
urlPathPattern?
Type: string
method?
Type: HttpMethod
queryParameters?
Type: Record<string, any>
bodyPatterns?
Type: Record<string, any>[]
response?
Type: Response
Default: { status: 200 }
status
Type: number
jsonBody?
Type: Record<string, any>
Type: Record<string, any>
body?
Type: string
Body can be a template used to generate random responses, for example:
await createMapping({
request: { urlPathPattern: '/someUrl', method: HttpMethod.Post },
response: { status: 200, body: "{{randomValue length=33 type='ALPHANUMERIC'}}", transformers: ['response-template'] },
});
To use this feature, make sure to start the wiremock docker with the --local-response-templating
option.
For more on templates see wiremock docs
base64Body?
Type: string
priority?
Type: number
waitForCalls(request, options?)
Return a Promise
to the calls that was made with the given request pattern.
Can be optionally ordered by a given orderBy
method.
It waits to get the
requests from
wiremock with the given timeout and interval.
Defaults:
- options: { timeoutOptions: { timeoutInMs: 3000, intervalInMs: 500 } }
request
Type: RequestPattern
options
Type: Options
timeoutOptions
Type: TimeoutOptions
Default: { timeoutInMs: 3000, intervalInMs: 500 }
The options for waiting until calls has been made.
orderBy(callA, callB)?
Type: Function
An optional function to sort the returning calls, returns a number
.
bodyAsString?
Type: boolean
Wheter to treat the body
of the requests as string
.
hasMadeCalls(request, timeoutOptions?)
Returns a Promise
to a boolean
representing if any calls with the given request pattern were made.
request
Type: RequestPattern
timeoutOptions
Type: TimeoutOptions
Default: { timeoutInMs: 3000, intervalInMs: 500 }
The options for waiting until calls has been made.