Jmeter+ant+Jenkins实现接口自动化平台及报告发送

Stella981
• 阅读 1051

项目中实现了比较方便的自动化体系,一直没时间总结一下,现抽空整理一番,废话不多说  内容如下:

一、环境准备

jmeter : 编写接口脚本,实现接口测试

**ant ** :静默执行jmeter脚本,并生成测试报告

jenkins  :集成接口测试到项目流程,实现定时运行及接口测试报告邮件发送

------以上准备工作可以百度自行安装,工具安装环境无依赖,把环境变量配置好即可。

二、jmeter脚本编写及运行

按照Jmeter要求编写规范的测试脚本,具体编写jmeter接口测试脚本,本篇不作细的介绍、

Jmeter+ant+Jenkins实现接口自动化平台及报告发送

jmeter运行分为两种方式:

1、GUI模式:在安装目录bin下面找到  jmeter.bat 双击运行

Jmeter+ant+Jenkins实现接口自动化平台及报告发送

2、非GUI命令行运行:

jmeter -n -t <testplan filename> -l <listener filename>
示例: jmeter -n -t testplan.jmx -l test.jtl

示例含义:则表示以命令行模式运行testplan.jmx文件,输出的日志文件为test.jtl

-h 帮助 -> 打印出有用的信息并退出

-n 非 GUI 模式 -> 在非 GUI 模式下运行 JMeter

-t 测试文件 -> 要运行的 JMeter 测试脚本文件

-l 日志文件 -> 记录结果的文件

-r 远程执行 -> 在Jmter.properties文件中指定的所有远程服务器

-H 代理主机 -> 设置 JMeter 使用的代理主机

-P 代理端口 -> 设置 JMeter 使用的代理主机的端口号

稍后ant集成jmeter会用到第二种非GUI命令运行方式

三、Ant安装及集成Jmeter

1、Ant介绍

Ant是一个功能强大的打包编译工具。我们使用他的目的是将JTL(xml)格式文件转化为html格式的文件

2、Ant结合Jmeter

a.将jmeter 所在 extras目录下 的 ant-jmeter-1.1.1.jar 文件 copy 到 ant 所在lib 目录下

Jmeter+ant+Jenkins实现接口自动化平台及报告发送

b.编写Ant的build.xml文件,包含运行及生成报告日志功能

<?xml version="1.0" encoding="GB2312"?>
<project name="JmeterTest" default="all" basedir=".">
    <tstamp>
            <format property="time" pattern="yyyy/MM/dd HH:mm" />
    </tstamp>
    
    <!--Jmeter主目录-->
    <property name="jmeter.home" value="E:\jmeter\apache-jmeter-3.3" />
   
        
    <!--存放Jmeter生成的报告文件的文件夹-->
    <property name="jmeter.result.dir" value="E:\jmeter\results" />
   
   <!--Jmeter文件名-->
    <property name="ReportName" value="TestReport" />
    
    <!--jtl文件-->
    <property name="jmeter.result.jtlName" value="${jmeter.result.dir}/${ReportName}.jtl" />
    <!--html报告文件-->
    <property name="jmeter.result.htmlName" value="${jmeter.result.dir}/${ReportName}.html" />
    
    
    <!--汇总标签-->
    <target name="all">
        <antcall target="clean" />
        <antcall target="test" />
        <antcall target="report" />
    </target>
    
    <!--每次清除Jmeter生成的结果目录-->
    <target name="clean">
         <delete includeemptydirs="true">
            <fileset dir="${jmeter.result.dir}" includes="**/*"/>
        </delete>
    </target>
    
    
    <!--运行Jmeter脚本文件-->
    <target name="test">
        <taskdef name="jmeter" classname="org.programmerplanet.ant.taskdefs.jmeter.JMeterTask" />
        <jmeter jmeterhome="${jmeter.home}" resultlog="${jmeter.result.jtlName}">
            <testplans dir="E:\jmeter\script" 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">
        <xslt classpathref="xslt.classpath" force="true" in="${jmeter.result.jtlName}" out="${jmeter.result.htmlName}" style="${jmeter.home}/extras/jmeter-results-detail-report_21.xsl" >
            <param name="dateReport" expression="${time}"/>
        </xslt>
            <!--复制报告所需图标-->
            <copy todir="${jmeter.result.dir}">
            <fileset dir="${jmeter.home}/extras">
                <include name="collapse.png" />
                <include name="expand.png" />
            </fileset>
        </copy>
    </target>
   
