jemeter+ant+jenkins测试集成框架

本文详细介绍如何通过Ant构建工具与JMeter性能测试工具集成,实现自动化测试与报告生成。步骤包括配置Ant与JMeter环境变量,修改配置文件,创建测试报告目录,以及通过Ant任务执行JMeter测试脚本并生成HTML报告。

一、安装配置ant
1、傻瓜式安装完ant后,配置环境变量ANT_HOME(ant安装路径下的bin路径)
2、将jmerter的extras下的ant-jmeter-1.1.1.jar文件复制到ant的lib目录下
3、检查ant是否安装好,cmd下输入ant
二、安装配置jmeter
1、安装jdk并配置环境变量
2、设置JMETER_HOME为jmeter安装路径
3、将jmeter安装路径lib目录下的serializer-2.7.2文件和xalan-2.7.2文件拷贝到ant安装路径下的lib目录下
三、
1、创建如下目录
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
其中html文件夹用来存放生成的测试报告,script文件夹用来存放Jmeter脚本文件
2、修改jmeter.properties文件

  将jmeter.save.saveservice.output_format=xml的#去掉

3、修改build文件

<?xml version="1.0" encoding="UTF-8"?>
<tstamp>
    <format property="time" pattern="yyyyMMddhhmm" />
</tstamp>
<!-- jmeter中extras路径 -->
<property name="basedirectory" value="D:\jmeter\apache-jmeter-5.2\extras" />
<!-- 需要改成自己本地的 Jmeter 目录-->
<property name="jmeter.home" value="D:\jmeter\apache-jmeter-5.2" />
<!-- jmeter生成jtl格式的结果报告的路径-->
<property name="jmeter.result.jtl.dir" value="D:\testsuite\report\jtl" />
<!-- jmeter生成html格式的结果报告的路径-->
<property name="jmeter.result.html.dir" value="D:\testsuite\report\html" />
<!-- Name of test (without .jmx) -->
<property name="test" value="ER_sales"/>
<!-- 生成的报告的前缀-->
<property name="ReportName" value="TestReport" />
<property name="jmeter.result.jtlName" value="${jmeter.result.jtl.dir}/${time}.jtl" />
<property name="jmeter.result.htmlName" value="${jmeter.result.html.dir}/${time}.html" />
<property name="jmeter.save.saveservice.output_format" value="xml"/>


<!-- 运行了两个标签中的内容-->
<target name="run">
    <!--测试脚本标签对应下面的jMeter脚本-->
    <antcall target="test" />
    <!--测试脚本标签对应下面的jMeter脚本后产生测试报告的-->
    <antcall target="report" />
</target>

<!--JMeter脚本执行,name属性值和上面name中标签下的<antcall target="test" /> target值对应-->
<target name="test">

<taskdef name="jmeter" classname="org.programmerplanet.ant.taskdefs.jmeter.JMeterTask" />
<jmeter jmeterhome="${jmeter.home}" resultlog="${jmeter.result.jtlName}">
         <!-- 声明要运行的脚本。"*.jmx"指包含此目录下的所有jmeter脚本-->
         <!-- 此处看到别人的includes="*.jmx"我没试过,只用系统自带的一个脚本Test.jmx脚本,式了下可以用-->
        <testplans dir="D:\testsuite\script" includes="IHG.jmx" />
    </jmeter>
</target>
<path id="xslt.classpath">
    <fileset dir="${jmeter.home}/lib" includes="xalan-2.7.2.jar"/>
    <fileset dir="${jmeter.home}/lib" includes="serializer-2.7.2.jar"/>
</path>

 <!--JMeter脚本执行,name属性值和上面name中标签下的<antcall target="report" /> target值对应-->
<target name="report">
    <tstamp> <format property="report.datestamp" pattern="yyyy/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-detail-report_21.xsl"><!--这里根据自己目录下测试报告模板修改-->
		  <!-- jmeter报告模板-->
          <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>
</target>
四、运行cmd,跳到该testsuite路径下,输入ant,即可运行并生成报告

五、Jenkins集成

