JMeter是一个软件,使负载测试或业绩为导向的业务(功能)测试不同的协议或技术。 Apache软件基金会的Stefano Mazzocchi JMeter的最初的开发。他写道:它主要对 Apache JServ

(现在称为如Apache Tomcat项目)的性能进行测试。Apache后来重新设计JMeter 增强的图形用户界面和添加功能测试能力。Jmeter最初使用到性能测试,后来经过修改,可以对软件的不
仅仅进行性能测试,还可以进行接口测试与功能,本文章在这里要详细介绍的就是,使用Jmeter测试一个产品的接口测试,并把Jmeter与ant,Jenkins结合起来,自动化的去执行,并且生成
给予html的测试报告。关于jmeter的其他详细信息,建议看官方的文档,解释的比较详细和权威。
    jmeter下载地址为:http://jmeter.apache.org/download_jmeter.cgi,也可以到本人的百度网盘下载,下载地址为:http://pan.baidu.com/s/1kVjgAxx,下载完成后,解压文件,
加压后,到biin目录下,点击jmeter.bat启动jmeter(如果是linux环境,给jmeter.sh可执行的权限,然后执行jmeter.sh就可以启动jmeter),见启动后的界面,见如下的截图:
这里已m.cyw.com为案例,测试网易邮箱登录,弹出的接口,见创建后的项目(这里重点介绍与ant,jenkins的整合,不详细介绍jmeter的使用方法),见创建后的项目计划截图:
 
下来来看m.cyw.com为案例,跳转到西安市的接口为:http://m.cyw.com/index.php?m=api&c=cookie&a=setcity,请求为post请求,具体见如下postman对该接口的请求截图:
见如上,该接口在postman中调用,返回的json字符串,完善jmeter,见完善后的jmeter截图以及附件:
在jmeter中,点击run,可以看到执行的结果,见截图:
依据结果中,可以看到执行的结果,是通过的,下来把jmeter与ant进行整合,实现自动化的执行,而不是每次执行,得打开jmeter的界面,点击run去执行,ant的下载地址为:
http://ant.apache.org/,下载后,在环境变量中配置ant,新建ANT_HOME,见截图:
然后在path环境变量中加入%ANT_HOME%\bin,配置完成后,打开cmd命令提示符,输入ant -v ,出现如下截图,说明ant环境配置OK,见截图:
 
想要实现jmeter使用ant去执行,需要做如下几个操作:
1、修改jmeter配置文件jmeter.properties,把jmeter.save.saveservice.output_format=csv修改为jmeter.save.saveservice.output_format=xml,并
不要注释,见截图:
2、在jmeter的extras目录下,把ant-jmeter-1.1.1.jar文件复制到ant的lib目录下,见截图;
3、在jmeter当前目录下创建TestCase文件夹,并把wap.jmx复制到TestCase目录下,见截图:
4、编写build.xml文件,ant执行时候,会使用到该文件,见build.xml文件的源码:
<?xml version="1.0" encoding="UTF8"?>

<project name="Jmeter-TestCase" default="run" basedir=".">
    <tstamp>
        <format property="time" pattern="yyyyMMddhhmm" />
     </tstamp>

     <!--jmeter的目录-->
     <property name="jmeter.home" value="D:\git\cyw\cyw_jmeter\apache-jmeter-2.12" />
     <property name="jmeter.result.jtl.dir" value="D:\git\cyw\cyw_jmeter\apache-jmeter-2.12\TestCaset\report\jtl" />
     <property name="jmeter.result.html.dir" value="Q:\tools\apache-jmeter\test\report\html" />
     <property name="ReportName" value="TestReport" />
     <property name="jmeter.result.jtlName" value="${jmeter.result.jtl.dir}/${ReportName}${time}.jtl" />
     <property name="jmeter.result.htmlName" value="${jmeter.result.html.dir}/${ReportName}${time}.html" />
     
    <target name="run">
         <antcall target="test" />
         <antcall target="report" />
     </target>
     
     <target name="test">
         <taskdef name="jmeter" classname="org.programmerplanet.ant.taskdefs.jmeter.JMeterTask" />
         <jmeter jmeterhome="${jmeter.home}" resultlog="${jmeter.result.jtlName}">
            <testplans dir="D:\git\cyw\cyw_jmeter\apache-jmeter-2.12\TestCase" includes="wap.jmx" />
             <property name="jmeter.save.saveservice.output_format" value="xml"/>
         </jmeter>
     </target>

    
     <target name="report">
         <xslt in="${jmeter.result.jtlName}"
              out="${jmeter.result.htmlName}"
                  <!--jmeter的xml模板-->
              style="${jmeter.home}/extras/jmeter-results-detail-report_21.xsl" />
         <copy todir="${jmeter.result.html.dir}">
             <fileset dir="${jmeter.home}/extras">
                 <include name="collapse.png" />
                 <include name="expand.png" />
             </fileset>
        </copy>
     </target>

</project>

5、到D:\git\cyw\cyw_jmeter\apache-jmeter-2.12\TestCase目录下,执行ant命令,就会执行接口测试用例,生成给予html的测试报告,见ant执行的命令:
 
从命令行中,可以看到执行已成功,到Report目录下,可以看到生成的html与jtl,到html目录下,可以看到html的报告,见截图:
打开html,可以看到详细的执行结果,见截图:
 
OK,已生成想要的结果报告,特别说明,apache-jmeter-2.12\extras目录下的xml文件可以自定义,你看到的html报告可能和我截图的不一致,不过,你也可以根据自己的爱好修改xml文件。
Jenkins是一个持续集成的工具,下载地址为:https://jenkins.io/index.html,下载后,把jenkins.war放到tomcat的webapps目录下,启动tomcat,在浏览器访问http://localhost:8080/jenkins
新创建工程,可以把jmeter,ant,jenkins结合起来,实现接口自动化或者性能测试的自动化测试平台,见jenmins截图:
在Jenkins点击立即构建,就可以执行了。
 
