接口自动化测试框架搭建详解

🍅点击文末小卡片,免费获取软件测试全套资料,资料在手,涨薪更快

一、原理及特点

  • 参数放在XML文件中进行管理
  • 用httpClient简单封装一个httpUtils工具类
  • 测试用例管理使用了testNg管理,使用了TestNG参数化测试,通过xml文件来执行case。
  • 测试报告这里用到第三方的包ReportNG 项目组织用Maven

二、准备

  • 使用工具:eclipse,maven
  • 用到的第三方jar包:dom4j、reportng、testng
  • 理解难点:httpUtils和xmlUtil工具类的封装;dom4j使用;CookieStore的应用

三、框架构思

1、项目结构

2、用例执行流程

3、接口调用流程

4、调度脚本流程

四、框架实现

1、输入参数

1.1 参数放在XML文件中进行管理

例:这里测试获取角色的接口输入参数为,page和rows,mapRole.xml内容如下

<?xml version="1.0" encoding="UTF-8"?> <map> <bean beanName="GetRole"> <!--Locator lists --> <locator name="page" value="1"></locator> <locator name="rows" value="10"></locator> </bean> </map>

1.2 封装一个xmlUtil工具类负责读取XML,使用第三方的jar包dom4j

1.2.1 xmlUtil中readXMLDocument方法返回值为HashMap<String, String>

public static HashMap<String, String> readXMLDocument(String beanName,String xmlName){ }

2、返回参数

2.1 创建一个接口返回对象ResponseBean

对象ResponseBean,包括status、statusCode、contentType、body、url、method、cookies

2.2 在工具类中在创建一个ReponseUtil工具类

ReponseUtil工具类负责将请求的返回数据CloseableHttpResponse 转换成ResponseBean

public ResponseBean setResponseBean(CloseableHttpResponse httpResponse) { }

3、测试用例

测试用例管理使用了TestNG管理 ,使用了TestNG参数化测试,通过xml文件来执行case

3.1 测试case脚本