<think>嗯,用户想知道如何集成JMeterAnt、Allure和Jenkins来进行自动化性能测试和生成报告的最佳实践。首先,我需要理清楚每个工具的作用和它们之间的协作流程。 首先,JMeter是用来执行性能测试的,用户需要编写测试脚本并运行。然后,Ant作为构建工具,可以自动化执行JMeter测试,并处理结果文件。接下来,Allure用于生成美观的测试报告,但JMeter默认生成的是.jtl或.xml格式的结果,可能需要转换才能被Allure识别。Jenkins则是持续集成工具,负责整个流程的自动化触发和调度。 接下来,我需要参考用户提供的引用内容。例如,引用[3]提到JMeter保存的结果文件格式需要设置为XML,这可能涉及到配置jmeter.properties文件。引用[2]和[5]提到了使用Ant构建脚本(build.xml)来运行JMeter测试并生成报告,引用[4]提到使用XSL样式表生成报告,但用户现在想用Allure,可能需要额外的步骤转换结果格式。 可能的步骤包括: 1. 配置JMeter以生成适合Allure的报告格式,可能需要插件或转换工具。 2. 编写Ant的build.xml文件,自动化执行JMeter测试,并将结果转换为Allure可识别的格式。 3. 集成Allure到Jenkins,配置Jenkins任务来触发Ant构建,并调用Allure生成报告。 4. 确保各工具之间的路径和配置正确,例如JMeter脚本路径、结果输出路径、Allure报告的生成路径等。 需要注意的是,Allure通常用于单元测试或接口测试,处理性能测试报告可能需要特定适配。可能需要查找是否有JMeter的Allure监听器或插件,或者通过中间步骤将JMeter的结果转换为Allure支持的格式(如JUnit格式)。 此外,引用[5]提到Jenkins中配置AntJMeter的步骤,可能需要参考这些步骤来设置Jenkins的构建任务。同时,确保所有依赖项如JMeterAnt的环境变量在Jenkins中正确配置。 最后,用户可能希望整个流程自动化,包括测试执行、结果处理和报告生成,所以需要验证每个步骤是否能在Jenkins中无缝衔接,并处理可能出现的错误或日志问题。</think>### 集成JMeterAnt、Allure与Jenkins的自动化性能测试实践 #### 一、环境配置与工具整合流程 1. **JMeter脚本编写与配置** - 创建性能测试脚本(.jmx文件),设置线程组、取样器等组件,确保测试逻辑正确[^5] - 修改`jmeter.properties`文件,设置输出格式为XML: ```properties jmeter.save.saveservice.output_format=xml[^3] ``` 2. **Ant构建自动化** - 在`build.xml`中定义JMeter执行任务: ```xml <target name="run-jmeter"> <jmeter jmeterhome="${jmeter.home}" testplan="${test.dir}/your_test.jmx" resultlog="${result.dir}/jmeter-results.xml"/> </target> ``` - 添加结果转换任务(需依赖`jmeter-results-report.xsl`样式文件[^4]) 3. **Allure报告集成** - 通过JMeter插件生成Allure兼容格式(需安装`jmeter-allure-plugin`) - 或使用Python脚本将JTL文件转换为Allure支持的JSON格式: ```python import pandas as pd df = pd.read_csv("results.jtl") df.to_json("allure-results/output.json") ``` 4. **Jenkins流水线配置** - 安装Allure插件和Ant插件 - 创建Pipeline脚本: ```groovy pipeline { agent any stages { stage('Checkout') { steps { git 'https://your-repo-url' }} stage('Run Test') { steps { bat 'ant run-jmeter' }} stage('Generate Report') { steps { allure includeProperties: false, jdk: '', results: [[path: 'allure-results']] }} } } ``` #### 二、目录结构示例 ``` ├── ant-jmeter/ │ ├── script/ │ │ ├── build.xml # Ant构建文件 │ │ └── test_scripts/ # JMeter脚本存放位置 │ └── result/ │ ├── html/ # JMeter原始报告[^2] │ ├── jtl/ # 测试结果文件[^1] │ └── allure-results/ # Allure报告数据 ``` #### 三、关键优化点 1. **参数化构建**:通过Jenkins参数设置线程数、持续时间等测试变量 2. **异常处理**:在Ant脚本中添加失败重试机制 3. **资源监控**:集成PerfMon插件收集服务器指标 4. **历史对比**:配置Allure历史趋势图功能 #### 四、验证流程 1. 本地执行`ant run-jmeter`验证脚本正确性 2. 检查`jtl/`目录是否生成结果文件 3. 验证Allure报告是否包含响应时间、错误率等核心指标 4. 触发Jenkins构建后查看控制台输出和报告可视化
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值