Socket
Socket
Sign inDemoInstall

@cxcloud/mimic

Package Overview
Dependencies
99
Maintainers
5
Versions
2
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

    @cxcloud/mimic

Zero configuration mocking application


Version published
Weekly downloads
0
decreased by-100%
Maintainers
5
Install size
3.38 MB
Created
Weekly downloads
 

Readme

Source

Mimic

Service to create mockserver with with zero configuration. Mimic uses express server with useful middlewares to provide simple application to create mock responses.

Getting started

# Create app folder with templates
mkdir -p mock/templates

# Init npm
cd mock && npm init -y

# Install
npm i @cxcloud/mimic
npx mimic --version
npx mimic --help

# Create main file
cat << EOF > main.js
const { Mimic } = require('@cxcloud/mimic');
Mimic.root.get('/greet', (req, res) => {
    res.json({
        data: 'hello world!'
    })
});
EOF

# Start mimic
DEBUG=mimic* npx mimic

# To use separate base folder
mkdir subfolder
mv templates subfolder/
mv main.js subfolder/
# mock/subfolder/
# ├── main.js
# └── templates

# Start mocking application in another folder and port
DEBUG=mimic* npx mimic -d subfolder -p 3000

Usage

// main.js
const { Mimic } = require('@cxcloud/mimic');

Mimic.root.get('/greet', (req, res) => {
  res.json({
    data: 'hello world!'
  });
});

Mimic.root is basically express router mounted at root '/' For Router mapping see Express routing

Examples

Return xml document using template

Directory structure

root
 |- templates
 |    `- user.ejs
 `- main.js

Template file

<!-- templates/user.ejs -->
<user><%= user.name %></user>

Route mapping

// main.js
const { Mimic } = require('@cxcloud/mimic');

const users = [{ name: 'user-one' }, { name: 'user-two' }];

Mimic.root.post('/users/:userId', (req, res) => {
  res.type('text/xml; charset=utf-8');
  const userId = parseInt(req.params.userId);
  res.render('user', {
    user: users[userId - 1]
  });
});

In above example requesting

  • POST /users/1 '<>...</>' will return user-one xml
  • POST /users/2 '<>...</>' will return user-two xml

Return respective response via request hashes

Each request uniquely generates hash from method, url and body. This hash can be used to respond with respective data;

const fruits = {
  'af7f992f-8489a5de': { name: 'apple' },
  'af7f992f-84a91dee': { name: 'banana' }
};

Mimic.root.post('/fruits', (req, res) => {
  const requestHash = res.locals.requestHash.combined;
  const data = fruits[requestHash];
  if (!data) {
    throw Error('Not found');
  }
  res.json(data);
});

In above example requesting

  • POST /fruits { "id": "a" } will generate hash "af7f992f-8489a5de"
  • POST /fruits { "id": "b" } will generate hash "af7f992f-84a91dee"

requestHash can be obtained via res.locals.requestHash object

{
    methodUrl: string;  // hash of method+url
    body: string;       // hash of body if exists or is empty
    combined: string;   // combiniation of hashes of methodUrl and body
}

FAQs

Last updated on 16 Jan 2020

Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc