Moco框架的搭建使用

2023-12-09 21:52
文章标签 使用 搭建 框架 moco

本文主要是介绍Moco框架的搭建使用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、前言
  之前一直听mock,也大致了解mock的作用,但没有具体去了解过如何用工具或框架实现mock,以及也没有考虑过落实mock,因为在实际的工作中,很少会考虑用mock。最近在学java,刚好了解到moco框架是用于mock的,凑巧就实践一下基本的运用吧。

二、Mock介绍
  Mock技术又叫测试桩、挡板,就是在测试过程中,对于某些不容易构造或者不容易获取的对象,用一个虚拟的对象来创建以便测试的测试方法。 在具体的测试过程中,我们经常会碰到需要模拟数据或者接口的情况,因为环境问题或者系统复杂度的问题,我们需要使用 Mock 方式进行数据的模拟。

1、测试行业中的应用场景
1.某个新需求,开发未完成,测试人员使用mock技术,把新增的业务使用mock技术模拟出来,进行初步测试,等开发人员开发完成,再进行真实环境测试。

2.在项目中,经常会用到很多第三方接口,比如充值、防沉迷验证。第三方接口返回效率低、环境搭建麻烦,可以使用mock技术,先测试整体流程。

2、怎么用mock?
1.测试团队开发--技术要求高,使用django、flask等

2.使用现成工具  postman、fiddler等

3.不写代码,使用框架(moco)去创建mock   moco.jar+xxx.json  (简单)

三、Moco框架介绍
  moco可以理解为一个mock的工具框架,一个简单搭建模拟服务器的工具,下载下来是一个jar包。

特点:

1.只需要简单地配置request、response等即可满足需求

2.支持http、https、socket协议,非常灵活

3.支持在request中设置Headers、Cookies、StatusCode等

4.支持get、post、put、delete等请求方式

5.无需环境配置,有Java环境即可

6.支持热更新,修改配置后,立即生效,只需要维护接口即可

7.支持多种数据格式,如json、text、xml、file等

8.可与其他工具集成,如Junit、Maven等

四、Moco工作原理

五、Moco框架运行

1、环境说明

  需先安装JDK并配置环境变量

2、Moco下载

  下载地址:https://github.com/dreamhead/moco

3、Moco目录结构

  在本地新建一个文件夹,将下载好的jar包放入文件夹,然后新建json配置文件,以下是以自己电脑为例截图:

4、Json说明
1)moco-get.json
[{"description": "一个简单的get请求","request": {"method": "get","uri": "/login"},"response": {"text": "我是login get method","headers":{"Content-Type":"text/html;charset=utf-8"}}},{"description": "带参数的get请求,p1和p2是两个参数","request": {"method": "get","uri": "/reg","queries": {"p1": "v1","p2": "v2"}},"response": {"text": "带参数的get请求","headers":{"Content-Type":"text/html;charset=utf-8"}}},{"description": "get请求返回json类型数据","request": {"method": "get","uri": "/login_json"},"response": {"json": {"key":"value","请求方式是get":"响应结果为json类型"},"headers": {"Content-Type": "application/json;charset=utf-8"}}}
]

2)moco-post.json
[{"description": "定义请求方式,通过method参数定义","request": {"uri": "/index","method": "post"},"response": {"text": "hello world"}},{"description": "定义请求参数,通过queries参数定义","request": {"uri": "/index","method": "get","queries": {"area": "010","kw": "hello"}},"response": {"text": "hello world"}},
{"description": "定义请求头,通过headers参数定义","request": {"uri": "/login","method": "post","headers": {"area": "010"}},"response": {"text": "hello world"}},
{"description": "定义表单请求体,通过forms参数定义","request": {"uri": "/login","method": "post","forms": {"username": "tom","password": "123456"}},"response": {"text": "login success"}},
{"description": "定义JSON请求体,通过json参数定义","request": {"uri": "/login","method": "post","headers": {"Content-Type": "application/json"},"json": {"username": "tom","password": "123456"}},"response": {"text": "hello world66666"}},
{"description": "定义HTTP响应状态码,通过status参数定义","request": {"uri": "/index2"},"response": {"status": 500,"text": "error"}},{"description": "定义JSON响应数据,通过json参数定义","request": {"uri": "/login"},"response": {"headers": {"Content-Type": "application/json;charset=UTF-8"},"json": {"code": "10000","msg": "操作成功","data": {"uid": 2,"token": "xxx"}}}}
]
3)moco-redirect.json
{"description":"重定向到指定网站","request":{"method":"get","uri":"/login_redirect"},"redirectTo":"https://www.baidu.com"}

字段说明:

description:程序不会识别,是写给我们自己看的;

request:请求,里面的 uri 是我们访问应用的时候拼接在端口后面的路径;

response:响应内容;

其他说明:post中

headers:请求头,根据是form还是json格式的请求来填写
from格式:"content-type": "application/x-www-form-urlencoded"
json格式:"content-type": "application/json"
请求参数格式以及数据,对应headers的content-type
form格式关键字为forms
json格式关键字为json
5、Moco启动服务
  有了jar包和json数据,就可以启动moco了

  打开cmd,切到jar包所在的路径后,执行指令:java -jar jar包的路径 http -p 运行端口 -c 要运行的文件路径

  以自己电脑为例,启动成功后效果如下:java -jar moco-runner-1.3.0-standalone.jar http -p 8899 -c moco-get.json

6、验证
1)打开浏览器,输入地址访问:

http://localhost:8899/login

http://localhost:8899/reg?p1=v1&p2=v2 

http://localhost:8899/login_json 

2)post请求的不能直接通过地址访问,可以用接口工具访问
  这里就不演示,类似访问正常接口

7、拓展-Moco引入配置文件
  moco支持在配置文件中引入其他配置文件,这样可以分服务/模块定义配置文件,便于对配置文件的管理。

实现步骤:

1)分服务/模块定义配置文件,如分别定义moco-get.json、moco-post.json、moco-redirect.json文件

2)定义启动配置文件,如config.json并引入其他配置文件

3)启动服务:java -jar moco-runner-1.3.0-standalone.jar http -p 8899 -g config.json

 注意:通过-g config.json指定配置文件

最后感谢每一个认真阅读我文章的人,看着粉丝一路的上涨和关注,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走!

软件测试面试文档

我们学习必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有字节大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。

这篇关于Moco框架的搭建使用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/475209

相关文章

使用Vue-ECharts实现数据可视化图表功能

《使用Vue-ECharts实现数据可视化图表功能》在前端开发中,经常会遇到需要展示数据可视化的需求,比如柱状图、折线图、饼图等,这类需求不仅要求我们准确地将数据呈现出来,还需要兼顾美观与交互体验,所... 目录前言为什么选择 vue-ECharts?1. 基于 ECharts,功能强大2. 更符合 Vue

如何合理使用Spring的事务方式

《如何合理使用Spring的事务方式》:本文主要介绍如何合理使用Spring的事务方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、介绍1.1、底层构造1.1.事务管理器1.2.事务定义信息1.3.事务状态1.4.联系1.2、特点1.3、原理2. Sprin

Vue中插槽slot的使用示例详解

《Vue中插槽slot的使用示例详解》:本文主要介绍Vue中插槽slot的使用示例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、插槽是什么二、插槽分类2.1 匿名插槽2.2 具名插槽2.3 作用域插槽三、插槽的基本使用3.1 匿名插槽

使用WPF实现窗口抖动动画效果

《使用WPF实现窗口抖动动画效果》在用户界面设计中,适当的动画反馈可以提升用户体验,尤其是在错误提示、操作失败等场景下,窗口抖动作为一种常见且直观的视觉反馈方式,常用于提醒用户注意当前状态,本文将详细... 目录前言实现思路概述核心代码实现1、 获取目标窗口2、初始化基础位置值3、创建抖动动画4、动画完成后

PyQt5 QDate类的具体使用

《PyQt5QDate类的具体使用》QDate是PyQt5中处理日期的核心类,本文主要介绍了PyQt5QDate类的具体使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录核心功能常用方法及代码示例​1. 创建日期对象​2. 获取日期信息​3. 日期计算与比较​4. 日

Go语言使用slices包轻松实现排序功能

《Go语言使用slices包轻松实现排序功能》在Go语言开发中,对数据进行排序是常见的需求,Go1.18版本引入的slices包提供了简洁高效的排序解决方案,支持内置类型和用户自定义类型的排序操作,本... 目录一、内置类型排序:字符串与整数的应用1. 字符串切片排序2. 整数切片排序二、检查切片排序状态:

使用Java将实体类转换为JSON并输出到控制台的完整过程

《使用Java将实体类转换为JSON并输出到控制台的完整过程》在软件开发的过程中,Java是一种广泛使用的编程语言,而在众多应用中,数据的传输和存储经常需要使用JSON格式,用Java将实体类转换为J... 在软件开发的过程中,Java是一种广泛使用的编程语言,而在众多应用中,数据的传输和存储经常需要使用j

Nginx使用Keepalived部署web集群(高可用高性能负载均衡)实战案例

《Nginx使用Keepalived部署web集群(高可用高性能负载均衡)实战案例》本文介绍Nginx+Keepalived实现Web集群高可用负载均衡的部署与测试,涵盖架构设计、环境配置、健康检查、... 目录前言一、架构设计二、环境准备三、案例部署配置 前端 Keepalived配置 前端 Nginx

Python logging模块使用示例详解

《Pythonlogging模块使用示例详解》Python的logging模块是一个灵活且强大的日志记录工具,广泛应用于应用程序的调试、运行监控和问题排查,下面给大家介绍Pythonlogging模... 目录一、为什么使用 logging 模块?二、核心组件三、日志级别四、基本使用步骤五、快速配置(bas

使用animation.css库快速实现CSS3旋转动画效果

《使用animation.css库快速实现CSS3旋转动画效果》随着Web技术的不断发展,动画效果已经成为了网页设计中不可或缺的一部分,本文将深入探讨animation.css的工作原理,如何使用以及... 目录1. css3动画技术简介2. animation.css库介绍2.1 animation.cs