基于BDD的接口自动化框架开箱即用

news/2024/5/6 9:24:05/文章来源:https://blog.csdn.net/wx17343624830/article/details/128105817

图片

1、背景说明

项目思想:BDD

行为驱动开发的思想褒贬不一,这里不多说。遵循的宗旨能解决业务痛点的思想就是好思想。

接口测试工具在实际的业务测试场景中往往会遇到一些使用上的局限性,自定义扩展要求技术较高,如果二次开发工具成本较大;

处于探索期的自动化团队,接口易于入手

接口测试用例后期的版本、维护、变更、存储遇到很多问题;

接口测试多人协同没有友好的支持;

接口测试用例没有统一的规范后期管理混乱、测试报告(业务场景接口)展示针对性、可读性差;

2、技术选型

cucumber 框架 官方链接 || GitHub链接

简介:Cucumber 是一个能够理解用普通语言 描述的测试用例的支持行为驱动开发(BDD)的自动化测试工具,用多种语言编写,支持Java、JavaScript、Ruby、.Net等多种开发语言。

rest-assured框架 官方链接 || GitHub链接

简介:REST-assured 用于方便 REST 服务测试的 JAVA DSL。

xeger正则表达式 GitHub链接

mock框架 GitHub链接

(微信不能外链接,以上可自行查找)

3、整体的框架思想

架构图谱
图片

单框架的了解

cucumber-环境配置

需要装俩idea插件用于自定义关键字自动提示和feature编写帮助

https://plugins.jetbrains.com/plugin/9164-gherkin/versions

https://plugins.jetbrains.com/plugin/7212-cucumber-for-java

或者直接在idea编译器内Settings->Plugins搜索:gherkin&&Cucumber for Java 安装即可

4、项目使用流程

idea创建一个maven项目使用自定义模板,配置如下:

GroupId=io.cucumber
ArtifactId=cucumber-archetype
Version=6.6.0
#踩坑,高版本结合其他框架使用遇到一些不适配的问题,目前使用6.6.0版本比较稳定

图片

自动生成cucumber项目模板

在这里插入图片描述

feature简单示例

Feature: rest-assured+cucumber测试实例Scenario: get请求示例场景Given 接口参数|params1|value1|params2|value2When 发起接口请求 "http://127.0.0.1:8091/api/test"Then 断言 "code"="1"

StepDefinitions类接收处理

 public String body;public Response response;@Given("接口参数")public void getubjectMajorstype(List<Map<String, String>> vegetables) {Map reqMap = vegetables.get(0);this.body = reqMap.toString();System.out.println("subjectMajorstype = " + reqMap.toString());}@When("发起接口请求 {string}")public void sendReq(String url){System.out.println("真正调用接口"+url);RequestSpecification request = given().contentType(ContentType.JSON).body(body);this.response = request.get(url);String responseBody = this.response.getBody().asString();System.out.println("当前响应结果:"+responseBody);}@Then("断言 {string}={string}")public void assertRes(String aValue){if ( aValue.equals("0")){System.out.println("=======断言通过=========");}else {System.out.println("==========断言失败==========");}}

rest-assured和cucumber遵循规范:

given-when-then逻辑思想

rest-assured具体使用可以参考GitHub的示例

public Response post(Map<String, String> headers, String body, String url) { request = given().headers(headers).contentType(ContentType.JSON).body(body); response = request.post(url); 
}

框架核心实现与测试用例分离

  • 核心实现与测试用例分类
  • 只关注接口的测试用例和维护
  • 核心实现

核心实现基础是上面创建的cucumber模板maven项目,根据实际需求功能不断完善…

  • 测试用例pom文件引用核心实现,通过git管理测试用例版本

图片

接口用例编写的关键字说明

接口执行顺序说明

用例执行前逻辑控制:预加载数据、获取场景名、环境变量…

用例执行中逻辑控制:根据各自场景使用关键字控制…

用例执行后逻辑控制:收集测试用例结果,展示用例测试结果数据…

接口用例关键字控制说明:整体遵循given-when-then思想

