JmeterAnt构建自动化测试平台

 一、jmeter

jmeter下载地址为:http://jmeter.apache.org/download_jmeter.cgi

下载完成后,解压文件,

加压后,到biin目录下,点击jmeter.bat启动jmeter(如果是linux环境,给jmeter.sh可执行的权限,然后执行jmeter.sh就可以启动jmeter)

安装下载jdk配置环境变量

二、ant

点击进入ant官网,找到下载选项。

http://ant.apache.org/

设置环境变量:

window中设置ant环境变量:

ANT_HOME    D:/ apache-ant-1.9.0

path             D:/ apache-ant-1.9.0/bin(按照其他的教程设置的不对)

classpath      D:/apache-ant-1.9.0/lib

ant验证:win+R  --  cmd

输入如下命令:ant -version

如果出现如下内容,说明安装成功:

三、Jenkins安装

http://jenkins-ci.org下载

点击setup安装

在浏览器输入http://localhost:8080/进行访问

(默认端口是8080,如果端口被占用,修改Jenkins安装目录下的配置文件,Jenkins.xml中httpport=8080,修改为不占用的端口8081)

操作步骤:

1、录制jmeter脚本(此处省略N。。。)

2、将jmeter安装目录下的extras目录中的“ant-jmeter-1.1.1.jar”这个jar放到ant的(安装目录)\lib目录下(关键)

3、配置jmeter的build.xml配置文件(D:\apache-jmeter-3.1\extras\build.xml)

在JMETER目录下新建一个testcase目录,把要运行的脚本放在此目录下,把编辑的新的build文件放在此目录下;在F:\apache-ant-1.9.4\bin目录下也放build文件(反正不知道对不对,刚开始没放的时候死活报错。。。。。就这样吧)

build.xml文件如下

 1 <?xml version="1.0" encoding="UTF8"?>
 2 
 3 <project name="Jmeter-TestCase" default="run" basedir=".">
 4     <tstamp>
 5         <format property="time" pattern="yyyyMMddhhmm" />
 6      </tstamp>
 7 
 8      <!--jmeter目录路径-->
 9      <property name="jmeter.home" value="D:\apache-jmeter-3.1" />
10      <!--jmeter生成报告的路径,二种格式-->
11      <property name="jmeter.result.jtl.dir" value="D:\apache-jmeter-3.1\TestCase\jtl" />
12      <property name="jmeter.result.html.dir" value="D:\apache-jmeter-3.1\TestCase\html" />
13 
14      <!--生成jmeter报告的前缀和定义结果集的路径-->
15      <property name="ReportName" value="TestReport" />
16      <property name="jmeter.result.jtlName" value="${jmeter.result.jtl.dir}/${ReportName}${time}.jtl" />
17      <property name="jmeter.result.htmlName" value="${jmeter.result.html.dir}/${ReportName}${time}.html" />
18      
19     <target name="run">
20          <antcall target="test" />
21          <antcall target="report" />
22      </target>
23      
24      <!--测试脚本-->
25      <target name="test">
26          <taskdef name="jmeter" classname="org.programmerplanet.ant.taskdefs.jmeter.JMeterTask" />
27          <jmeter jmeterhome="${jmeter.home}" resultlog="${jmeter.result.jtlName}">
28          <!--声明要运行的脚本-->
29             <testplans dir="D:\apache-jmeter-3.1\TestCase" includes="*.jmx" />
30             <property name="jmeter.save.saveservice.output_format" value="xml"/>
31             <property name="jmeter.save.saveservice.assertion_results" value="all"/>
32             <property name="jmeter.save.saveservice.bytes" value="true"/>
33             <property name="file_format.testlog" value="${format}"/>
34             <property name="jmeter.save.saveservice.response_data.on_error" value="${funcMode}"/>
35          </jmeter>
36      </target>
37 
38          
39     
40      <target name="report">
41          <xslt in="${jmeter.result.jtlName}"
42               out="${jmeter.result.htmlName}"
43               style="${jmeter.home}/extras/jmeter-results-detail-report_21.xsl" />
44               <!-- 因为上面生成报告的时候,不会将相关的图片也一起拷贝至目标目录,所以,需要手动拷贝 -->
45          <copy todir="${jmeter.result.html.dir}">
46              <fileset dir="${jmeter.home}/extras">
47                  <include name="collapse.png" />
48                  <include name="expand.png" />
49              </fileset>
50         </copy>
51      </target>
52 
53  </project>

 

jmeter Ant xml 文件

  •   Ant关键元素

  Ant的构建是基于XML编写的,默认名称是build.xml

  project元素是ant构建文件的跟元素,ant构建文件至少包含一个project元素,每个project元素下,可包含多个target元素。

  (1)name属性

    用于指定project元素的名称

  (2)default属性

    用于指定project默认执行时所执行的target的名称

  (3)basedir属性

    用于指定jmeter的基路径的位置,该属性没有指定时,使用ant的构建文件的附目录作为基准目录

  • target元素

   是ant的基本执行单元,她可以包含一个或是多个具体的任务,多个target可以存在相互依赖关系。有    如下属性:

  (1)name属性

  (5)description属性

    是target功能的简单描述和说明

  • property属性

