Moco学习总结

作者: 星期六1111 | 来源:发表于2016-09-29 15:35 被阅读680次
    因为项目需要,和小伙伴pair学习了下Moco.

    一.Moco是什么?

    官方网站https://github.com/dreamhead/moco 上给出了解释,Moco是一个简单简单搭建stub的框架。那么新的问题又来了,什么是stub呢?stub(桩),维基百科上解释说:桩(Stub / Method Stub)是指用来替换一部分功能的程序段。桩程序可以用来模拟已有程序的行为(比如一个远端机器的过程)或是对将要开发的代码的一种临时替代。因此,打桩技术在程序移植、分布式计算、通用软件开发和测试中用处很大.
    根据stub的含义,我做出这样的猜测,Moco的作用就是替换某个功能。那么它替换了什么功能?为什么要替换呢?带着这样的问题,我们先按照官网上的Quick Start来走一遍吧!

    二 .Quick Start

    1.下载 Standalone Moco Runner,下载好后放在某的目录下,例如该目录为Moco-demo。
    2.写配置文件,内容如下:
    [
       { "response" :
            { "text" : "Hello, Moco" }
       } 
    ]
    

    (foo.json)

    3.启动 Moco 服务
    进入到你刚下载放jar包的目录,即cd Moco-demo

    输入以下命令:

    java -jar moco-runner-<刚下载jar包版本的版本好>-standalone.jar http -p 12306 -c foo.json
    

    注:-p 指定 Moco 服务端口 (目前仅指 Web 端口)

    4.访问 Web 服务打开浏览器,访问 http://localhost:12306 ,这样就可以看见"Hello, Moco"了

    三.Moco的作用是什么?

    这就回到了我上面的第一个问题,替换了什么功能?从上面的小demo可以看出,站在浏览器的角度上看,我输入了一个URL,看到了配置文件中的response内容,那么此时的Moco就像是一个模拟服务器。
    站在后台服务器的角度上看,配置文件中直接写好输出我想要的内容,这不就是相当于测试嘛。

    四.为什么使用Moco?

    1.我们先看如果不使用Moco会怎么样?
    在官网上说:集成,尤其是基于 HTTP 协议的集成——web service、REST 等,在我们的项目开发中被广泛应用。以前,我们每次都要往 Jetty 或 Tomcat 等应用服务器上部署一个新的 WAR。大家都知道,开发部署一个 WAR 的过程是很枯燥的,即使在嵌入式服务器上也是如此。而且,每次我们做一点改动,整个 WAR 都要重新组装。(稍微补充一下:在软件工程中,WAR文件(Web应用程序归档,英语:Web application ARchive[1])是一种JAR文件,其中包含用来分发的JSP、Java Servlet、Java类、XML文件、标签库、静态网页(HTML和相关文件),以及构成Web应用程序的其他资源。)
    2.Moco是如何解决这个问题的呢?
    很容易就可以想到,就是前面提到的模拟服务器,开发团队只要根据自己的需要进行相应的配置,就会很方便得到一个模拟服务器。(据说,由于 Moco 本身的灵活性,其用途已经不再局限于最初的集成测试,比如,Moco 可以用于移动开发,模拟尚未开发的服务;Moco 还可以用于前端开发,模拟一个完整的 Web 服务器,等等。这些没有使用到,目前没有深刻体会)
    好了,今天就到这里了,我们的小demo请详见github地址:https://github.com/MHwishes/moco-demo (用postman模拟客户端发送请求,demo中相同url,不同的method.)

    相关文章

      网友评论

      • 张雨生在路上:post请求该如何模拟?
        星期六1111:和get 类似,将请求类型改为post, 返回201(要不要返回你的message 和数据根据你的项目情况而定;post 本来就是新增,这里 mock 后的新增是假的,返回201只是表面上告诉你新增成功罢了

      本文标题:Moco学习总结

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