given 来控制请求前:api、参数、mock、文件流等功能使用

when 来控制发送什么样的请求:支持restful风格请求-get/post/delete/put,以及对应mock的请求类型

then 来控制获取响应后的参数化、响应结果的断言、数据库断言等

自定义关键字说明

Param 支持 :application/x-www-form-urlencoded 和 form-data格式

Body支持:raw 的json格式

ParamsJsonX支持:是把Param写成json格式

JSONPATH_GET_MONGO:是rest-assured的jsonpath使用,用于取出当前响应结果的某一对象值,也支持参数化

常用写法
• 获取children的列表rest-assured的jsonpath取值写法Then JSONPATH_GET_MONGO|data[0].children|children|
• 获取children第二条记录rest-assured的jsonpath取值写法Then JSONPATH_GET_MONGO|data[0].children[1]|children|
• 获取children第二条记录的yearId值rest-assured的jsonpath取值写法Then JSONPATH_GET_MONGO|data[0].children[1].yearId|yearId|
• 获取children所有的yearId值(列表)rest-assured的jsonpath取值写法Then JSONPATH_GET_MONGO|data[0].children.yearId|yearId|
• 获取特定的yearId值rest-assured的jsonpath取值写法【目前公司用的,支持该写法】Then JSONPATH_GET_MONGO| data[0].children.findAll{ children -> children.year == "2020"}.yearId[0] | yearId_2020 |
• 标准版的jsonpath取值【rest-assured的json-path不支持这种写法】Then JSONPATH_GET_MONGO| data[0].children[?@.year == "2020"}.yearId | yearId_2020 |

JSONPATH_ASSERT_EQUALS:是rest-assured的jsonpath使用,用于断言参数化当前响应结果与期望结果是否相等

INIT_MOCK:开启mock,mock读取顺着当前用例执行结束而结束

CONTENT_TYPE_IN_MULTIPART:开启文件上传支持

#采坑:目前rest-assured底层只支持一个文件的上传,不支持多个文件同时上传

FILECONTENT_ASSERT_CONTAINS:文本内容断言

ASSERT_MYSQL_SQL:SQL断言

todo。。。自定义扩展

接口用例编写实战分享

1.前置条件:

以企业微信为示例演示接口用例编写流程

企业微信测试地址:https://work.weixin.qq.com/

企业微信错误查询工具:https://open.work.weixin.qq.com/devtool/query?e=50001

配置idea编译器服务端地址

在这里插入图片描述

2.feature项目目录结构(和核心实现分离,只看到接口用例):

在这里插入图片描述

3.测试流程步骤

简单的测试操作流程:获取鉴权token->新增部门成员->编辑新增成员名称->删除被编辑名称的成员操作流程

#初始化变量池
@test
Feature: 初始化数据Scenario:  初始化变量数据Given INIT_MOCKGiven INI_VAR_DATA"""name: 测试名_Random(Char[4])mobile: 152Random(Long[5])5317email: testerRandom(Char[4])@qq.comwxName: zyRandom(Char[2])alias: alias_Random(Char[4])userid: userid_testRandom(Char[4])editUserid: 修改名称操作_Random(Char[2])"""# 1.获取access_tokenScenario: 获取access_tokenGiven API "/cgi-bin/gettoken"And Param"""corpid : ww27d6f876d80ceec6corpsecret: yiXycY2QFDwD9HysYNk6hF7NFnt1CxBybuei1YKVaVw"""When GETThen STATUS "200"Then JSONPATH_GET_MONGO|access_token|getToken|Then JSONPATH_ASSERT_EQUALS| errmsg   | ok |# 2.新增企业微信成员Scenario: wx_新增人员接口Given API "/cgi-bin/user/create?access_token=${getToken}"And Body"""{"userid": "test_user","name": "test_name","position": "测试工程师","alias": "背锅侠","mobile": "15238380000","email":"76556@qq.com","department": [3],}"""When POSTThen STATUS "200"
#    jsonpath断言使用Then JSONPATH_ASSERT_EQUALS| errcode  | 0      |# 3.断言新增人员是否成功      
Scenario Outline: wx_读取人员接口Given API "/cgi-bin/user/get"And Param"""access_token: ${getToken}userid: ${userid}"""When GETThen STATUS "200"Then JSONPATH_ASSERT "<jsonPath>" equals "<value>"Examples:| jsonPath | value  || errmsg   | ok |# 4.编辑新增成员_修改nameScenario: 编辑新增企业微信成员操作Given API "/cgi-bin/user/update?access_token=${getToken}"And Body"""{"userid": "test_user","name": "test_name_edit","department": [3],"order": [10],"position": "测试工程师","mobile": "15238305311","gender": "1","email": "zhangsn@gdev.com"}"""When POSTThen STATUS "200"Then JSONPATH_ASSERT_EQUALS| errcode  | 0      || errmsg   |updated |# 5. 删除微信成员操作Scenario: 删除新增企业微信成员操作Given API "/cgi-bin/user/delete?access_token=${getToken}"#urlencoded格式也可以在Param里写成yaml格式,也可以在url拼接使用And Param"""userid: test_user"""When GETThen STATUS "200"Then JSONPATH_ASSERT_EQUALS| errcode  | 0      |

