npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

webservice-mocker

v0.8.4

Published

A simple webservice mocker to mock basic http calls

Downloads

13

Readme

Webservice Mocker

Build Coverage Status Version Downloads Total Downloads Dependencies

A simple api mocker which validates the request and respond based on a config file.

NPM

#####Whats new?

Usage of variables in Route URL and response payload

To run

(1) Define your request and response as per the structure given below [example: login.json]

{
    "request" : {
        "headers" : {
            "Content-Type" : "application/json"
        },
        "payload" : {
            "username": "Cerlin",
            "password" : "random"
        }
    },
    "response" : {
        "headers" : {
            "Content-Type" : "application/json"
        },
        "statusCode" : 201,
        "payload" : {
            "success" : true,
            "message" : "Successfully logged in"
        }
    }
}

        [Note: Not all http verbs uses payload variable]

(2) Define your routes as per the structure given below. Routes are the files which connects the request and the config.

{
    "GET:/api/v2/user" : {
        "rule" : "./[path to file]/user.json"
    },
    "POST:/api/v2/user" : {
        "rule" : "./[path to file]/login.json"
    },
    "GET:/api/v2/posts" : {
        "data" : {
            "request" : {
                "headers" : {
                    "content-type" : "application/json"
                }
            },
            "response" : {
                "headers" : {
                    "content-type" : "application/json"
                },
                "statusCode" : 200,
                "payload" : {
                    "posts" : [
                        {
                            "name" : "Post 1"
                        },
                        {
                            "name" : "Post 2"
                        }
                    ],
                    "message" : "Posts retrieved successfully"
                }
            }
        }
    },
    "POST:/api/v2/user/:id/:name" : {
        "data" : {
            "request" : {
                "headers" : {
                    "Content-Type" : "application/vnd.api+json"
                },
                "payload" : {
                    "fake" : "data"
                }
            },
            "response" : {
                "headers" : {
                    "Content-Type" : "application/vnd.api+json"
                },
                "statusCode" : 200,
                "payload" : {
                    "name" : ":name",
                    "id" : ":id"
                }
            }
        }
    }
}

[Note: The path should be relative from your app's root directory] [Note: You can have inline request/response definition as well] [Note: Now you can use variables in URL. Ofcourse the variables can be used in RESPONSE payload]

(3) Create a http server, require the mocker and call the handle method like,

var http = require('http');
var mocker = require('webservice-mocker');

var server = http.createServer(function (req,res) {
    // by default the routes will be searched in ./routes/routes.json
    // use mocker.setRouteFile('path to the routes file') to over load with a different file

    mocker.handle(req,res);
});

server.listen(8080);

        [Note: If there is any error in loading the routes or config file, the response payload will have the error message.]

After putting files in place, your project will look something similar to the below image. (ofcourse you can have custom folder name and file name)

Imgur

or simply register your routes using get or post methods [Available from v0.4.0] like metioned below

var http = require('http');
var mocker = require("webservice-mocker");
mocker.enableLogs(); // Should be the first method, so that all the actions will be logged.


var requestObject = {
    "headers" : {
        "content-type" : "application/json"
    }
};

var responseObject = {
    "headers" : {
        "content-type" : "application/json"
    },
    "statusCode" : 200,
    "payload" : {
        "links" : [
            {
                "name" : "Link 1"
            }
        ],
        "message" : "Links retrieved successfully"
    }
};

var postReqObj = {};
postReqObj['headers'] = requestObject['headers'];
postReqObj['payload'] = {
    "name" : "cerlin"
}
var postResObj = {};
postResObj['headers'] = responseObject['headers'];
postResObj['payload'] = {
    "links" : [{
        "name" : "cerlin"
    }]
}

var getReqObj = {};
getReqObj['headers'] = requestObject['headers'];

var getNewResObj = {}; 
getNewResObj['headers'] = responseObject['headers'];
getNewResObj['payload'] = {
    "links" : [{
        "name" : "cerlin",
        "id" : ":id"
    }]
}

mocker
    .get('/api/v2/links', requestObject, responseObject)
    .post('/api/v2/links', postReqObj, postResObj)
    .get('/api/v2/user/:id', getReqObj, getNewResObj);

var server = http.createServer(function (req,res) {

    // use mocker.enableCors() to enable Cross Domain Request Sharing.
    // If CORS is enabled, the server will respond for requests with OPTIONS as method.
    mocker.handle(req,res);

});

server.listen(8080);

This Mocker exposes Ten methods

  1. mocker.handle(request, response). Method to handle the request. This method validates header and payload then return the response which is mentioned in routes.json

  2. mocker.setRouteFile('path to the routes file'). Method to force the app to read a different route file

  3. mocker.get(url, requestObj, responseObj). This method registers your GET request over the rules in routes file. (ie, if routes file is present then this rule will be appended with that else this rule standalone). This method can be used if you dont want to create any routes file and rules/config files. This method should be called before handle method [Please refer the example above for request/response structure]

  4. mocker.post(url, requestObj, responseObj). This method registers your POST request over the rules in routes file. (ie, if routes file is present then this rule will be appended with that else this rule standalone). This method can be used if you dont want to create any routes file and rules/config files. This method should be called before handle method [Please refer the example above for request/response structure]

  5. mocker.register(method, url, requestObj, responseObj). This method can be used to register GET or POST or PUT. Previous two methods will call this method internally. [Please refer the example above for request/response structure]

  6. mocker.enableCors(). This method is to enable Cross Domain Request Sharing . [Available from v0.5.0]

  7. mocker.disableCors(). This method is to disable Cross Domain Request Sharing . [Available from v0.5.0]

  8. mocker.enableLogs(). This method is to enable logs to be written in console. [Available from v0.6.0]. This method should be called just after requiring all the packages.

  9. mocker.disableLogs(). This method is to disable logs to be written in console. [Available from v0.6.0]

  10. mocker.setDefaultResponse(responseObj). This method is to override the default response given by the mocker. responseObj should be in the same structure as in response object passed in mocker.get. [Available from v0.8.0]

###Change Log: ####v0.8.4

  1. Update dependencies to accept latest patch version
  2. Removed dev dependency badge from the document

####v0.8.3

  1. Minor refactor
  2. Added more tests to improve code coverage

####v0.8.2

  1. Updated build process with coverage report generation.
  2. Added code coverage badge.

####v0.8.1

  1. Document update.

####v0.8.0

  1. Added method to override default response given by the mocker.

####v0.7.3

  1. Minor Document correction

####v0.7.2

  1. SEO

####v0.7.1

  1. Minor document correction

####v0.7.0

  1. Much awaited variables in URL and in Response payload.

####v0.6.1

  1. Minor document update.

####v0.6.0

  1. Added options to enable and disable logging info in console.

####v0.5.1

  1. Minor patch in CORS feature.

####v0.5.0

  1. Added options to enable and disable CORS.

####v0.4.1

  1. Code cleanup and minor corrections in README.MD

####v0.4.0

  1. Added support for putting data in routes file itself [Json file method is better for organising code for bigger mocking app.]
  2. Added methods [get, post and register methods] for better rule registration on the fly.

Contribution Note

#####1.Pull requests has to be created for dev branch not master as master will have only released code.

Feature poll

#####TODO:

  1. Default response should be configurable by the user.
  2. ~~Variables in URL~~
  3. ~~Logging all requests and response in console~~
  4. Support for file upload
  5. Support for regex based request payload.