Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

vite-plugin-mock-dev-server

Package Overview
Dependencies
Maintainers
1
Versions
84
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

vite-plugin-mock-dev-server

Vite Plugin for API mock dev server.

  • 1.0.7
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
1.8K
decreased by-21.29%
Maintainers
1
Weekly downloads
 
Created
Source

vite-plugin-mock-dev-server



Vite Plugin for API mock dev server.


npm node-current npm peer dependency version npm
GitHub Workflow Status fossa status


English | 简体中文



Feature

  • ⚡️ light weight,flexible,fast.
  • 🧲 Not injection-based, non-intrusive to client code.
  • 💡 ESModule/commonjs.
  • 🦾 Typescript.
  • 🏷 Support json / json5.
  • 📦 Auto import mock file.
  • 🎨 Support any lib,like mockjs,or not use it.
  • 📥 Path rule matching, request parameter matching.
  • ⚙️ Support Enabled/Disabled any one of api mock
  • 🔥 HMR
  • ⚖️ Use server.proxy
  • 🍕 Support viteConfig.define in mock file
  • ⚓️ Support resolve.alias
  • 📤 Support multipart content-type,mock upload file.
  • 🌈 Support vite preview mode
  • 🗂 Support building small independent deployable mock services.

Documentation

See the documentation to learn more.

Netlify Status

Playground

Open in StackBlitz

Usage

Install

# npm
npm i -D vite-plugin-mock-dev-server
# yarn 
yarn add vite-plugin-mock-dev-server
# pnpm
pnpm add -D vite-plugin-mock-dev-server

Configuration

vite.config.ts

import { defineConfig } from 'vite'
import mockDevServerPlugin from 'vite-plugin-mock-dev-server'

export default defineConfig({
  plugins: [
    mockDevServerPlugin(),
  ],
  // The fields defined here can also be used in mock.
  define: {},
  server: {
    proxy: {
      '^/api': {
        target: 'http://example.com'
      }
    }
  }
})

The plugin will read the configuration of server.proxy or options.prefix, and enable mock matching for matched URLs.

The plugin will also read the define configuration, which supports direct use in mock files.

Because in general scenarios, we only need to mock URLs with proxies so that we can use the proxy and mock services provided by Vite's HTTP service.

However, you can also configure mocks using options.prefix.

Edit Mock File

By default, write mock data in the mock directory of your project's root directory:

mock/api.mock.ts :

import { defineMock } from 'vite-plugin-mock-dev-server'

export default defineMock({
  url: '/api/test',
  body: {
    a: 1,
    b: 2,
  }
})

Methods

mockDevServerPlugin(options)

vite plugin

vite.config.ts

import { defineConfig } from 'vite'
import mockDevServerPlugin from 'vite-plugin-mock-dev-server'

export default defineConfig({
  plugins: [
    mockDevServerPlugin(),
  ]
})
options
  • options.prefix

    Type: string | string[]

    Configure custom matching rules for mock server. Any request path starting with the value of prefix will be proxied to the corresponding target. If the prefix value starts with ^, it will be recognized as a RegExp.

    In general, server.proxy is sufficient to meet the needs. Adding this item is for compatibility with certain scenarios.

    Default: []

  • option.include

    Type: string | string[]

    Configure to read mock files, which can be a directory, glob, or an array.

    Default: ['mock/**/*.mock.{js,ts,cjs,mjs,json,json5}'] (Relative to the root directory.)

  • options.exclude

    Type: string | string[]

    When reading mock files for configuration, the files that need to be excluded can be a directory, glob, or an array.

    Default:

    [
      '**/node_modules/**',
      '**/.vscode/**',
      '**/.git/**',
    ]
    
  • options.reload

    Type: boolean

    When the mock resource is hot updated, only the data content is updated, but the page is not refreshed by default. If you want to refresh the page every time you modify the mock file, you can open this option.

    Default: false

  • options.formidableOptions

    Configure to formidable,see formidable options

    Default: {}

    example: Configure to file upload dir

    MockDevServerPlugin({
      formidableOptions: {
        uploadDir: path.join(process.cwd(), 'uploads'),
      }
    })
    
  • options.build

    Configuration needed to build a small, independently deployable mock service.

    Type: boolean | ServerBuildOptions

    Default: false

    interface ServerBuildOptions {
      /**
       * server port
       * @default 8080
       */
      serverPort?: number
      /**
       * build output dir
       @default 'mockServer'
       */
      dist?: string
    }
    