通过上面的用例可以看出,需要什么功能只需要引入实现的关键字即可

用例的优化动态参数化和用例可持续执行

目前框架已实现功能

mock数据支持

restful风格接口支持

文件上传支持

jsonPath参数化变量引用支持

CSV文件参数数据引用

断言参数化变量引用支持

数据库断言支持

响应URL链接断言支持

随机函数支持

String 、Char、Long 、Boolean 的数据类型随机生成

各自日期类型和身份证等数据的随机生成

// 生成当前时间
Random(Date[yyyy-MM-dd hh:mm:ss])
// 当前事件为模板指定个别值
Random(Date[2020-MM-dd hh:mm:ss])
Random(Date[yyyy-03-12 08:mm:ss])
// 只生成年月日
Random(Date[yyyy-12-dd])
// 随机生日的身份证号
Random(IDCard)
// 指定生日的身份证号
Random(IDCard[20210312])

4、项目的核心思想

框架的核心实现思想

底层实现思路分析
图片

jenkins集成cucumber报告展示

冒烟测试报告…

1.报告汇总:

图片

2.错误信息展示

图片

3.配置坑:Cucumber reports 报告展示坑,由于配置了mock的config.json数据导致可能识别json文件有点问题,需要指定cucumber.json名即可结果

图片

写在最后附上项目源码地址:

https://github.com/CuiZhongyuan/cucumber-weixin-api-test

由于涉及公司项目核心jar包未开源,公众号后台回复cucumber即可获取打包后依赖jar包,放置maven依赖包com相应路径下即可:

<dependency><groupId>com.weixin.api</groupId><artifactId>cuke</artifactId><version>jxc_2.2.2</version><scope>test</scope>
</dependency>

如果你不想一个人野蛮生长,找不到系统的资料,问题得不到帮助,坚持几天便放弃的感受的话,可以加入我们的QQ群:746506216,大家可以一起讨论交流,里面会有各种软件测试资料和技术交流。


资源分享

下方这份完整的软件测试视频学习教程已经上## 标题传CSDN官方认证的二维码,朋友们如果需要可以自行免费领取 【保证100%免费】

在这里插入图片描述

在这里插入图片描述

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

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

相关文章

小程序瀑布流实现

什么是瀑布流布局 瀑布流布局&#xff0c;一般等宽&#xff0c;不等高的列表排列 原理是找出高度之和最小的那一列&#xff0c;在高度最小列继续添加元素 可以通过 absolute 定位实现&#xff0c;动态计算每一项的 top 和 left 封装瀑布流方法 function getAllRect(context…

[附源码]Python计算机毕业设计Django的疫苗接种管理系统

