当前位置: 首页 > news >正文

5分钟教会你搭建接口自动化测试框架

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

一、原理及特点

  • 参数放在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.jsqmd.com/news/421017/

相关文章:

  • 拒绝花哨,回归本质:19 款主流与小众浏览器硬核性能横评 (2026版)
  • 2026年阿里云邮箱华东区域服务商有哪些?优选合作伙伴指南 - 品牌2025
  • 2026甘孜阿坝/成都地暖市场解析,三大服务商精准解决痛点 - 深度智识库
  • 揭秘2026江苏口碑好的三坐标培训职业学校口碑排行,SolidWorks培训/UG培训/电工培训,三坐标培训学校推荐榜单 - 品牌推荐师
  • 【轻量化交付宣言】:DevOps 的本质是工程化,而非工具化
  • 对标ProfiHub B5!耐达讯自动化Profibus六路集线器:国产替代的性能之选
  • 超越profiHub B5:耐达讯自动化Profibus六路集线器——更高兼容、更强防护的伺服驱动控制中枢
  • 2026年2月实木餐桌源头厂家,售后体系完善选购指南 - 品牌鉴赏师
  • 元气AI Bot到底能做什么呢?哪些Skills是值得用的?【深度体验】国产AI管家的真实能力到底如何?OpenClaw的完美平替来了! - PC修复电脑医生
  • 两栏布局的实现
  • 面向企业级 AI Agent 自动化智能体开发和应用平台原理与开发实践——基于 FastAPI + LangChain 与 LangGraph、Docker Sandbox 的完整开发指南
  • 国产替代不止于价格:耐达讯自动化Profibus六路集线器以技术实力对标进口profiHub B5
  • 基于三菱PLC音乐喷泉控制系统设计的音乐喷泉组态
  • 2026年上海阿里云企业邮箱服务商推荐:安全稳定高效办公首选合作方 - 品牌2025
  • 说说郑州口碑好的装修公司有哪些,派轩装饰值得推荐吗? - 工业设备
  • 2026年2月广州GEO优化公司推荐,数据驱动优化效果看得见 - 品牌鉴赏师
  • 2026年企业微信开通方式有哪些?官方最新版操作流程指南 - 品牌2025
  • 想买域名找中介靠谱吗?
  • 邮件系统日志的合规性与隐私保护技巧
  • PaperZZ:本科毕业论文「无痛通关」指南 ——2026 届毕业生的学术效率革命
  • 域名历史WHOIS查询:为什么重要?怎么查?一文讲清
  • 二级冷板生产厂哪家性价比高,雷雷金属价格贵不贵? - 工业品网
  • 芯片行业CAE仿真分析深度白皮书:核心难点、解决方法与实战技巧全解析
  • 2026年广州受欢迎的专利申请专业公司有哪些? - myqiye
  • python+flask企业单位职工考勤管理系统-vue pycharm django
  • 什么样的域名更容易被企业收购?
  • Python+flask小程序 springboot大学生心理健康服务系统的设计与实现_5tsd9a39-vue pycharm django
  • 聊聊讯灵AI,深圳地区可靠的品牌有哪些,怎么收费? - 工业设备
  • 上海智能装备工厂10个SolidWorks画图设计如何共享一台服务器算力和资源
  • xbbblbl