defineMock(config)

Mock Type Helper

import { defineMock } from 'vite-plugin-mock-dev-server'

export default defineMock({
  url: '/api/test',
  body: {}
})

createDefineMock(transformer)

Return a custom defineMock function to support preprocessing of mock config.

import path from 'path'
import { createDefineMock } from 'vite-plugin-mock-dev-server'

// Preprocessed mock url
const defineAPIMock = createDefineMock((mock) => {
  mock.url = path.join('/api', mock.url)
})

export default defineApiMock({
  url: '/test' // Complete as '/api/test'
})

Mock Configuration

export default defineMock({
  /**
   * Request address, supports the `/api/user/:id` format.
   */
  url: '/api/test',
  /**
   * Supported request methods of the interface.
   * 
   * @type string | string[]
   * @default ['POST','GET']
   * 
   */
  method: ['GET', 'POST'],
  /**
   * In practical scenarios, 
   * we usually only need certain mock interfaces to take effect, 
   * rather than enabling all mock interfaces. 
   * For interfaces that do not currently require mocking, 
   * they can be set to false.
   * 
   * @default true
   */
  enable: true,
  /**
   * Set interface response delay, unit: ms.
   * 
   * @default 0
   */
  delay: 1000,
  /**
   * response status
   * 
   * @default 200
   */
  status: 200,
  /**
   * response status text
   */
  statusText: 'OK',
  /**
   * Request validator, return mock data if validated, otherwise do not use current mock. 
   * This is useful in scenarios where an interface needs to return different data based 
   * on different input parameters. 
   * Validators can solve this type of problem well by dividing the same URL into multiple 
   * mock configurations and determining which one is effective based on the validator.
   * 
   * @type { headers?: object; body?: object; query?: object; params?: object; refererQuery?: object  }
   * 
   * If the validator passes in an object, 
   * then the validation method is to strictly compare whether the `value` 
   * of each `key` in headers/body/query/params in the request interface is exactly equal. 
   * If they are all equal, then the validation passes.
   * 
   * @type ({ headers: object; body: object; query: object; params: object; refererQuery: object }) => boolean
   * If the validator passed in is a function, 
   * then the data related to the requested interface will be provided as input parameters 
   * for users to perform custom validation and return a boolean.
   * 
   */
  validator: {
    headers: {},
    body: {},
    query: {},
    params: {},
    /**
     * refererQuery validates the query parameters in the URL of the request source page, 
     * which allows for direct modification of parameters in the browser address bar 
     * to obtain different simulated data.
     */
    refererQuery: {}
  },
  /**
   * 
   * response headers
   * 
   * @type Record<string, any>
   * 
   * @type (({ query, body, params, headers }) => Record<string, any>)
   */
  headers: {
    'Content-Type': 'application/json'
  },

  /**
   * Response Body
   * Support `string/number/array/object` 
   * You can also use libraries such as' mockjs' to generate data content
   * 
   * @type string | number | array | object
   * 
   * @type (request: { headers, query, body, params }) => any | Promise<any>
   */
  body: {},

  /**
   * If the mock requirement cannot be solved through `body` configuration, 
   * then it can be achieved by configuring response and exposing the interface of http server 
   * to realize fully controllable custom configuration in req parameters. 
   * The parsing of query, body and params has been built-in, so you can use them directly. 
   * Don't forget to return response data through `res.end()` or skip mock by calling `next()`.
   */
  response(req, res, next) {
    res.end()
  }
})

Tips:

If you write mock files using json/json5, the 'response' method is not supported, as is the function form that uses other fields.

mock/**/*.mock.{ts,js,mjs,cjs,json,json5}

See more examples: example

Example 1:

