moco框架搭建接口mock服务

1、什么是接口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.3.0-standalone.jar

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

2.3、如何运行Moco

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

复制代码
[
    {
        "request": {
            "headers": {
                "content-type": "application/x-www-form-urlencoded"
            },
            "method": "post",
            "uri": "/login1",
            "forms": {
                "username": "admin",
                "pwd": "e10adc3949ba59abbe56e057f20f883e"
            }
        },
        "response": {
            "json": {
                "code": 0,
                "msg": "successed",
                "data": [{
                    "username": "admin",
                    "checkstatus": "on",
                    "token": "ksjdakfjadlkfjeoipwoewe092939wlskd9"
                }]
            },
            "status": 200
        }
    }
]
复制代码

2>启动http服务启动命令:
示例:

java -jar <path-to-moco-runner> http -p <monitor-port> -c <configuration-file>
  • <path-to-moco-runner>:jar包的路径
  • <monitor-port>:http服务监听的端口
  • <configuration-file>:配置文件路径
java -jar D:\TestTools\mock\moco-runner-0.11.1-standalone.jar http -p 12306 -g D:\TestTools\mock\api_student_login.json

3>接口访问打开jmeter执行接口请求

2.4、Moco常用配置参数

请求头:headers

请求方法:method

请求体:forms、queries、json

响应码:status

响应体:json

复制代码
[
    {
        "request": {
            "headers": {//定义请求头,通过headers参数定义
                "content-type": "application/x-www-form-urlencoded"
            },
            "method": "post",//定义请求方式,通过method参数定义
            "uri": "/login1",
            "forms": {//定义表单请求体,通过forms参数定义
                "username": "admin",
                "pwd": "e10adc3949ba59abbe56e057f20f883e"
            }
        },
        "response": {
            "json": {//定义JSON响应数据,通过json参数定义
                "code": 0,
                "msg": "successed",
                "data": [{
                    "username": "admin",
                    "checkstatus": "on",
                    "token": "ksjdakfjadlkfjeoipwoewe092939wlskd9"
                }]
            },
            "status": 200//定义HTTP响应状态码,通过status参数定义
        }
    }
]
复制代码

 

复制代码
[
    {
        "request": {
            "headers": {"content-type": "application/x-www-form-urlencoded"
            },
            "method": "post","uri": "/login1",
            "queries": {//定义请求参数,通过queries参数定义
          "username": "admin",
                "pwd": "e10adc3949ba59abbe56e057f20f883e"
            }
        },
        "response": {
            "json": {"code": 0,
                "msg": "successed",
                "data": [{
                    "username": "admin",
                    "checkstatus": "on",
                    "token": "ksjdakfjadlkfjeoipwoewe092939wlskd9"
                }]
            },
            "status": 200
        }
    }
]
复制代码

 

复制代码
[
    {
        "request": {
            "headers": {
                "content-type": "application/x-www-form-urlencoded"
            },
            "method": "post",
            "uri": "/login1",
            "json": {//定义JSON请求体,通过json参数定义
                "username": "admin",
                "pwd": "e10adc3949ba59abbe56e057f20f883e"
            }
        },
        "response": {
            "json": {//定义JSON响应体,通过json参数定义
                "code": 0,
                "msg": "successed",
                "data": [{
                    "username": "admin",
                    "checkstatus": "on",
                    "token": "ksjdakfjadlkfjeoipwoewe092939wlskd9"
                }]
            },
            "status": 200
        }
    }
]
复制代码
 

2.5、Moco 引入配置文件

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

1.分服务/模块定义配置文件,如分别定义api_student_login.json、api_student_list.json、api_student_info.json文件

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

[
  {"include": "api_student_login.json"},
  {"include": "api_student_list.json"},
  {"include": "api_student_info.json"}
] 

3.本地部署启动服务

java -jar D:\TestTools\mock\moco-runner-0.11.1-standalone.jar http -p 12306 -g D:\TestTools\mock\api_student_login.json

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

若部署服务器上注意nohup和&规则使用

4.接口访问打开jmeter执行接口请求

也可moco正常与异常接口情况

今天就介绍到这里,有疑问可留言回复

posted @   .kalo  阅读(451)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· AI与.NET技术实操系列(六):基于图像分类模型对图像进行分类
点击右上角即可分享
微信分享提示