项目运行 环境配置&#xff1a; Pychram社区版 python3.7.7 Mysql5.7 HBuilderXlist pipNavicat11Djangonodejs。 项目技术&#xff1a; django python Vue 等等组成&#xff0c;B/S模式 pychram管理等等。 环境需要 1.运行环境&#xff1a;最好是python3.7.7&#xff0c;…

c#、wpf开发中页面在win10下被缩放125%引起页面错乱的解决办法。

正常情况下,我们开发的页面页面应该是100%缩放的,这样程序在win7和win10下保持一致,但是win10里面会根据显示器的情况自动调整“缩放与布局”,这使得桌面程序有时候会发生页面错乱,怎么调整就是个问题。 如图:在“缩放与布局”100%显示如下: 而在 “缩放与布局”125%显…

基于AD Event日志检测LSASS凭证窃取攻击

01、简介 简单介绍一下&#xff0c;LSASS(本地安全机构子系统服务)在本地或域中登录Windows时&#xff0c;用户生成的各种凭证将会存储在LSASS进程的内存中&#xff0c;以便用户不必每次访问系统时重新登录。 攻击者在获得起始攻击点后&#xff0c;需要获取目标主机上的相关凭证…

小程序中的confirm-type设置键盘的确认按钮

详情&#xff1a; confirm-type是很多小程序组件中的一种设置&#xff0c;用于改变输入键盘右下角的确认按钮。比如说&#xff0c;正常情况下&#xff0c;键盘上的默认提示可能是完成&#xff0c;但是你可以通过confirm-type将其设置为发送&#xff0c;搜索等&#xff0c;在特…

搬砖日记:关于sync用不了的问题

自己封装了个输入框的组件&#xff0c;想要实现的输入框的值的修改可以实时修改到父组件的值 印象中看到过人家用.sync修饰符去实现这个功能&#xff0c;大抵是 //父组件 <searchInput :value.sync"value"></searchInput> //子组件 <input v-model&qu…

Redeis缓存查询基于元注解与AOP结合使用——不过时的优雅

Redeis缓存查询基于元注解与AOP结合使用 根据优化需要&#xff0c;数据查询的时候无法避免的使用Redis基于缓存查询&#xff0c;进而减少对于数据库的查询压力&#xff0c;对于过多的方法基于缓存存储&#xff0c;为提高代码的复用性&#xff0c;采用一种不过时的写法。 整体的…

一文详解,数据仓库、数据库、数据中台、数据湖的区别

数据时代&#xff0c;各行业的企业都已经开始通过数据库来沉淀数据&#xff0c;但是真的论起数据库、数据仓库、数据中台&#xff0c;还是新出现的数据湖&#xff0c;它们的概念和区别&#xff0c;可能知道的人就比较少了&#xff0c;今天我们详细来比较了解一下。 数据仓库是…

你的数据库到底应该如何存储密码?

最近接手公司一个之前的服务&#xff0c;竟然发现用户密码是明文存储在数据库中&#xff01; 说实话还是有点吃惊的&#xff0c;这可不兴学 CSDN 呀&#xff08;手动狗头&#xff09;&#xff0c;至少也得搞个 MD5 存一存吧。 不过 MD5 其实也没啥用&#xff0c;今天我们就来…

JVM之运行时数据区 PC、虚拟机栈、本地方法栈

JVM之运行时数据区 PC、虚拟机栈、本地方法栈PC寄存器线程回顾寄存器实践面试使用PC寄存器存储字节码指令地址有什么用&#xff1f;为什么使用PC寄存器记录当前线程的执行地址PC寄存器为什么会被设定为线程私有虚拟机栈虚拟机栈出现背景简介栈可能出现的异常栈中存储着什么运行…

电商新趋势:Starday拿下黑色星期五的制胜法宝是物流速度

国内电商“双十一”购物狂欢季活动已经闭幕&#xff0c;“双十二”又将袭来&#xff0c;但更多人却将眼光放在蓬勃发展的跨境电商行业中。当下跨境电商卖家们正在各大跨境电商服务平台的带领下全力备战&#xff0c;在“黑色星期五”期间推出各类大促活动&#xff0c;奋力冲刺20…