Match /api/test,And returns a response body content with empty data

export default defineMock({
  url: '/api/test',
})
Example 2:

Match /api/test ,And returns a static content data

export default defineMock({
  url: '/api/test',
  body: {
    a: 1
  }
})
Example 3:

Only Support GET Method

export default defineMock({
  url: '/api/test',
  method: 'GET'
})
Example 4:

In the response header, add a custom header

export default defineMock({
  url: '/api/test',
  headers: {
    'X-Custom': '12345678'
  }
})
export default defineMock({
  url: '/api/test',
  headers({ query, body, params, headers }) {
    return {
      'X-Custom': query.custom
    }
  }
})
Example 5:

Define multiple mock requests for the same url and match valid rules with validators

export default defineMock([
  // Match /api/test?a=1
  {
    url: '/api/test',
    validator: {
      query: {
        a: 1
      }
    },
    body: {
      message: 'query.a == 1'
    }
  },
  // Match /api/test?a=2
  {
    url: '/api/test',
    validator: {
      query: {
        a: 2
      }
    },
    body: {
      message: 'query.a == 2'
    }
  },
  {
    /**
     * `?a=3` will resolve to `validator.query`
     */
    url: '/api/test?a=3',
    body: {
      message: 'query.a == 3'
    }
  }
])
Example 6:

Response Delay

export default defineMock({
  url: '/api/test',
  delay: 6000, // delay 6 seconds
})
Example 7:

The interface request failed

export default defineMock({
  url: '/api/test',
  status: 504,
  statusText: 'Bad Gateway'
})
Example 8:

Dynamic route matching

export default defineMock({
  url: '/api/user/:userId',
  body({ params }) {
    return {
      userId: params.userId,
    }
  }
})

The userId in the route will be resolved into the request.params object.

Example 9:

Use mockjs:

import Mock from 'mockjs'
export default defineMock({
  url: '/api/test',
  body: Mock.mock({
    'list|1-10': [{
      'id|+1': 1
    }]
  })
})

You need installed mockjs

Example 10:

Use response to customize the response

export default defineMock({
  url: '/api/test',
  response(req, res, next) {
    const { query, body, params, headers } = req
    console.log(query, body, params, headers)

    res.status = 200
    res.setHeader('Content-Type', 'application/json')
    res.end(JSON.stringify({
      query,
      body,
      params,
    }))
  }
})

Example 11:

Use json / json5

{
  // Support comment
  "url": "/api/test",
  "body": {
    "a": 1
  }
}

Example 12:

multipart, upload file.

use formidable to supported.

<form action="/api/upload" method="post" enctype="multipart/form-data">
    <p>
      <span>file: </span>
      <input type="file" name="files" multiple />
    </p>
    <p>
      <span>name:</span>
      <input type="text" name="name" value="mark">
    </p>
    <p>
      <input type="submit" value="submit">
    </p>
  </form>

fields files mapping to formidable.File

export default defineMock({
  url: '/api/upload',
  method: 'POST',
  body(req) {
    const body = req.body
    return {
      name: body.name,
      files: body.files.map((file: any) => file.originalFilename),
    }
  },
})

Mock Services

In some scenarios, it may be necessary to use the data provided by mock services for display purposes, but the project may have already been packaged, built and deployed without support from vite and this plugin's mock service. Since this plugin supports importing various node modules in mock files at the design stage, the mock file cannot be inline into client build code.

To meet such scenarios, on one hand, the plugin provides support under vite preview, and on the other hand, it also builds a small independent mock service application that can be deployed to relevant environments during vite build. This can then be forwarded through other HTTP servers like nginx to actual ports for mock support.

The default output is built into the directory dist/mockServer, generating files as follows:

./mockServer
├── index.js
├── mock-data.js
└── package.json

In this directory, execute npm install to install dependencies, and then execute npm start to start the mock server.

The default port is 8080.

You can access related mock interfaces through localhost:8080/.

Archives

awesome-vite

LICENSE

MIT

FOSSA Status

Keywords

FAQs

Package last updated on 22 Mar 2023

Did you know?

Socket

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
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc