JMeter+Ant+Jenkins实现接口自动化测试持续集成

简介: 本文介绍了如何使用Ant生成JMeter接口测试报告,并集成到Jenkins中实现自动化测试。内容涵盖Ant与JMeter环境配置、build.xml文件设置、测试执行及报告生成,同时包括Jenkins插件安装、项目配置和钉钉消息通知的集成,帮助实现持续测试与结果可视化。

Ant生成接口测试报告

下载ant

ant是jmeter的插件,官网地址:https://ant.apache.org/,下载指定版本如1.10.14支持Java1.8以上


1.官网下载后解压ant,然后把ant的bin目录配置到环境变量的path里,配置好后可以在电脑任意位置启动ant,配置过程中路径尽量不要出现中文。


配置build.xml文件

新增一个项目文件夹,把需要执行的jmx脚本复制到该文件夹,并在文件夹里新增配置ant的编译文件bulid.xml,里面涉及到文件路径的需要参考自己电脑的路径进行修改,否则运行会出现路径报错。


第8行需要改为自己电脑上JMeter所在目录

第11和13行需要改成结果输出目录,建议改为jmx脚本所在目录

第40行改为jmx脚本所在的目录,即和11,13行同一个目录 参考如下

第57行是汇总报告模板,默认JMeter自带,在extras目录下

第66行是详细报告模板,需要外部引用,下载好了之后放在extras目录下,后面第5步有说明。

<?xml version="1.0" encoding="UTF-8"?> <project name="ant-jmeter-test" default="run" basedir="."> <property environment="env"/> <tstamp> <format property="time" pattern="yyyy_MM_dd_hh_mm" /> </tstamp> <!--需要调用的jmeter目录,根据需要进行修改,本次使用的Windows路径--> <property name="jmeter.home" value="D:\Program Files\apache-jmeter-5.5" /> <property name="report.title" value="接口测试"/> <!-- jmeter生成jtl格式的结果报告的路径--> <property name="jmeter.result.jtl.dir" value="D:\Desktop\ant_demo\jtl" /> <!-- jmeter生成html格式的结果报告的路径--> <property name="jmeter.result.html.dir" value="D:\Desktop\ant_demo\html" /> <!-- 【详细报告】jmeter生成html格式的详细报告的路径--> <property name="jmeter.result.html.dir1" value="report" /> <!--生成的报告的前缀--> <property name="ReportName" value="接口测试汇总报告" /> <property name="ReportName1" value="接口测试详细报告" /> <property name="jmeter.result.jtlName" value="${jmeter.result.jtl.dir}/${ReportName}.jtl" /> <property name="jmeter.result.htmlName" value="${jmeter.result.html.dir}/${ReportName}.html" /> <!-- 【详细报告】详细报告的文件名--> <property name="jmeter.result.htmlName1" value="${jmeter.result.html.dir1}/${ReportName1}.html" /> <target name="run" > <!--antcall target-"delete" /--> <antcall target="test" /> <antcall target="report" /> </target> <!-- 该命令用来删除今天已经执行过的jtl,防止旧数据重叠 <target name = "delete"> <delete file="${jmeter.result.jtl.dir}/${ReportName}${env.BUILD_ID}.jtl"/> </target> --> <!-- 该命令为执行命令--> <target name="test"> <taskdef name="jmeter" classname="org.programmerplanet.ant.taskdefs.jmeter.JMeterTask" /> <jmeter jmeterhome="${jmeter.home}" resultlog="${jmeter.result.jtlName}"> <!-- 声明要运行的脚本路径"*.jmx"指包含此目录下的所有jmeter脚本--> <testplans dir="D:\Desktop\ant_demo" includes="*.jmx" /> <property name="jmeter.save.saveservice.output_format" value="xml"/> </jmeter> </target> <path id="xslt.classpath"> <fileset dir="${jmeter.home}/lib" includes="xalan*.jar"/> <fileset dir="${jmeter.home}/lib" includes="serializer*.jar"/> </path> <!--该命令为生成汇总和详细报告--> <target name="report"> <tstamp> <format property="report.datestamp" pattern="yyy/MM/dd HH:mm" /></tstamp> <xslt classpathref="xslt.classpath" force="true" in="${jmeter.result.jtlName}" out="${jmeter.result.htmlName}" style="${jmeter.home}/extras/jmeter-results-report_21.xsl"> <param name="dateReport" expression="${report.datestamp}"/> </xslt> <!--【详细报告】指定详细报告模板文件--> <xslt classpathref="xslt.classpath" force="true" in="${jmeter.result.jtlName}" out="${jmeter.result.htmlName1}" style="${jmeter.home}/extras/jmeter.results.shanhe.me.xsl"> <param name="dateReport" expression="$report.datestamp"/> </xslt> <!--因为上面生成报告的时候,不会将相关的图片也一起拷贝至日标目录,所以,需要手动拷贝--> <copy todir="${jmeter.result.html.dir}"> <fileset dir="${jmeter.home}/extras"> <include name="collapse.png" /> <include name="expand.png" /> </fileset> </copy> <!-- 【详细报告】拷贝图片到目标日录--> <copy todir="${jmeter.result.html.dir1}"> <fileset dir="${jmeter.home}/extras"> <include name="collapse.png" /> <include name="expand.png" /> </fileset> </copy> </target> </project>

3.配置jmeter的插件扩展,把Jmeter\extras目录下的ant-jmeter-1.1.1.jar拷贝到apache-ant-1.10.14\lib目录下


配置jmeter文件

4.配置jmeter的全局配置文件bin/jmeter.properties,打开注释修改以下三处。

#指定了JMeter保存测试结果的输出格式。将结果以XML格式保存可以使其更易于解析和处理。499行

