『居善地』接口测试 — 20.Mock功能介绍

1、Mock功能介绍

各个业务系统都会关联多个三方系统接口调用,在测试过程中第三方业务存在不能及时提供接口调用,这时就需要用到我们的mock服务了。

Mock的本质在于模拟三方业务接口的返回,来满足自身的测试功能,快速完成测试任务。

如果你想学习自动化测试,我这边给你推荐一套视频,这个视频可以说是B站播放全网第一的自动化测试教程,同时在线人数到达1000人,并且还有笔记可以领取及各路大神技术交流:798478386   

【已更新】B站讲的最详细的Python接口自动化测试实战教程全集(实战最新版)_哔哩哔哩_bilibili【已更新】B站讲的最详细的Python接口自动化测试实战教程全集(实战最新版)共计200条视频,包括:1、接口自动化之为什么要做接口自动化、2、接口自动化之request全局观、3、接口自动化之接口实战等,UP主更多精彩视频,请关注UP账号。icon-default.png?t=N7T8https://www.bilibili.com/video/BV17p4y1B77x/?spm_id_from=333.337.search-card.all.click

2、Moco框架是什么

Moco框架是Mock概念中的一种实现。

Moco框架是一个简单搭建模拟服务器的程序库/工具,这个基于 Java 开发的开源项目。

Moco框架已经在 Github 上获得了不少的关注,该项目的简介是这样描述自己的:

  • Moco 是一个简单搭建 stub 的框架,主要用于测试和集成。

  • 这个框架的开发灵感来自 Mock 框架,如 MockitoPlayframework

为什么要开发这个框架?

  • 用于基于HTTP协议的集成:web serviceREST等,在我们的项目开发中被广泛应用。

  • 以前,我们每次都要往JettyTomcat等应用服务器上部署一个新的 WAR。

  • 大家都知道,开发部署一个 WAR 的过程是很枯燥的,即使在嵌入式服务器上也是如此。而且,每次我们做一点改动,整个 WAR 都要重新组装。

  • Moco框架的出现,正是为了解决这些问题。开发团队只要根据自己的需要进行相应的配置,就会很方便得到一个模拟服务器。

  • 而且,由于 Moco框架本身的灵活性,其用途已经不再局限于最初的集成测试。

    比如:

    Moco 可以用于移动开发;

    模拟尚未开发的服务;

    Moco 还可以用于前端开发,模拟一个完整的 Web 服务器等等。

3、Moco框架在接口测试中的作用

一般接口文档编写完成后,测试人员需要提前进行接口测试用例的编写,而这时接口开发工作可能还没完成。

如果要等到开发人员完成接口的开发,再进行测试用例的编写,这样会降低测试开发的效率。

这时如果测试人员使用Moco框架搭建一个模拟服务器,就可以根据接口文档,自己模拟出接口的调用并返回结果。

在用例设计完成后,即使接口开发工作还未完成,也可以立即进行接口测试用例的执行。并且在这个过程中可以修改、补充测试用例。

在接口开发完成以后,只需要简单的切换服务器地址,就可以测试所有的开发人员实现的接口了。这样可以节省很多的测试时间,减少项目开发的周期。

Moco框架支持HTTP协议,采用热部署,修改配置后,立刻生效,无需重启服务。

Moco框架接口测试中的作用:方法隔离,服务解耦。即可并行又可驱动。

4、Moco框架的优点

  1. 只需要简单的配置RequestResponse等即可满足要求,支持HTTP、HTTPS、SCOKET。可以说是非常的灵活性。

  2. 支持在Request中设置Headers , Cookies , StatusCode等。

  3. 对GET、POST、PUT、DELETE等请求方式均支持,很适合web开发。

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

  5. 修改配置后,立刻生效。只需要维护接口,也就是契约即可。

  6. 对可能用到的数据格式都支持,如json、text、xml、file等。

  7. 还能与其他工具集成,如Junit、Maven、Gradle等。

5、Moco框架的下载与启动

(1)Moco框架的下载

Github下载地址:https://github.com/dreamhead/moco(这里下载的是源码,不是jar包)