Unknown custom element: <el-image>无法使用该组件,升级element-ui版本后项目报错

需求背景&#xff1a; 项目中需要使用图片点击放大&#xff0c;想要使用<el-image>组件&#xff0c;引入后报了下面的错&#xff0c;需要升级element版本&#xff0c;element-ui版本过低&#xff0c;没有该组件。 过程&#xff1a; cnpm i element-ui2.14.1 --save-dev…

clickhouse远程访问Oracle 11g数据库(clickhouse-jdbc-bridge)

1、简介 clickhouse-jdbc-bridge&#xff1a;是clickhouse提供的一个jdbc组件&#xff0c;用于通过JDBC的方式远程访问其他数据库表。 2、安装 &#xff08;1&#xff09;下载源文件并打包获取clickhouse-jdbc-bridge-2.0.7-shaded.jar 在官网&#xff1a;https://github.c…

tictoc例子理解10-13

tictoc10-13tictoc 10 几个模块连接&#xff0c;发送消息直到模块3收到消息tictoc 11 新增信道定义tictoc 12 双向连接信息简化定义tictoc 10 几个模块连接&#xff0c;发送消息直到模块3收到消息 让我们用几个(n)’ tic’模块让它更有趣&#xff0c;并将每个模块连接到其他模…

ANR 触发、监控、分析 一网打尽

平时看博客或者学知识&#xff0c;学到的东西比较零散&#xff0c;没有独立的知识模块概念&#xff0c;而且学了之后很容易忘。于是我建立了一个自己的笔记仓库 (一个我长期维护的笔记仓库&#xff0c;感兴趣的可以点个star~你的star是我写作的巨大大大大的动力)&#xff0c;将…

大客车玻璃擦净器设计

目 录 摘 要 I ABSTRACT II 1 绪论 1 1.1选题背景及意义 1 1.2发展现状 2 1.3发展趋势 3 1.4研究主要内容 4 2 大客车玻璃擦净器总体方案设计 5 2.1 大客车玻璃擦净器设计思想 5 2.2功能分析 5 2.3工作原理分析 6 2.4功能分解 6 2.4.2传动系统 6 2.4.3真空吸盘 7 2.4.4 清洁刷 …

欢聚季报图解:营收5.87亿美元同比降10% 净利提升

雷递网 雷建平 11月29日欢聚集团(NASDAQ: YY)今日发布2022年第三季度财报。财报显示&#xff0c;欢聚集团2022年第三季度营收为5.867亿美元&#xff0c;较上年同期下降10%。欢聚集团2022年第三季度Bigo Live的平均移动MAU为3540万&#xff0c;较上年同期的3100万增长14.2%&…

转铁蛋白修饰的去氢骆驼蓬碱磁纳米脂质体TF-HM-MPS

转铁蛋白又名运铁蛋白&#xff08;Transferrin&#xff0c;TRF、Tf&#xff09;&#xff0c;负责运载由消化管吸收的铁和由红细胞降解释放的铁。以三价铁复合物&#xff08;Tf-Fe3&#xff09;的形式进入骨髓中&#xff0c;供成熟红细胞的生成。转铁蛋白主要存在于血浆中&#…

冒烟测试的7个好处,你是否经常用到它?

以下为作者观点&#xff1a; 冒烟测试(smoke testing)是在开发的早期阶段评估基本的软件组件&#xff0c;以检查它们是否 “着火”&#xff08;有问题&#xff09;&#xff0c;本文旨在介绍冒烟测试及其在程序开发过程中的作用。 什么是冒烟测试&#xff1f; 冒烟测试是在开…

企业日常公关如何抵御负面信息的入侵?

如今&#xff0c;互联网时代信息传播速度极快&#xff0c;这使得宣传工作效率倍增&#xff0c;也给企业舆情管理带来一定的挑战。舆情优化搞得好&#xff0c;企业宣传工作事半功倍&#xff0c;网络舆论走向负面的话&#xff0c;则对宣传工作非常不利&#xff0c;会导致推广效果…