mountebank安装、启动

最近想要找一款可以提供假接口数据的软件,以便在开发时提供给前端和移动端使用,这样前端的任务就可以和后端一起开发,甚至可以提前开发。正好mountebank进入了视线,这里记录下学习过程,并准备在工作中使用。

安装

1. node安装

node的版本需要在4以上

npm install -g mountebank

运行

mb

加载配置文件启动

mb start --configfile ./imposters.ejs

imposters.ejs是配置文件,用来配置模拟的请求的返回值。

注意:配置文件更新后,需需要重启命令,暂时未找到热更新方法

2. 使用docker-compose

安装docker, 新建一个目录创建docker-compose.yaml文件,添加一下内容

version: "2"
services:
  mountebank:
    image: expert360/mountebank
    volumes:
     - ./imposters/:/imposters
    ports:
     - 2525:2525
     - 4545:4545
     - 4646:4646
     - 5555:5555
     - 52602:52602
    entrypoint:
     - mb
     - start
     - --configfile
     - /imposters/imposters.ejs
     - --allowInjection

说明:

  • volumes : 挂载目录,./imposters 当前目录的imposters映射到容器里的/imposters
  • ports : 端口映射

启动:

docker-compose up

注意:修改了mountebank的文件必须重启容器,目前没有找到热加载的方法

模拟请求

官方示例

imposters.ejs

{
  "port": 4545,
  "protocol": "http",
  "stubs": [{
    "responses": [
      { "is": { "statusCode": 400 }}
    ],
    "predicates": [{
      "and": [
        {
          "equals": {
            "path": "/test",
            "method": "POST",
            "headers": { "Content-Type": "application/json" }
          }
        },
        {
          "not": {
            "contains": { "body": "requiredField" },
            "caseSensitive": true
          }
        }
      ]
    }]
  }]
}

启动命令如上节,mb start --configfile ./imposters.ejs

模拟请求1

请求

curl -i -X POST -H 'Content-Type: application/json' http://localhost:4545/test --data '{"optionalField": true}'

结果

HTTP/1.1 400 Bad Request
Connection: close
Date: Wed, 28 Feb 2018 08:02:47 GMT
Transfer-Encoding: chunked

模拟请求2

请求

curl -i -X POST http://localhost:4545/test --data '{"optionalField": true}'

结果

HTTP/1.1 200 OK
Connection: close
Date: Wed, 28 Feb 2018 08:02:55 GMT
Transfer-Encoding: chunked

出现相似的结果则说明配置正确。

配置说明

这里对imposter的主要配置项进行简单的说明,让大家对配置有一个整体的了解。

  • port

    该imposter的监听端口。目前发现两个imposter的监听端口不能重复,否则会有一个imposter的配置加载不上

  • protocol

    协议,mountebank支持多种协议包括:http, https, tcp, smtp。

  • stubs

    模拟请求响应(response)的配置集合。该配置包含了模拟请求的接收条件和响应结果。

    • predicates

      请求断言。用来断言请求是否被改stub接收。

    • responses

      请求相应。断言判断成功后对请求的响应结果。

你可能感兴趣的:(mountebank安装、启动)