Moco框架Jar包下载地址:https://repo1.maven.org/maven2/com/github/dreamhead/moco-runner/0.11.0/

得到moco-runner-0.11.0-standalone.jar文件。

Moco框架文档地址:https://github.com/dreamhead/moco/blob/master/moco-doc/apis.md

(2)Moco框架的启动
  1. 条件:

    因为Moco框架工具是一个jar包,所以需要Java环境才能启动。

    即:配置好Java环境。

  2. 启动:

    把Moco框架Jar包和Json文件放入同一个文件夹中,

    命令行终端里进入到Json文件所在的目录,执行启用命令,如下:

    java -jar ./moco-runner-0.11.0-standalone.jar http -p 12306 -c foo.json即可。

    说明:

    ./moco-runner-0.11.0-standalone.jar为Moco工具所在目录。

    http:表示服务器协议,server type: http, https, socket

    -p:表示端口号。

    -c:表示一个json文件。接口所有的信息都配置在该json文件中。

提示:Moco工具路径和json文件路径都可以写相对路径和绝对路径。

6、Moco框架的使用

当需要调用接口来编写测试用例的时候,此时该接口并没有被实现,这个时候我们就可以用Mock框架来模拟一个接口出来。

使用Mock模拟接口以下功能:

  • 拦截服务:httphttps

  • 请求方式:GET,POST。

  • 模拟请求地址:URL。

  • 模拟参数:包括headercookie的数据。

  • 模拟响应结果。

  • 支持重定向。

(1)Moco框架第一个练习

编写一个Json文件,接口所有的信息都配置在该json文件中。

[{"description": "第一个Moco框架例子。",  # 描述:增加接口的可读性"request": {"uri": "/api/moco/demo",},"response": {"text": "hello Moco !"}}
]    

把Moco框架的jar包和上面编辑好的Json文件放在同一个文件夹中。

 

在cmd命令行或者PyCharm的命令行终端执行启动命令。

  • 进入json文件的所在目录。
  • 执行命令:java -jar ./moco-runner-0.12.0-standalone.jar http -p 12306 -c test.json

Moco服务启动后,我们可以使用Requests库请求接口,也可以用浏览器接口。

# 1.导入requests库
import requests# 2.明确请求地址
url = "http://127.0.0.1:12306/api/moco/demo"# 3.发送请求
response = requests.get(url=url)
print(response.text)

 

浏览器访问接口:

(2)Get方法的Mock实现

我们主要是看Json文件怎么写,其他步骤和上面练习一样。

1)、没有参数的get请求