jmeter.save.saveservice.output_format=xml

#当设置为 true 时,表示将响应数据包含在测试结果中。这意味着在保存测试结果时,会将每个请求的响应数据一并保存下来,以便后续分析和查看请求的具体响应内容。513行

jmeter.save.saveservice.response_data=true

#当设置为 true 时,表示将采样器数据也包含在测试结果中。这样做可以保存有关每个采样器执行的详细信息,

比如开始时间、结束时间等等。525行

jmeter.save.saveservice.samplerData=true

5.添加配置文件jmeter.results.shanhe.me.xsl到extras目录下,该文件为报告提供模板。


运行测试

6.执行ant查看报告生成结果

把jmx文件和bulid.xml放在同一目录下,打开cmd执行ant命令,运行成功后会生成html,jtl和report三个文件夹。



此处如果启动出现build38行报错,检查ant-jmeter-1.1.1.jar包拷贝的路径是否正确,配置的build的JMeter路径是否正确。


查看报告信息

在生成的report文件夹下可以查看接口测试详细报告



在生成的html文件夹下可以查看接口测试汇总报告



Ant与Jenkins的集成

启动电脑上的Jenkins服务,访问Jenkins,默认地址为ttp://127.0.0.1:8080/login


安装插件

需要准备插件

安装插件

HTML Publisher plugin

Ant Plugin


DingTalk


安装完毕插件后,重启一下Jenkins

添加钉钉机器人

钉钉群里添加机器人,复制Webhook和关键词


配置机器人



测试成功后会发送测试消息


添加构建项目

新建一个自由风格的项目

1.配置钉钉机器人


2.配置工作目录


3.添加构建步骤,执行ant


4.添加构建后的操作,设置两个报告

第一个报告


第二个报告


保存设置 执行构建


查看报告



控制台输出乱码问题,在系统里配置环境变量


键:JAVA_TOOL_OPTIONS 值:-Dfile.encoding=utf-8

键:LANG值:zh_CN.UTF-8



目录
相关文章
|
7天前
|
设计模式 前端开发 测试技术
告别脆弱:构建稳定UI自动化测试的3个核心策略
告别脆弱:构建稳定UI自动化测试的3个核心策略
164 113
|
2月前
|
存储 关系型数据库 测试技术
玩转n8n测试自动化:核心节点详解与测试实战指南
n8n中节点是自动化测试的核心,涵盖触发器、数据操作、逻辑控制和工具节点。通过组合节点,测试工程师可构建高效、智能的测试流程,提升测试自动化能力。
|
2月前
|
机器学习/深度学习 人工智能 测试技术
EdgeMark:嵌入式人工智能工具的自动化与基准测试系统——论文阅读
EdgeMark是一个面向嵌入式AI的自动化部署与基准测试系统,支持TensorFlow Lite Micro、Edge Impulse等主流工具,通过模块化架构实现模型生成、优化、转换与部署全流程自动化,并提供跨平台性能对比,助力开发者在资源受限设备上高效选择与部署AI模型。
249 9
EdgeMark:嵌入式人工智能工具的自动化与基准测试系统——论文阅读
|
2月前
|
Java 测试技术 API
自动化测试工具集成及实践
自动化测试用例的覆盖度及关键点最佳实践、自动化测试工具、集成方法、自动化脚本编写等(兼容多语言(Java、Python、Go、C++、C#等)、多框架(Spring、React、Vue等))
95 6
|
2月前
|
jenkins Java 持续交付
使用 Jenkins 和 Spring Cloud 自动化微服务部署
随着单体应用逐渐被微服务架构取代,企业对快速发布、可扩展性和高可用性的需求日益增长。Jenkins 作为领先的持续集成与部署工具,结合 Spring Cloud 提供的云原生解决方案,能够有效简化微服务的开发、测试与部署流程。本文介绍了如何通过 Jenkins 实现微服务的自动化构建与部署,并结合 Spring Cloud 的配置管理、服务发现等功能,打造高效、稳定的微服务交付流程。
288 0
使用 Jenkins 和 Spring Cloud 自动化微服务部署
|
2月前
|
自然语言处理 前端开发 测试技术
使用 Playwright MCP 实现 UI 自动化测试
本文介绍如何结合Playwright与MCP协议实现智能化UI自动化测试。通过自然语言指令控制浏览器,降低技术门槛,提升效率,并涵盖环境搭建、核心功能、实战案例及最佳实践,展现对话式自动化的未来趋势。
|
3月前
|
前端开发 Java jenkins
Jmeter压力测试工具全面教程和使用技巧。
JMeter是一个能够模拟高并发请求以检查应用程序各方面性能的工具,包括但不限于前端页面、后端服务及数据库系统。熟练使用JMeter不仅能够帮助发现性能瓶颈,还能在软件开发早期就预测系统在面对真实用户压力时的表现,确保软件质量和用户体验。在上述介绍的基础上,建议读者结合官方文档和社区最佳实践,持续深入学习和应用。
631 10
|
4月前
|
人工智能 前端开发 测试技术
如何让AI帮你做前端自动化测试?我们这样落地了
本文介绍了一个基于AI的UI自动化测试框架在专有云质量保障中的工程化实践。
1690 21
如何让AI帮你做前端自动化测试?我们这样落地了
|
4月前
|
Web App开发 开发框架 .NET
Playwright 自动化测试系列(6)| 第三阶段:测试框架集成​指南:参数化测试 + 多浏览器并行执行
Pytest 与 Playwright 集成可提升自动化测试效率,支持参数化测试、多浏览器并行执行及统一报告生成。通过数据驱动、Fixture 管理和并行优化,显著增强测试覆盖率与执行速度,适用于复杂 Web 应用测试场景。

热门文章

最新文章

推荐镜像

更多