美文网首页Java 杂谈程序员
mountebank安装、启动

mountebank安装、启动

作者: 菜鸟栖飞 | 来源:发表于2018-03-08 11:50 被阅读0次

    最近想要找一款可以提供假接口数据的软件,以便在开发时提供给前端和移动端使用,这样前端的任务就可以和后端一起开发,甚至可以提前开发。正好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安装、启动

        本文链接:https://www.haomeiwen.com/subject/edzefftx.html