[{"description": "模拟一个没有参数的get请求。","request": {"uri": "/api/moco/get/demo","method": "get"  # 这里添加了要给method属性},"response": {"text": "hello get request !"}}
]

2)、有参数的get请求

[{"description": "模拟一个没有参数的get请求。","request": {"uri": "/api/moco/get/demo","method": "get"},"response": {"text": "hello get request !"}},{"description": "模拟一个带参数的get请求。","request": {"uri": "/api/moco/get/param/demo","method": "get","queries": {      # get请求参数的选项,queries固定属性。"name": "xiaoming","age": "18"}},"response": {"text": "hello xiaoming !"}}
]

说明:请求地址为:http://127.0.0.1:12306/api/moco/get/param/demo?name=xiaoming&age=18

(3)Post方法的Mock实现

1)、没有参数的post请求

[{"description": "模拟一个不带数据的post请求。","request": {"uri": "/api/moco/post/demo","method": "post"    },"response": {"text": "hello post request !"}}
]

提示:POST请求就不能用浏览器进行查看了。只能用Request库或者JMeter,Postman等进行查看。(能进行接口调用的工具都可以)

# 1.导入requests库
import requests# 2.明确请求地址
url = "http://127.0.0.1:12306/api/moco/post/demo"# 3.发送请求
response = requests.post(url=url)
print(response.text)

2)、有参数的post请求

[{"description": "模拟一个带数据post请求。","request": {"uri": "/api/moco/post/param/demo","method": "post","forms": {      # post请求带参数,参数要添加到forms属性中。"name": "xiaoming","age": "18"}},"response": {"text": "hello post xiaoming !"}}
]

调用接口查看结果。

# 1.导入requests库
import requests# 2.明确请求地址
url = "http://127.0.0.1:12306/api/moco/post/param/demo"data = {"name": "xiaoming","age": "18"
}# 3.发送请求
response = requests.post(url=url, data=data)
print(response.text)
(4)请求中加入Cookies

使用的是request中的cookies属性。

1)、get请求

[{"description": "模拟一个带cookie的get请求。","request": {"uri": "/api/moco/get/cookies/demo","method": "get","cookies": {          # 这里添加cookies参数"login": "true"}},"response": {"text": "hello get cookies !"}}
]

调用接口查看结果。

# 1.导入requests库
import requests# 2.明确请求地址
url = "http://127.0.0.1:12306/api/moco/get/cookies/demo"cookies = {"login": "true"
}# 3.发送请求
response = requests.get(url=url, cookies=cookies)
print(response.text)

2)、post请求

[{"description": "模拟一个带cookie的post请求。","request": {"uri": "/api/moco/post/cookies/demo","method": "post","cookies": {"login": "true"},"json": {     # post请求的参数也可以用json格式的数据进行传输"name": "xiaoming","age": "18"}},"response": {"status": 201,"json": {"text": "hello post cookies !"}}}
]

调用接口查看结果。

# 1.导入requests库
import requests# 2.明确请求地址
url = "http://127.0.0.1:12306/api/moco/post/cookies/demo"cookies = {"login": "true"
}json = {"name": "xiaoming","age": "18"
}# 3.发送请求
response = requests.post(url=url, json=json ,cookies=cookies)
print(response.text)
(5)请求中加入Header

使用的是request中的headers属性。

Header是添加请求头信息,关于请求头信息get请求和post请求都是一样的。

[{"description": "模拟一个带Header的post请求。","request": {"uri": "/api/moco/post/headers/demo","method": "post","headers": {      # 添加请求头信息"content-type": "application/json"},"json": {"name": "xiaoming","age": "18"}},"response": {"status": 201,"json": {"text": "hello get Headers !"}}}
]

调用接口查看结果。

# 1.导入requests库
import requests# 2.明确请求地址
url = "http://127.0.0.1:12306/api/moco/post/headers/demo"headers = {"content-type": "application/json"
}json = {"name": "xiaoming","age": "18"
}# 3.发送请求
response = requests.post(url=url, json=json, headers=headers)
print(response.text)
(6)Moco模拟重定向

重定向使用的是和request同级的redirectTo属性。

[{"description": "重定向到百度","request": {"uri": "/api/moco/redirect/demo","method": "get"},"redirectTo": "http://www.baidu.com"},{"description": "重定向到自己的接口","request": {"uri": "/api/moco/redirect/new/demo","method": "get"},"redirectTo": "http://www.baidu.com","response": {"text": "hello redirectTo !"}}
]

使用浏览器进行测试就可以。

还有更多的使用方式请查看文档:https://github.com/dreamhead/moco/blob/master/moco-doc/apis.md

(7)综合练习
[{"description": "department by dep_id","request": {"uri": "/api/departments/","method": "get","queries": {"$dep_id_list": "T001"}},"response": {"json": {"count": 1,"next": null,"previous": null,"results": [{"dep_id": "T001","dep_name": "php学院","master_name": "老李","slogan": "啦啦啦啦"}]}}},{"description": "update department by dep_id","request": {"uri": "/api/departments/T03/","method": "put","json": {"data": [{"dep_id": "T03","dep_name": "C++","master_name": "C++-Master","slogan": "Here is Slogan"}]}},"response": {"status": 201,"json": {"dep_id": "T03","dep_name": "C++","master_name": "C++-Master","slogan": "Here is Slogan"}}}
]
(8)总结:

Json文件的配置属性说明:

像我们上面练习过的Json文件配置,所有的数据值是固定的,

如:descriptionrequestresponseredirectTo等这些都是固定的,不能修改,修改可能连Moco服务都启动不来。

还有request的属性值,如:urimethodcookiesheaders,也是必须这样写的。

还有GET请求传递参数用queries属性,POST请求传递参数用formsjson属性都可以。(PUT,DELETE请求同Post请求。)

Moco框架原理:

就是把所有接口的数据,包括发送请求的所有数据和返回结果的所有数据,以Json数据格式进行编写。

把这些数据放入Moco框架提供的HTTP或者HTTPS的服务上,就实现了接口数据的模拟。

在使用的时候,我们只要按照json文件中接口配置的信息进行请求即可,如果调用接口传递的数据和Json文件中接口编写要接收的数据不一致,则无法请求成功。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/238557.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

docker安装ES:7.8和Kibana:7.8

本文适用于centos7,快速入手练习es语法 前置:安装docker教程docker、docker-component安装-CSDN博客 1.安装es 9200为启动端口,9300为集群端口 docker pull elasticsearch:7.8.0mkdir -p /mydata/elasticsearch/pluginsmkdir -p /mydata/elasticsear…

python核心阶段(七)—— 包&模块以及虚拟环境

1.包&模块 概念解释 模块:为了使代码容易维护,可以将一组功能相关的代码写入一个单独的.py文件中,这 个.py文件就被称作一个模块 包: 包是指一个有层次的文件目录结构,它包含多个相关模块或子包; 它…

基于MybatisPlus批量高效插入百万条数据

引言 在JAVA程序开发中,对数据库进行大量数据插入是一个常见的操作,作为一个软件开发工程师,大批量的数据处理是日常工作,如何优化插入性能,提升数据处理效率是对大多数工程师的一个重要考验。本文将围绕逐条插入和批…

随时随地安心工作:迅软DSE保护您手机办公中的关键数据

互联网的快速发展让移动办公成为了日常工作中的一部分,同时企业数据加密的需求也已经不仅仅局限于内部终端,对于灵活的手机移动端也同样需要进行合法合规的数据安全管控。 迅软DSE数据防泄密系统提供移动端管理模块,支持Android、IOS移动客户…

BearPi Std 板从入门到放弃 - 引气入体篇(11)(SPI驱动 TFT LCD(ST7789))

简介 SPI 驱动 ST7789V2 进行字符显示, 并且使用中文库显示中文信息。主芯片: STM32L431RCT6LED : PC13 \ 推挽输出即可 \ 高电平点亮串口: Usart1 / LPUARTSPI(与LCD数据传输) : SPI2LCD_RESET(复位引脚): PC7 \ 推挽输出即可 LCD_POWER(…

通过几个基本概念说一下为什么openGauss是当下之选?

Database、Schema、User都是数据库的基本概念,SQL标准中也有明确规范。但不同数据库的具体实现也不尽相同,有些甚至大相径庭。这就导致用户在做国产化选型和数据库迁移时可能会遇到种种困难。本文从这几个基本概念展开,说说为什么openGauss系…

CHARLS CLHLS CFPS公共数据库, 最新文章|周报(12.6)

欢迎参加郑老师2023年孟德尔随机化课程即将开始 发表文章后退款!郑老师科研统计课程详情 CHARLS公共数据库 CHARLS数据库简介中国健康与养老追踪调查(China Health and Retirement LongitudinalStudy,CHARLS)是一项持续的纵向调查,旨在调查中…

Stable Diffusion Windows 部署简单认知

写在前面 偶然看到,简单了解博文为 SD 部署,以及简单使用,部署过程遇到问题解决理解不足小伙伴帮忙指正 对每个人而言,真正的职责只有一个:找到自我。然后在心中坚守其一生,全心全意,永不停息。…

pnpm :无法加载文件 D:\nodejs\node_global\pnpm.ps1,因为在此系统上禁止运行脚本

目录 一、问题描述 二、原因分析 三、解决问题 一、问题描述 pnpm : 无法加载文件 D:\learningsoftware\nodejs\node_global\pnpm.ps1,因为在此系统上禁止运行脚本。有关详细信息,请参阅 https:/go.microsoft.com/fwlink/?LinkID1351 70 中的 a…

大象机器人发布万元级水星Mercury人形机器人产品系列,联结未来,一触即达!

十四五机器人产业发展规划指出机器人的研发、制造、应用是衡量一个国家科技创新和高端制造业水平的重要标志。当前,机器人产业蓬勃发展,正极大改变着人类生产和生活方式,为经济社会发展注入强劲动能。 人形机器人作为机器人产业中重要的一环&…

Java异常类分类,所有子类的父类是什么

1.异常的层次机构: 所有异常的父类是Throwable,它有两个子类,分别是Error和Exception。 2.Error: 表示系统错误,通常不能处理和恢复。比如StackOverFlowError或者OutOfMemoryError,出了问题只能结束程序…

Grafana安装zabbix插件

文章目录 一、在线安装zabbix插件二、离线安装1.下载安装2.grafana配置zabbix数据源 一、在线安装zabbix插件 如果grafana服务器可以联网即可在线安装。 安装方法官网上有:官网链接联网安装比较慢。 二、离线安装 1.下载安装 官网下载链接 [rootnode1 src]# mo…

猫罐头哪个品牌好?五款性价比高的猫罐头推荐

很多新手养猫的姐妹们都会为选罐头感到焦虑!但是每种罐头都有优缺点,每只猫咪的胃口也都不同,只有适合自家猫的才是最好的。所以姐妹们在选罐头之前可以先做好功课,了解一下怎么选好的罐头。 作为家里有3只猫的铲屎官来说&#xf…

Text Intelligence - TextIn.com AI时代下的智能文档识别、处理、转换

本指南将介绍Text Intelligence,AI时代下的智能文档技术平台 Textin.com 关注TechLead,分享AI全维度知识。作者拥有10年互联网服务架构、AI产品研发经验、团队管理经验,同济本复旦硕,复旦机器人智能实验室成员,阿里云认…

Ubuntu 常用命令之 clear 命令用法介绍

📑Linux/Ubuntu 常用命令归类整理 clear命令在Ubuntu系统下用于清除终端屏幕的内容。这个命令没有任何参数,它的主要作用就是清理终端屏幕上的所有信息,使得屏幕看起来像是新打开的一样。 使用clear命令非常简单,只需要在终端中…

JavaScript读写15693 ICod2 卡源码

本示例使用设备 &#xff1a; https://item.taobao.com/item.htm?spma1z10.5-c-s.w4002-21818769070.11.23eb789efg450Y&id615391857885 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-t…

camera 客观校准 (1)——抓图

#灵感# 客观校准很多平台都有&#xff0c;无非是抓raw&#xff0c;导入到calibration tool 中&#xff0c;设置一些参数&#xff0c;导出相应的校准数据。抓raw的方法&#xff0c;也是大差不差。但有些地方细节容易忽略&#xff0c;所以罗列一下。 目录 blc: lsc: color: …

ELFK日志收集

文章目录 第一章:ELK日志收集系统介绍日志收集重要性ELK介绍EFK介绍ELFK介绍ES部署Kibana部署第二章:Logstach日志收集Logstash介绍Logstash安装Logstash Input输入插件Logstash Filter过滤插件Logstash Output输出插件Input fileFilter mutatesplit示例add_field示例remove_…

ATFX期市:安哥拉宣布退出OPEC,减产计划还能否彻底执行?

ATFX期市&#xff1a;昨日&#xff0c;安哥拉矿产资源、石油和天然气部长迪亚曼蒂诺阿泽维多在首都罗安达宣布&#xff0c;安哥拉决定退出OPEC&#xff0c;原因是此前OPEC第36次会议将安哥拉的产量配额设定为111万桶&#xff0c;不及安哥拉方面提出的118万桶。安哥拉的退出预计…

操作系统期末知识点总结

第一章 1、操作系统&#xff1a;OS是一个大型的系统软件、它负责计算机的全部软件和硬件资源的管理&#xff0c;并为用户提供良好的应用界面&#xff0c;使整个计算机系统实现高效率和高度自动化 2、操作系统的形成 1&#xff09;手工操作阶段 2&#xff09;批处理系统&…