public class GetRoleTest { static CookieStore cookieStore ; static CookieUtil cookieUtil=new CookieUtil() ; CloseableHttpClient client; HttpUtils httpUtils=HttpUtils.getInstance(); @Parameters({ "url", "objBean" ,"statusCode","xmlName"}) @BeforeSuite /* * 登录进入系统获取JSESSIONID放入到CookieStore中 * */ public void TestLoginIn(String url ,String objBean, String statusCode,String xmlName) { Map<String,String> params=xmlUtil.readXMLDocument(objBean,xmlName); client = HttpClients.createDefault(); CloseableHttpResponse httpResponse= httpUtils.post(url, params, client, cookieStore); //cookieUtil.printResponse(httpResponse); cookieStore=cookieUtil.setCookieStore(httpResponse); } @Parameters({ "url", "objBean" ,"statusCode","body","xmlName"}) @Test(priority = 2) public void TestGetRole(String url ,String objBean, String statusCode,String body,String xmlName) { Map<String,String> params=xmlUtil.readXMLDocument(objBean,xmlName); client = HttpClients.custom().setDefaultCookieStore(cookieStore).build(); CloseableHttpResponse httpResponse= httpUtils.post(url, params, client, cookieStore); ResponseBean rb=new ReponseUtil().setResponseBean(httpResponse); // add Assert Assert.assertEquals("OK", rb.getStatus()); Assert.assertEquals(statusCode, rb.getStatusCode()); Assert.assertEquals(true, rb.getBody().contains(body)); } @AfterSuite public void closeClient(){ try { // 关闭流并释放资源 client.close(); } catch (IOException e) { e.printStackTrace(); } } }

[注] 因为API接口测试时每次都要校验Cookie,所有我们每次都先执行登录操作去获取Cookie

3.2 xml文件的编写

<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd"> <suite name="TestGetRole" parallel="classes" thread-count="5"> <parameter name="url" value="/sys/login" /> <parameter name="objBean" value="loginIn" /> <parameter name="status" value="OK" /> <parameter name="statusCode" value="200" /> <parameter name="xmlName" value="mapRole" /> <test name="TestGetRole" preserve-order="true"> <parameter name="url" value="/json/getRoleInfo" /> <parameter name="objBean" value="GetRole" /> <parameter name="status" value="OK" /> <parameter name="statusCode" value="200" /> <parameter name="body" value="roleName" /> <classes> <class name="com.lc.testScript.GetRoleTest"> <methods> <include name="TestGetRole" /> <!--<include name="TestGetRole2" />--> </methods> </class> </classes> </test> </suite>

右键->run as ->TestNG Suite,这个场景的的测试用例就可以运行了

4、测试报告和项目组织

测试报告这里用到第三方的包ReportNG 项目组织用Maven

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> .......................................... .......................................... .......................................... <properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <xmlFileName1>TestGetRole.xml</xmlFileName> .................这里写testNG对应的XML名称---------------------- <xmlFileName10>TestGetUser.xml</xmlFileName> </properties> <dependencies> .......................... </dependencies> <build> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-surefire-plugin</artifactId> <version>2.19</version> <configuration> <suiteXmlFiles> <suiteXmlFile>src/test/java/testSuites/${xmlFileName}</suiteXmlFile> .................略............ ..............这里的和properties中的xmlFileName想对应............ <suiteXmlFile>src/test/java/testSuites/${xmlFileName10}</suiteXmlFile> </suiteXmlFiles> </configuration> </plugin> <!-- 添加插件,添加ReportNg的监听器,修改最后的TestNg的报告 --> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-surefire-plugin</artifactId> <version>2.5</version> <configuration> <properties> <property> <name>usedefaultlisteners</name> <value>false</value> </property> <property> <name>listener</name> <value>org.uncommons.reportng.HTMLReporter</value> </property> </properties> <workingDirectory>target/</workingDirectory> </configuration> </plugin> <plugin> <artifactId>maven-compiler-plugin</artifactId> <version>3.5.1</version> <configuration> <source>1.8</source> <target>1.8</target> </configuration> </plugin> </plugins> </build> </project>

[注] 因为是maven的项目所以要将testSuite的xml文件放在maven的test目录下,这样右键pom.xml文件maven test,所有的测试用例就开始执行了

测试报告

框架目前存在的不足。

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

这些资料,对于做【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!凡事要趁早,特别是技术行业,一定要提升技术功底。

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

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

相关文章

揭秘VSCode中动态网页审查:90%开发者忽略的关键功能

第一章&#xff1a;VSCode中动态网页审查的认知重构在现代前端开发中&#xff0c;VSCode 已不仅是代码编辑器&#xff0c;更逐渐演变为集调试、审查与实时反馈于一体的集成开发环境。传统的网页审查多依赖浏览器开发者工具&#xff0c;但随着 Live Server、Debugger for Chrome…

城通网盘直连地址获取技术深度解析

城通网盘直连地址获取技术深度解析 【免费下载链接】ctfileGet 获取城通网盘一次性直连地址 项目地址: https://gitcode.com/gh_mirrors/ct/ctfileGet 在数字资源分享领域&#xff0c;城通网盘作为国内知名的文件存储与分享平台&#xff0c;其下载体验一直备受关注。本文…

老旧Mac系统兼容性升级完整指南:从发现问题到完美运行

老旧Mac系统兼容性升级完整指南&#xff1a;从发现问题到完美运行 【免费下载链接】OpenCore-Legacy-Patcher 体验与之前一样的macOS 项目地址: https://gitcode.com/GitHub_Trending/op/OpenCore-Legacy-Patcher 您是否正在为老旧Mac无法升级到最新macOS而苦恼&#xf…

16.仿函数

1.function-like classes,所谓仿函数 一个对象能够像函数一样被调用,关键就是重载(重定义)operator()。 比如: template struct identity { const T& operator()(const T& x) const { return x; } }; 使…

Steam创意工坊模组下载新方案:WorkshopDL深度解析

Steam创意工坊模组下载新方案&#xff1a;WorkshopDL深度解析 【免费下载链接】WorkshopDL WorkshopDL - The Best Steam Workshop Downloader 项目地址: https://gitcode.com/gh_mirrors/wo/WorkshopDL 在游戏模组生态系统中&#xff0c;Steam创意工坊以其庞大的资源库…

Chrome浏览器网页完整截图终极解决方案

Chrome浏览器网页完整截图终极解决方案 【免费下载链接】full-page-screen-capture-chrome-extension One-click full page screen captures in Google Chrome 项目地址: https://gitcode.com/gh_mirrors/fu/full-page-screen-capture-chrome-extension 在日常浏览网页时…

区块链交易模拟:VibeThinker生成简易智能合约逻辑

区块链交易模拟&#xff1a;VibeThinker生成简易智能合约逻辑 在去中心化应用开发日益复杂的今天&#xff0c;一个微小的逻辑漏洞就可能导致数百万美元的资产损失。智能合约&#xff0c;作为区块链世界中的“自动执行协议”&#xff0c;其编写过程要求极高的精确性与严密性——…

揭秘VSCode 1.107多智能体配置:3步实现团队智能协同开发

第一章&#xff1a;揭秘VSCode 1.107多智能体配置的核心机制VSCode 1.107 引入了多智能体协同架构&#xff0c;标志着编辑器从单实例模式向分布式智能服务演进。该机制通过独立运行的多个语言智能体&#xff08;Agent&#xff09;实现并行语法分析、代码补全与错误诊断&#xf…

VS:Ctrl+K

在Visual Studio中&#xff0c;CtrlK 是一个‌组合键前缀‌&#xff0c;按下后需再按一个键来执行特定命令。以下是常见用法&#xff1a;‌代码片段操作‌&#xff1a;CtrlK, CtrlX&#xff1a;插入代码片段。CtrlK, X&#xff1a;同上&#xff0c;部分版本简写。‌注释控制‌&…

如何快速掌握MCEdit 2.0:新手玩家的终极地图编辑指南

如何快速掌握MCEdit 2.0&#xff1a;新手玩家的终极地图编辑指南 【免费下载链接】mcedit2 MCEdit 2.0 - World Editor for Minecraft. 项目地址: https://gitcode.com/gh_mirrors/mc/mcedit2 你是否曾经在《我的世界》中耗费数小时手动搭建建筑&#xff0c;却总是达不到…

Qt - QSplitter组件功能及用法

QSplitter 是 Qt 中的一个布局管理组件,主要用于创建可拖动的分隔条,让用户能够动态调整子控件的大小。在 Qt Designer(UI 设计界面)中,QSplitter 确实不会像按钮、标签那样直接出现在左侧的组件列表中。这是因为…

YuukiPS启动器:原神玩家的智能管家

YuukiPS启动器&#xff1a;原神玩家的智能管家 【免费下载链接】Launcher-PC 项目地址: https://gitcode.com/gh_mirrors/la/Launcher-PC 游戏启动的痛点与解决方案 每位原神玩家都曾经历过这样的困扰&#xff1a;多账号切换需要频繁退出登录&#xff0c;不同版本间的…

API网关设计模式:AI列举限流与鉴权实施方案

API网关设计模式&#xff1a;AI服务限流与鉴权的实战方案 在AI模型日益普及的今天&#xff0c;一个参数仅1.5B的小型语言模型——比如VibeThinker-1.5B-APP——已经能在手机端或边缘设备上流畅运行。这类“轻量级但可用”的推理引擎正被广泛部署于教育平台、内部工具和开发者沙…

Steam创意工坊模组下载难题的终极解决方案

Steam创意工坊模组下载难题的终极解决方案 【免费下载链接】WorkshopDL WorkshopDL - The Best Steam Workshop Downloader 项目地址: https://gitcode.com/gh_mirrors/wo/WorkshopDL 还在为无法访问Steam创意工坊的精彩模组而苦恼吗&#xff1f;WorkshopDL作为一款革命…

缓存穿透怎么办?AI提供Redis布隆过滤器解决方案

缓存穿透怎么办&#xff1f;AI提供Redis布隆过滤器解决方案 在高并发系统中&#xff0c;一个看似不起眼的边缘请求&#xff0c;可能成为压垮数据库的最后一根稻草。想象一下&#xff1a;攻击者不断用随机ID请求用户信息&#xff0c;这些ID在数据库中根本不存在。每次请求都绕过…

7.在程序中链接静态库

在cmake中,链接静态库的命令如下: link_libraries( [...]) 如果该静态库不是系统提供的(自己制作或者使用第三方提供的静态库)可能出现静态库找不到的情况,此时可以将静态库的路径也指定出来: link_directories(…

Server-Sent Events实现:VibeThinker构建实时通知系统

Server-Sent Events实现&#xff1a;VibeThinker构建实时通知系统 在如今的AI交互系统中&#xff0c;用户早已不再满足于“提问—等待—接收结果”这种黑箱式体验。尤其是在数学推理、编程解题这类需要逻辑展开的任务中&#xff0c;人们更希望看到模型“边想边说”的全过程——…

Mapshaper:地理数据处理的神器,零基础也能轻松上手

Mapshaper&#xff1a;地理数据处理的神器&#xff0c;零基础也能轻松上手 【免费下载链接】mapshaper Tools for editing Shapefile, GeoJSON, TopoJSON and CSV files 项目地址: https://gitcode.com/gh_mirrors/ma/mapshaper 还在为复杂的地理数据处理而烦恼吗&#…

Z-Image真实感生成实测:人像、产品图细节还原度惊人

Z-Image真实感生成实测&#xff1a;人像、产品图细节还原度惊人 在电商页面刷新率越来越高的今天&#xff0c;一张高质量的产品主图可能决定用户是否愿意多停留两秒&#xff1b;而在短视频和社交内容爆发的当下&#xff0c;创作者对“一键出图”的效率需求早已超越了单纯的画质…

3步精通YuukiPS启动器:原神多账号管理与网络优化终极方案

3步精通YuukiPS启动器&#xff1a;原神多账号管理与网络优化终极方案 【免费下载链接】Launcher-PC 项目地址: https://gitcode.com/gh_mirrors/la/Launcher-PC 还在为频繁切换原神账号而烦恼&#xff1f;网络延迟影响游戏体验&#xff1f;YuukiPS启动器作为专为原神玩…