Based around mockserver-client-node.
The package provides the ability to program the MockServer in design mode.
Configure expectations, scheduling requests and responses through a convenient builder system.
Detailed API documentation of MockServer can be found on the official website.
npm i mockserver-client-builder
import { client } from 'mockserver-client-builder';
// Config
const config = {
host: 'mockserver-srv',
port: 1080,
tls: false,
};
// Simple plain response mock
client(config)
.mockSimpleResponse('/simple-mock-request', { music: 'Rock' }, 418);
For running MockServer in Docker for local usage you can apply this docker-compose.yml.
For advanced manual configuration of MockServer in Docker see this article.
To run some scenario use nodejs CLI for compiled js.
$ eslint . --ext .ts
...
$ tcs --build
...
$ nodejs ./lib/path/complex-expectation.js
Now your MockServer is ready to accept requests with expectation responses based on complex-expectation.js
scenario.
Let's create a new file complex-expectation.ts
for mock expectation implementation.
src/path/complex-expectation.ts
import {
client, expectation, request, response,
} from 'mockserver-client-builder';
/**
* Complex expectation building with some advanced params for request matcher, response and expectation.
* @see {@link https://www.mock-server.com/mock_server/creating_expectations.html}
*/
// Config
const config = {
host: 'mockserver-srv',
port: 1080,
tls: false,
};
// Expectation
const expectationBuilder = expectation()
// When we send request
.when(
request()
.withMethod('GET')
.withPath('/cities')
.withQueryStringParameters({
'filter[id]': ['11', '12'],
code: ['61'],
}),
)
// We expect a respond
.action(
response()
.withStatusCode(200)
.withBody({
items: [
{
id: '1',
name: 'Ростов-на-Дону',
},
{
id: '2',
name: 'Москва',
},
{
id: '3',
name: 'Таганрог',
},
],
})
.withCookies({
session_id: 'Rftre5638jucg93',
})
.withHeaders({
'Content-Type': [
'application/json; charset=utf-8',
],
'Cache-Control': [
'public, max-age=86400',
],
'X-Vendor': [
'Oleg Chulakov Studio',
],
}),
)
// Sets priority of expectation
.withPriority(100)
// After 2 calls the expectation will be cleared
.withTimes({
remainingTimes: 2,
})
// After 30 seconds the expectation will be deleted
.withTimeToLive({
timeUnit: 'SECONDS',
timeToLive: 30,
})
// Set custom expectation id for simple update (replace)
.withId('the-on-of-123');
// Send our expectation into mocksever
client(config)
.mockAnyResponse(expectationBuilder)
.then((/* value */) => {
console.log('OK: /cities');
}, (/* reason */) => {
console.log('FAIL: /cities');
});
Let's write a small code in file reset-all.ts
.
src/path/reset-all.ts
import { client } from 'mockserver-client-builder';
/**
* Clear & resets all data: logs, expectations.
*
* @see {@link https://www.mock-server.com/mock_server/clearing_and_resetting.html}
*/
// Config
const config = {
host: 'mockserver-srv',
port: 1080,
tls: false,
};
// Reset all saved expectations in Mockserver
client(config)
.reset()
.then((/* value */) => {
console.log('OK: Clear All');
}, (/* reason */) => {
console.log('FAIL: Clear All');
});
See other examples with creation of requests, responses, expectations and also control it in mockserver.
For example, the MockServer started on mockserver-srv
, without https and on 1080 port.
SCHEMA=http HOST=mockserver-srv PORT=1080 npm run test