4、cd到进入jmeter的build目录下运行ant(我的是D:\apache-jmeter-3.1\TestCase)

 

生成的报告如下

 

5、 测试报告优化

  用jmeter自带的测试报告得到的测试报告信息并不是很全,这里参考网上的方法,做一个优化

  • 下载下载优化模板 jmeter-results-shanhe-me.xsl,拷贝到jmeter的extras目录中

        href="http://shanhe.me/download.php?file=jmeter.results.shanhe.me.xsl

  • 编辑D:\apache-jmeter-3.1\bin\jmeter.properties文件,设置需要输出的内容为true,并去掉前面的注释符号#,这里全部设置成true

  • 设置build文件的报告模板为优化后的模板jmeter-results-shanhe-me.xsl

 按前面的方式再次用ant构建测试,查看优化后的测试报告

 

6、部署到持续集成平台Jenkins

打开http://localhost:8080/

点击新建-输入项目名称-OK-在构建里面选择invoke_Ant-高级-输入jmeter的build文件的目录

 

 

 基本配置完成:

JOB主页,点击立即构建,执行测试,构建完成即可通过HTML_Report来查看测试结果

 

 继续构建基本完成,另外还 可以配置邮件插件来发送测试报告,设置构建时间来定时自动执行测试  (后续加上)

遇见的问题

1、运行ant的时候总是报错。如下提示java(tm) platform se binary 已停止工作

解决方式:

  • 重新配置jdk的环境变量
  • 我原先安装的是jdk8,还是报错,最后卸载重新安装了jdk7,问题就解决了!!!!!

2、在jenkins构建运行的时候报错:提示Java.exe不是内部程序说明的(其实我也不知道什么鬼啊,以为我成功了,结果卡在这里,各种百度,心酸。。。)

猜测应该是和jdk的环境变量有关系(不要问我怎么猜的。。。。我也不知道)

系统管理-系统设置-全局属性-Environment variables-添加jdk的环境变量

 

失败了这么多,最后才算是成功了

查看控制台的输出---这个和命令行ant run运行输出是一样哒。。。

3、记得安装报告的插件(在jenkines中安装报告的插件,还有其他的不想说了)

终于完成了。。。。。。。。。。

 

转载于:https://www.cnblogs.com/bell1991/p/7260846.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/369801.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

input复选框checkbox默认样式纯css修改

