外贸领航
首页海外营销 > mock如何实现「接口开发框架」

mock如何实现「接口开发框架」

来源:互联网 2023-12-07 14:04:04
什么是接口Mock测试?

应用场景思考? 1.在前后端分离的项目中,假如后端代码还未开发完,前端代码需要调用后端接口进行调试,该怎么办? 2.本公司的电商平台需要对接第三方支付接口,如何测试支付失败的场景?

1.1 概念

Mock:模拟的、仿制的、虚假的

Mock测试:在测试过程中,对于某些不容易构造或者不容易获取的对象,可以用一个虚拟的对象来代替的测试方法。

接口Mock测试:在接口测试过程中,对于某些不容易构造或者不容易获取的接口,可以用一个模拟接口来代替。

1.2 作用

可以用来解除测试对象对外部服务的依赖,使得测试用例可以独立运行替换外部服务调用或一些速度较慢的操作,提升测试用例的运行速度模拟异常逻辑,异常逻辑往往很难触发,通过Mock可以人为的控制触发异常逻辑团队可以并行工作

1.3 实现方式

接口mock实现的核心思想是搭建一个Mock Server,通过该服务提供mock接口。常见的实现方式有:

使用第三方mock平台自己开发mock服务使用mock框架搭建mock服务

2. Moco框架

2.1 Moco简介

Moco是一个简单搭建模拟服务器的框架(工具),可以模拟http、https、socket等协议基于Java开发的开源项目,Github地址:https://github.com/dreamhead/moco原理:Moco会根据一些配置,启动一个真正的HTTP服务(会监听本地的某个端口)。当发起的请求满足某个条件时,就会返回指定的响应数据

2.2 环境搭建

Moco运行时所需环境包括:

Java运行环境安装JDK,并配置环境变量

moco-runner-1.1.0-standalone.jar下载地址:https://repo1.maven.org/maven2/com/github/dreamhead/moco-runner/1.1.0/moco-runner-1.1.0-standalone.jar

2.3 如何运行Moco

1>创建配置文件

创建配置文件test.json,并输入如下内容:

[ { "description": "首页", "request": { "uri": "/index" }, "response": { "text": "hello world" } }]

2>启动http服务

启动命令:

java -jar <path-to-moco-runner> http -p <monitor-port> -c <configuration-file>示例:java -jar moco-runner-1.1.0-standalone.jar http -p 9090 -c test.json<path-to-moco-runner>:jar包的路径<monitor-port>:http服务监听的端口<configuration-file>:配置文件路径

3>接口访问

打开浏览器,在浏览器地址栏中输入

2.4 Moco常用配置参数

定义请求方式,通过method参数定义[ { "description": "首页", "request": { "uri": "/index", "method": "post" }, "response": { "text": "hello world" } }]定义请求参数,通过queries参数定义[ { "description": "首页", "request": { "uri": "/index", "method": "get", "queries": { "area": "010", "kw": "hello" } }, "response": { "text": "hello world" } }]定义请求头,通过headers参数定义[ { "description": "登录", "request": { "uri": "/login", "method": "post", "headers": { "area": "010" } }, "response": { "text": "hello world" } }]定义表单请求体,通过forms参数定义[ { "description": "登录", "request": { "uri": "/login", "method": "post", "forms": { "username": "tom", "password": "123456" } }, "response": { "text": "login success" } }]定义JSON请求体,通过json参数定义[ { "description": "登录", "request": { "uri": "/login", "method": "post", "headers": { "Content-Type": "application/json" }, "json": { "username": "tom", "password": "123456" } }, "response": { "text": "hello world66666" } }]定义HTTP响应状态码,通过status参数定义[ { "description": "首页", "request": { "uri": "/index2" }, "response": { "status": 500, "text": "error" } }]定义JSON响应数据,通过json参数定义[ { "description": "登录", "request": { "uri": "/login" }, "response": { "headers": { "Content-Type": "application/json;charset=UTF-8" }, "json": { "code": "10000", "msg": "操作成功", "data": { "uid": 2, "token": "xxx" } } } }]

2.5 Moco引入配置文件

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

实现步骤:

分服务/模块定义配置文件,如分别定义index.json和login.json文件[ { "description": "首页", "request": { "uri": "/index" }, "response": { "text": "hello world" } }][ { "description": "登录", "request": { "uri": "/login" }, "response": { "text": "success" } }]定义启动配置文件,如config.json并引入其他配置文件[ {"include": "index.json"}, {"include": "login.json"}]启动服务java -jar moco-runner-1.1.0-standalone.jar http -p 9090 -g config.json

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

郑重声明:本文版权归原作者所有,转载文章仅为传播更多信息之目的,如有侵权行为,请第一时间联系我们修改或删除,多谢。

CopyRight © 外贸领航 2023 All Rights Reserved.