OK,基本就介绍到这,如有任何疑问,可扫描关注本人的微信公众平台,或者加入本人的qq群,一起讨论,共同进步,也可看本人写的百度阅读写的自动化测试电子书,地址:http://yuedu.baidu.com/ebook/3c0077aaa32d7375a41780bb

Jmeter&Ant构建自动化测试平台的更多相关文章

  1. Jenkins环境搭建(2)-搭建jmeter+ant+jenkins自动化测试环境

    一直想在持续集成方向学习并研究一番,近期正准备结合jmeter+ant+jenkins做自动化接口测试,在学习的同时,正好实践一番,毕竟实践才是真理. 在搭建jmeter+ant+jenkins环境有 ...

  2. Jmeter + Ant 构建接口自动化

    1.首先安装ANT,解压,建议放根目录. 对应安装包已上传 2.环境变量配置新建 ANT_HOMEANT_HOME:解压的路径path环境配置新增Path:%ANT_HOME%\binclasspat ...

  3. jenkins+jmeter+ant搭建接口测试平台

    接口测试的重点是检查数据的交换,传递和控制管理过程以及系统间的相互逻辑依赖关系. 接口测试的流程 项目启动后,测试人员要尽早拿到接口测试文档. 开始编写接口测试用例 将接口测试用例部署到持续集成的测试 ...

  4. Linux下搭建Jmeter+Ant+Jenkins自动化测试框架

    前言 在之前的文章中,我们学习了通过Ant调用Jmeter脚本生成HTML测试报告,但未实现自动执行脚本生成报告,同时生成的报告是在Linux下,查看报告很不方便.因此,我们将结合Jenkins来进一 ...

  5. Jenkins+maven+jmeter+eclipse搭建自动化测试平台

    一.准备工作 1.jmeter准备测试脚本 2.maven环境配置 3.eclipse创建maven项目 4.Jenkins集成项目 二.jmeter准备测试脚本 使用jmeter准备测试脚本(不管录 ...

  6. 基于jmeter+ant实现的接口自动化测试

    jmeter+ANT接口自动化测试框架 项目说明 本框架是一套基于jmeter+Ant+Excel+Python而设计的数据驱动接口自动化测试框架,jmeter 作为执行器,Ant 作为构建工具,进行 ...

  7. Jmeter+Ant+Jenkins构建接口自动化测试平台(Windows)

    一.首先先介绍下我的环境: 1. win10系统 2. ant版本:apache-ant-1.10.1(作用:执行脚本,便于后期的持续集成,下载地址:http://ant.apache.org/bin ...

  8. Jmeter+ant+jenkins接口自动化测试 平台搭建(一)

    平台简介 一个完整的接口自动化测试平台需要支持接口的自动执行,自动生成测试报告,以及持续集成.Jmeter 支持接口的测试,Ant 支持自动构建,而 Jenkins 支持持续集成,所以三者组合在一起可 ...

  9. Jenkins+Ant+Jmeter自动化测试平台

            持续集成 持续集成是一种软件开发实践,即团队开发成员经常集成他们的工作,通常每个成员每天至少集成一次,也就意味着每天可能会发生多次集成.每次集成都通过自动化的构建(包括编译,发布,自动 ...

随机推荐

  1. SpringCloud开发学习总结(五)—— 服务容错保护Hystrix

    在微服务架构中,我们将系统拆分成了很多服务单元,各单元的应用间通过服务注册与订阅的方式相互依赖.但由于每个单元都在不同的进程中运行,一来通过远程调用的方式执行,这样就有可能因为网络原因或是依赖服务自身 ...

  2. 树莓派 VNC 远程桌面 同一个桌面

    如何在ssh登录的情况下配置好vino 1.传输文件 2.ssh sudo dpkg -i ~/swap/deb/tight* sudo cp ~/swap/vino.desktop /etc/xdg ...

  3. [转]查询表达式 (F#)

    本文转自:http://msdn.microsoft.com/zh-cn/library/hh225374.aspx 查询表达式可以查询数据源并将数据是一种预期形式.             查询表达 ...

  4. Partial(部分方法,局部方法),virtual(虚方法),abstract(抽象方法)

    Partial 部分方法顾明思议是方法的一部分,不完整的,在ide编译时候,会将所有部分方法加载到一起统一编译,如果分部方法没有被实现,编译器就不会.对他们进行编译. 局部类型的限制 (1) 局部类型 ...

  5. vue 2.0 路由创建的详解过程

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  6. JS中的对象之原型

    对象 ECMAScript做为一个高度抽象的面向对象语言,是通过_对象_来交互的.即使ECMAScript里边也有_基本类型_,但是,当需要的时候,它们也会被转换成对象. 一个对象就是一个属性集合,并 ...

  7. 关于mapState和mapMutations和mapGetters 和mapActions辅助函数的用法及作用(三)-----mapGetters

    简单的理解: const getters = { newCount: function(state){ return state.count += 5; } } ------------------- ...

  8. jQuery 点击 星星评分

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  9. 解决vue项目eslint校验 Do not use 'new' for side effects 的两种方法

    import Vue from 'vue' import App from './App.vue' import router from './router' new Vue({ el: '#app' ...

  10. ztree 展开一级节点 | ztree只显示到二级目录

    // 默认展开一级节点var nodes = tree.getNodesByParam("level", 0);for (var i = 0; i < nodes.lengt ...