1.0.2
Denock intercepts HTTP calls to allow mocking response from third parties API
Repository
Current version released
a year ago
Dependencies
std
Versions
Denock
This module allow you to intercept HTTP calls. It’s inspired from the NPM package nock.
So your tests will not need --allow-net
flag anymore.😝
The package works but is still experimental. You can use it for some tests but there is a lot to do to make it stable.
If you find issues please open an issues on github and if you want to contribute open a PR. (see TODO section below)
Example:
import { denock } from 'https://raw.githubusercontent.com/SachaCR/denock/master/mod.ts';
// Or
import { denock } from 'https://deno.land/x/denock/mod.ts';
denock({
method: 'POST',
protocol: 'https',
host: 'jsonplaceholder.typicode.com',
headers: [{
header: 'content-type', value: 'application/json'
}],
path: '/todos',
requestBody: {
userId: 2,
id: 23024,
title: 'delectus aut autem',
completed: false,
},
replyStatus: 201,
responseBody: { example: 'My mocked response' },
});
const urlObject = new URL('https://jsonplaceholder.typicode.com/todos');
const response = await fetch(urlObject, {
method: 'POST',
headers: new Headers({
'content-type': 'application/json'
}),
body: JSON.stringify({
userId: 2,
id: 23024,
title: 'delectus aut autem',
completed: false,
}),
});
const body = await response.json();
console.log(body) // ==> { example: 'My mocked response' } instead of the real response.
);
Options object:
method
: “GET” | “POST” | “PATCH” | “PUT” | “DELETE”protocol
: “http” | “https”host
: host to interceptport
: optional port to interceptpath
: optional, is the path of the queryqueryParams
?: optional, object that contains URL query parametersheaders
: optional. Is an array of objects representing headersrequestBody
: optional, this is the body that the request must contains to be interceptedreplyStatus
?: optional, default 200, this is the status code that will be returned on interceptionresponseBody
: this is the body that will be returned on interception;interception
: optional, default 1 Represent the number of call you want to intercept;
TODO
- Implement intercept HTTP calls made with fetch with a simple string
- Implement intercept HTTP calls made with fetch with a simple string and RequestInit object
- Implement intercept HTTP calls made with fetch with a Request object
- Implement intercept HTTP calls made with fetch with a URL object
- Implement interception number
- Implement matching on headers
- Implement basic authentication