</project>

3、运行Ant编译Jmeter

在build.xml所在的目录下,运行ant即会执行

Jmeter+ant+Jenkins实现接口自动化平台及报告发送

执行完成后会在build.xml设置的报告目录下生成对应的报告及日志

Jmeter+ant+Jenkins实现接口自动化平台及报告发送

------此时使用Jmeter运行及生成html报告的功能已经完成,接下来就是将整个运行过程集成到Jenkins里面,实现自动运行并发送报告邮件

四、Jenkins集成使用

将jmeter脚本放到jenkins上面定期运行,并自动发送测试结果报告,这个是自动化流程中核心的一环,步骤如下:

1、安装jenkins

已与百度达成战略合作,可咨询百度

2、 新建2个job工程,第一个用来执行jmeter脚本、   第二个工程根据执行结果来判定测试报告的邮件及钉钉推送

Jmeter+ant+Jenkins实现接口自动化平台及报告发送

执行Jmeter脚本的job工程配置如下:

1)给项目命名

Jmeter+ant+Jenkins实现接口自动化平台及报告发送

2)从svn拉取jmeter脚本到jenkins的工作空间

(存在多个目录下的脚本,就要创建多个svn插件)

Jmeter+ant+Jenkins实现接口自动化平台及报告发送

3)设置定时触发策略   (每天早上6点、中午12点分别执行一次)

Jmeter+ant+Jenkins实现接口自动化平台及报告发送

4)从svn上down下来的脚本迁移路径及编译构建

  ------编译构建就是调用ant编译

Jmeter+ant+Jenkins实现接口自动化平台及报告发送

5)Jenkins中将运行结果图形展示    (主要是方便直接在jenkins上查看运行结果)

Jmeter+ant+Jenkins实现接口自动化平台及报告发送

结果如下 :   添加完后在对应job详情页面会多出一个 HtmlReport 插件

Jmeter+ant+Jenkins实现接口自动化平台及报告发送

点击插件,可以查看详细的执行结果(包含总运行请求数,失败数,成功率,失败详情)

Jmeter+ant+Jenkins实现接口自动化平台及报告发送

3、第二个工程用来判定此次运行的结果,然后是结果情况进行邮件或钉钉推送

1)构建触发器配置  (在Jmeter第一个工程之后自动执行第二个工程)

Jmeter+ant+Jenkins实现接口自动化平台及报告发送

2)构建    (读取此次运行结果情况,  敲黑板  这里是重点 !!!)

a. 打开报告

b.找到报告中运行失败用例的关键字“Failure Message”

c.如果这个关键字不存在,则证明本次运行情况通过,通过shell让本次结果正常返回控制台

如果存在,即向控制台抛出 exit 0  异常退出。    这样jenkins工程就能读取到此次构建成功与否

cd /d E:\jmeter\results
findstr /c:"Failure Message" TestReport.html
if %errorlevel% == 0 (exit 1) else (exit 0)

3)构建之后,添加钉钉通知和邮件通知

Jmeter+ant+Jenkins实现接口自动化平台及报告发送

钉钉通知就是用钉钉机器人的webhook

邮件通知就使用smtp的授权码   

(------这两点可以参照我其他的博文,都有详细介绍)

4)至此整个自动化流程完成,让我们查看一下钉钉通知消息和邮件通知的结果

钉钉通知结果如下:

Jmeter+ant+Jenkins实现接口自动化平台及报告发送

邮件通知结果如下:

Jmeter+ant+Jenkins实现接口自动化平台及报告发送

我们也可以把jmeter在jenkins中的运行放到项目部署之后,作冒烟测试使用 ,至此整个自动化流程完结,实施起来效率有了很大提升 ~~

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Easter79 Easter79
3年前
swap空间的增减方法
(1)增大swap空间去激活swap交换区:swapoff v /dev/vg00/lvswap扩展交换lv:lvextend L 10G /dev/vg00/lvswap重新生成swap交换区:mkswap /dev/vg00/lvswap激活新生成的交换区:swapon v /dev/vg00/lvswap
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
待兔 待兔
4个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Wesley13 Wesley13
3年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Wesley13 Wesley13
3年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Stella981 Stella981
3年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
10个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这