修改之前的样式 修改之后的样式 html <input type"checkbox" name"btn" id"btn1"><label for"btn1">按钮1</label> css input[type"checkbox"]{width:20px;height:20px;display: inline-block;text-al…

c++word书签_「职场必备」干货!WORD办公软件快捷键,小编整理拿走不谢

小编工作时的照片&#xff0c;不上镜CtrlShiftSpacebar创建不间断空格Ctrl -(连字符)创建不间断连字符CtrlB使字符变为粗体CtrlI使字符变为斜体CtrlU为字符添加下划线CtrlShift缩小字号CtrlShift>增大字号CtrlQ删除段落格式CtrlSpacebar删除字符格式CtrlC复制所选文本或对象…

前端学习---css基本知识

css基本知识 我们先看一个小例子&#xff1a; <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>Title</title> </head> <body><div style"background-color:#2459a2;height:…

mysql 从库_mysql数据库主从配置

在一篇文章《离线安装mysql数据库》,讲解了离线安装mysql数据库的过程&#xff0c;本文将讲解mysql数据库的主从配置方法。mysql数据库进行主从配置后&#xff0c;可以实现数据库的备份、同时应用也可以实现读写分离&#xff0c;提高应用的并发量。1、主从原理从《高性能mysql》…

前端学习---html基础知识

HTML基本知识 学习html首先我们先看看HTML本质&#xff1a; web框架本质 我们在学socket&#xff0c;我们创建一个socketserver&#xff0c;然后运行起来&#xff0c;有一个client客户端要连接socket服务端&#xff0c;连接上之后&#xff0c;如果两边都没有close&#xff0…

前端:css

一,css介绍 CSS&#xff08;Cascading Style Sheet&#xff0c;层叠样式表)定义如何显示HTML元素。 当浏览器读到一个样式表&#xff0c;它就会按照这个样式表来对文档进行格式化&#xff08;渲染&#xff09;。 二,CSS语法 1,每个CSS样式由两个组成部分&#xff1a;选择器…

爬虫框架:scrapy

阅读目录 一 背景知识二 同步、异步、回调机制三 高性能一 背景知识 爬虫的本质就是一个socket客户端与服务端的通信过程&#xff0c;如果我们有多个url待爬取&#xff0c;采用串行的方式执行&#xff0c;只能等待爬取一个结束后才能继续下一个&#xff0c;效率会非常低。 需要…

为Openshift + MongoDb应用程序编写验收测试

验收测试用于确定是否满足规范要求。 它应该在与生产环境尽可能相似的环境中运行。 因此&#xff0c;如果您的应用程序已部署到Openshift中&#xff0c;则您将需要一个与生产环境中使用的帐户平行的帐户&#xff0c;以运行测试。 在这篇文章中&#xff0c;我们将为部署到Opensh…

CSS 自适应布局

前言 本篇文章将介页面布局中的自适应布局&#xff0c;常见的自适应布局有以下2种&#xff1a;左列固定右列自适应、左右两列固定中间自适应。 1. 左列固定右列自适应布局方案 说明&#xff1a;左列固定右列自适应&#xff0c;也可以为右列固定左列自适应&#xff0c;常见于中…

mysql的表导出er关系图_使用Navicat生成ER关系图并导出的方法

平时管理数据库一般都是用cmd命令提示符&#xff0c;或是IDEA Intellij自带的Data source&#xff0c;使用Navicat比较少。这段时间&#xff0c;由于要对前后端交互的数据结构进行设计&#xff0c;直接写文档联系多表时有些困难&#xff0c;想着如果有关系图就直观很多。想到Na…

Scude导入MySQL_FM2017_FMF赛季更新和真实修正数据库[更新至9.9,超过89000个更新]

FM2017_FMF赛季更新和真实修正数据库[更新至9.9&#xff0c;超过89000个更新]FM2017_FMF赛季更新和真实修正数据库[更新至9.9&#xff0c;超过89000个更新](2)这是国外玩家制作的一款FM2017_FMF冬季更新和真实修正数据库&#xff0c;更新至9月9日&#xff0c;超过89000个更新内…

音视频和表单的详情

网页中的音视频 <audio> 和 <vedio> 标签属性&#xff1a;autoplay 自动播放 controls 控制播放 loop 循环播放 表单 HTML 表单用于收集用户输入。 标签<form> 标签属性 action 数据的路径 enctype 传输文件 enctype"multipart/form-data" method …

mysql otter 数据同步_MySQL数据同步之otter

一、otter介绍基于日志数据&#xff0c;用于MySQL或者ORACLE之间准实时同步数据。用途&#xff1a;mysql/oracle互相同步中间表/行记录同步二、原理及架构图otter整体模块manager (提供web页面进行同步管理)arbitrate (分布式调度&#xff0c;可跨IDC机房)node (同步过程setl)c…

ubuntu中获取文件名称并生成txt文件

简介&#xff1a; 在机器视觉学习过程中&#xff0c;通常会经常批量处理一些图片&#xff0c;在&#xff35;&#xff42;&#xff55;&#xff4e;&#xff54;&#xff55;下可以使用find命令&#xff0c;来实现将文件名全部读取出来&#xff0c;生成列表txt文件&#xff0c;…

HTMLCSS

HTML xml &#xff08;标签名&#xff09;可扩展标记语言 <Stu> </Stu> Html 超文本标记语言&#xff08;文本&#xff0c;图片&#xff0c;链接&#xff09; <> </> Internet网上编写页面&#xff08;H5版本&#xff1a;支持多种标签特性&…

java中i+=2什么意思_三分钟看懂Java中i++与++i的性能差别以及循环中如何使用

在Java中&#xff0c;自增是一种非常常见的操作&#xff0c;在自增中&#xff0c;有两种写法&#xff0c;一种是前缀自增(i)&#xff0c;一种是后缀自增(i)。这里主要简单介绍两种自增的差别。一、含义差别前缀自增和后缀自增是不同的。前缀自增(i)是从内存中加载i&#xff0c;…

动态规划:从新手到专家

作者&#xff1a;Hawstein出处&#xff1a;http://hawstein.com/posts/dp-novice-to-advanced.html前言 本文翻译自TopCoder上的一篇文章&#xff1a; Dynamic Programming: From novice to advanced &#xff0c;并非严格逐字逐句翻译&#xff0c;其中加入了自己的一些理解。水…

小程序 foreach_【第2106期】小程序依赖分析实践

前言这种可视化分析图还是很直观的&#xff0c;很有趣。今日早读文章由自然醒授权分享。正文从这开始~~用过 webpack 的同学肯定知道 webpack-bundle-analyzer &#xff0c;可以用来分析当前项目 js 文件的依赖关系。webpack-bundle-analyzer因为最近一直在做小程序业务&#x…

python----模块

collections---------------------------------------->扩展数据类型 re-------------------------------------------------->正则相关操作&#xff0c;正则 匹配字符串 time----------------------------------------------->时间相关 三种格式&#xff1a;时间戳&…

css渲染(二) 文本

一、文本样式 首行缩进  text-indent 首行缩进是将段落的第一行缩进&#xff0c;这是常用的文本格式化效果。一般地&#xff0c;中文写作时开头空两格。[注意]该属性可以为负值&#xff1b;应用于: 块级元素(包括block和inline-block)  <div><p style"text-in…