This library can be used to Mock REST requests in NodeJS. It works with Connect middleware and adds on the fly mock functionality to a NodeJS server.
Sometimes when you're testing a website or app that's backed by a NodeJS server, you'd like to see what happens if the server would give different results. That's what this library does for you.
You send a POST request to your webserver telling it that you want to mock a certain request. This POST request contains the mock data. After that, GET requests will return the mocked data.
Of course also works with other methods besides GET these operations will be performed in memory (PUT/POST, DELETE & GET)..
The above scenario can be easily applied to web applications build with Grunt when using Grunt with Connect middleware. See below for examples of how to configure this.
Install with NPM and add to your project.
var mockRequests = require('mock-rest-request');
var app = connect()
.use(mockRequests())
http.createServer(app).listen(3000);
var http = require('http');
var mockRequests = require('mock-rest-request');
http.createServer(function (req, res) {
mockRequests()(req, res);
}).listen(3000);
var mockRequests = require('mock-rest-request');
connect: {
options: {
// your options
},
livereload: {
options: {
},
middleware: function (connect, options) {
var middlewares = [];
middlewares.push(mockRequests());
options.base.forEach(function (base) {
middlewares.push(connect.static(base));
});
return middlewares;
}
}
}
Once you've added mock-rest-request
to your project, you can start making POST requests to mock certain rest requests. These call need to start the path with /mock
, followed by the path to mock.
Let's say we have our server running on localhost, port 3000 and we want to mock the call that gives back the user. With curl we can send the POST request telling the server that we want to mock this request.
curl -X POST -d '{"name":"Foo"}' http://localhost:3000/mock/api/user
After that, normal calls (like the ones coming from our web application) will then return the mocked data.
curl http://localhost:3000/api/user
{"id": 1, "name":"Foo"}
curl http://localhost:3000/api/user/1/
{"id": 1, "name":"Foo"}
curl -X PUT -d '{"name":"Foos 1"}' curl http://localhost:3000/api/user/1/
{"id": 1, "name":"Foos 1"}
curl -X POST -d '{"name":"Foos 2"}' curl http://localhost:3000/api/user/
{"id": 2, "name":"Foos 2"}
curl -X DELETE http://localhost:4000/api/users/1/
{"id": 1, "name":"Foos 1"}
To remove the mock for a certain path, call /reset on the path.
curl http://localhost:3000/reset/api/user