• 2015-05-12

    Moco 0.10.1发布

    Tag:moco

    版权声明:转载时请以超链接形式标明文章原始出处和作者信息及本声明
    http://www.blogbus.com/dreamhead-logs/272207202.html

    前版信息:Moco 0.10.0发布

    我很高兴地宣布,Moco 0.10.1发布了。

    Moco是什么?

    Moco是一个可以轻松搭建测试服务器的框架/工具/程序库。

    变更

    本次发布对使用Java API的用户最大影响在于,原来的httpserver已经废弃了,推荐使用httpServer。

        HttpServer server = httpServer(12306);

    另外一个废弃掉的API是没有TimeUnit的latency,推荐使用有时间单位的latency接口。

        server.response(latency(1, TimeUnit.SECONDS));

    以上废弃的API将会在下一次发布中移除,请尽早更新。

    接下来,比较大的变动是增加了字符集,file和pathResource都可以进行字符集的处理。

        server.response(file("gbk.response", Charset.forName("GBK")));

    甚至,日志也指定对应的字符集:

        HttpServer server = httpServer(port(), log("path.log", Charset.forName("UTF-8")));

    模板在原来对内容处理的基础上,增加了对文件名的处理:

        server.response(file(template("${var}.response", "var", "foo")));

    这样一来,你可以把更多模板的特性用在文件名上,比如jsonPath、xpath等,也就是说,可以把不同请求应答的结果,放到不同的文件里。当然,你可以把它用在JSON配置文件里:

    [
      {
        "response":
        {
          "file":
          {
            "name": {
              "template": {
                "with" : "${var}.response",
                "vars" : {
                  "var" : "foo"
                }
              }
            }
          }
        }
      }
    ]

    这次发布还有一个针对于JSON API的调整,就是现在可以mount的时候,额外增加应答配置,比如像下面这样:

    [
      {
        "mount" :
        {
          "dir" : "src/test/resources/mount",
          "uri" : "/mount-response",
          "headers" : {
            "Content-Type" : "text/plain"
          }
        }
      }
    ]

    还有一个针对全局配置的特性,就是配置全局Request,如果你想实现一个全局token,保证每次请求都带过来,现在,就不必在每个请求上编写,只要配置一个全局的就好了:

    [
      {
        "request" : {
          "headers" : {
            "foo" : "bar"
          }
        },
        "include": "blah.json"
      }
    ]

    还有一个实现细节方面的调整,如果在模板里采用了xpath或jsonpath,可能会返回多个值,可以参考freemarker的文档编写对多值对象的处理。

    更多发布相关信息,请参考Release Notes

    分享到:

    历史上的今天:

    客户来了 2008-05-12
    引用地址: