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

jmeter+ANT接口自动化测试框架

项目说明

  • 本框架是一套基于jmeter+Ant+Excel+Python而设计的数据驱动接口自动化测试框架,jmeter 作为执行器,Ant 作为构建工具,进行构建测试,本框架无需你使用代码编写用例,测试用例存储在csv中,在csv中可以进行接口用例编写,接口断言,用例运行控制

技术栈

  • jmeter
  • Ant
  • Python

环境部署

1、安装JDK

2、安装Jmeter

3、安装 ANT

  • 1、解压apache-ant-1.10.5-bin.zip到任意目录,比如 E:\apache-ant-1.10.5
  • 2、windows中配置ANT环境变量,如下为我的配置

ANT_HOME    E:\apache-ant-1.10.5
Path        E:\apache-ant-1.10.5\bin
CLASSPATH   E:\apache-ant-1.10.5\lib
  • 3、ANT安装验证
    验证安装结果,命令行输入ant -v ,出现版本信息则安装成功,如图

4、ANT与Jmeter集成

  • 1、配置库文件
    将jmeter\extras目录下的ant-jmeter-1.1.1.jar 文件拷贝到ant安装目录下的lib文件夹中,如图
  • 2、配置ANT与Jmeter的配置文件
    新建ant的编译文件,命名为 build.xml,其内容如下:

<?xml version="1.0" encoding="UTF-8"?>

<project name="ant-jmeter-test" default="run" basedir=".">
    <tstamp>
        <format property="time" pattern="yyyy_MM_dd_HH_mm" />
    </tstamp>
    <!-- 需要改成自己本地的 项目路径根 目录,即jmeter安装文件所在的目录-->
    <property name="project.home" value="..\" />
    <!-- 需要改成自己本地的 Jmeter 目录-->
    <property name="jmeter.home" value="${project.home}\apache-jmeter-3.2" />
    <!-- jmeter生成jtl格式的结果报告的路径-->
    <property name="jmeter.result.jtl.dir" value="${project.home}\report\jtl" />
    <!-- jmeter生成html格式的结果报告的路径-->
    <property name="jmeter.result.html.dir" value="${project.home}\report\html" />
    <!-- 生成的报告的前缀-->
    <property name="ReportName" value="TestReport" />
    <property name="jmeter.result.jtlName" value="${jmeter.result.jtl.dir}/${ReportName}_${time}.jtl" />
    <property name="jmeter.result.all_htmlName" value="${jmeter.result.html.dir}/All_Report/All${ReportName}_${time}.html" />
    <property name="jmeter.result.detail_htmlName" value="${jmeter.result.html.dir}/Detail_Report/Detail${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}">
             <!-- 声明要运行的目录和脚本。"*.jmx"指包含此目录下的所有jmeter脚本-->
            <testplans dir="${project.home}\jmeter_Code" 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="yyyy/MM/dd HH:mm" /></tstamp>
        <xslt
              classpathref="xslt.classpath"
              force="true"

              in="${jmeter.result.jtlName}"
              out="${jmeter.result.all_htmlName}"
              style="${jmeter.home}/extras/jmeter-results-detail-report_21.xsl" />  

        <xslt
              classpathref="xslt.classpath"
              force="true"

              in="${jmeter.result.jtlName}"
              out="${jmeter.result.detail_htmlName}"
              style="${jmeter.home}/extras/jmeter.results.shanhe.me.xsl" />     

        <!-- 因为上面生成报告的时候,不会将相关的图片也一起拷贝至目标目录,所以,需要手动拷贝 -->
        <copy todir="${jmeter.result.html.dir}/All_Report">
            <fileset dir="${jmeter.home}/extras">
                <include name="collapse.png" />
                <include name="expand.png" />
            </fileset>
        </copy>
    </target>    

</project>
  • 按实际情况修改build.xml文件,相关说明如下

  • 3、配置jmeter.properties
    • 配置jmeter报告输出格式为xml。在jmeter根目录下apache-jmeter-3.2\bin\jmeter.properties文件中修改 jmeter.save.saveservice.output_format=csvjmeter.save.saveservice.output_format=xml,并去掉前面的注释符号#,如图所示

框架代码与用例设计及相关说明

1、用例设计

  • 测试用例保存在csv文件中,如图所示

2、脚本代码说明

  • 测试计划中定义用户变量,以供后面的脚本使用,如图
  • 循环控制器设置永远循环,如图
  • 循环控制器下新增CSV Data Set ConFig控件,循环读取用例文件中的测试用例,如图
  • Allow quoted data?:是否允许带双引号的数据
  1. 此项实际是控制csv文件中的双引号是否为有效字符;
  2. 如果数据带有双引号且此项设置TRUE,则会自动去掉数据中的引号使能够正常读取数据,且即使引号之间的内容包含有分隔符时,仍作为一个整体而不进行分隔;
  3. 如果数据带有引号且此项设置为FALSE,则读取数据报错;
  4. 如果希望双引号字段中间再包含双引号,则需要加两个双引号来代表单个双引号。
  5. 比如此项设置为true时,"2,3"-->2,3;"4""5"-->4"5
  • Sharing mode:共享模式
  1. All threads:针对所有线程组的所有线程,每个线程取值不一样,依次取csv文件中的下一行。即不管是单个线程组还是多个线程组,每个线程都是依次取下一行。
  2. Current thread group:当前线程组。以线程组为单位,每个线程组内的线程都会从第1行开始取值并依次往下进行取值。
  3. Current thread:当前线程。每个线程都会从第1行开始取值并依次往下进行取值,在同一次循环中所有的线程取值一样。
  • 添加执行控制器,筛选测试用例执行,如下,可执行所有用例、可执行其中某部分用例、也可按用例的优先级执行测试用例。
  • 根据调用方法选择请求方式
    通过if选择器区分GET与POST方法的请求,配置http请求,如图
  • Post请求的配置方式 :post请求参数放在body data中
  • 响应结果配置如图
  • Get 请求的配置方式:get请求的参数配置url后面,如图
  • 结合Python发送测试报告到邮箱

#encoding=utf-8

import time
import smtplib
import email
from email.mime.text import MIMEText
from email.mime.multipart import MIMEMultipart
import sys
import os.path
reload(sys)
sys.setdefaultencoding('utf-8')

#收件箱,如果是list请以逗号分隔
mailto_list=['[email protected]','[email protected]']
#发件箱
mail_host="smtp.126.com"
mail_user="XXXXtest"
mail_pass="XXXXXX"
mail_postfix="126.com"

def send_mail(attfile1, attfile2):

    today = time.strftime('%Y-%m-%d',time.localtime(time.time()))
    detailTime = time.strftime('%H:%M:%S',time.localtime(time.time()))
    todaytime = today + ' 00:00:00'
    selectres = todaytime
    send_header = "[demo项目][线上环境][自动化用例测试报告]- ".encode("utf-8") + today +" "+detailTime
    me= mail_user+"@"+mail_postfix
    msg = MIMEMultipart()
    msg['Subject'] = send_header
    msg['From'] = me
    msg['To'] = ";".join(mailto_list)

    #正文
    fp = open(attfile1,"r")
    content1 = fp.read()
    fp.close()

    content2 = '<html><h3>测试结果及更多详情请查看邮件附件【All_Report.html】和【Detail_Report.html】!!!</h3></html>'

    msg.attach(MIMEText(content1 + content2, 'html', 'utf-8'))

    #总体报告目录
    att1 = MIMEText(open(attfile1, 'rb').read(), 'base64', 'gb2312')
    att1["Content-Type"] = 'application/octet-stream'
    att1["Content-Disposition"] = 'attachment; filename="All_Report.html"'
    msg.attach(att1)

    #详细报告目录
    att2 = MIMEText(open(attfile2, 'rb').read(), 'base64', 'gb2312')
    att2["Content-Type"] = 'application/octet-stream'
    att2["Content-Disposition"] = 'attachment; filename="Detail_Report.html"'
    msg.attach(att2)

    try:
        server = smtplib.SMTP()
        server.connect(mail_host)
        server.ehlo()
        server.starttls()
        server.login(mail_user,mail_pass)
        server.sendmail(me, mailto_list, msg.as_string())
        server.quit()
        return True
    except Exception, e:
        print str(e)
        return False

#======查找测试报告目录,找到最新生成的测试报告文件====
def new_report(testreport):
    result_dir = testreport
    #获取该目录下的所有文件,将文件存到列表lists里
    lists=os.listdir(result_dir)
    #重新按时间先后对目录下(列表lists里)的文件进行排列,最新文件排末尾
    lists.sort(key=lambda fn: os.path.getmtime(result_dir+"\\"+fn))
    #找到最新生成的文件,并加上路径,lists(-1)倒数第一个
    file_new = os.path.join(result_dir,lists[-1])
    return file_new

if __name__ == '__main__':

    report_dir1 = "../report/html/Detail_Report"   #详细报告目录
    report_dir2 = "../report/html/All_Report"   #总体报告目录

    #找到生成的最新的测试报告
    file_new1 = new_report(report_dir1)
    file_new2 = new_report(report_dir2)
    print(file_new2)

    if send_mail(file_new2, file_new1):
        print u"测试报告邮件发送成功!"
    else:
        print u"测试报告邮件发送失败!"

3、执行测试,查看结果

  • build配置文件放在与测试脚本同目录下
  • 执行测试
  1. 命令行cd到build.xml文件所在目录,输入 ant run ,执行测试,如图
  2. 看到build successful 则说明构建测试成功
  • 测试报告
  1. 概要报告如下
  2. 详细报告如下

原文地址:https://www.cnblogs.com/jun-zi/p/12038438.html

时间: 2024-10-07 15:44:53

基于jmeter+ant实现的接口自动化测试的相关文章

使用jmeter+ant+jenkins实现接口自动化测试

本次使用linux环境搭建自动化框架 配置ANT ?首先下载Ant压缩包,下载地址https://ant.apache.org/bindownload.cgi?解压下载的ant包,然后复制jmeter/extras下的ant-jmeter-1.1.1.jar文件放到ant的lib目录?然后对该文件进行压缩,然后使用rz命令上传zip压缩包?上传成功之后,使用unzip apache-ant-1.10.5.zip 命令解压到当前文件夹,使用pwd查看当前文件路径,需要在jenkins配置用到?然后

Jmeter + ant + jenkins轻量级接口自动化测试

需要安装的工具: jdk1.8 jmeter3.2 ant1.9 jenkins2.1 1.Jdk 安装包安装 设置环境变量 验证是否安装正确 Java -version检查,如下就代表安装成功了,环境变量设置就去搜索了,网上很多. 2.Jmeter jmeter直接下载解压,然后配置环境变量就可以了 3.ANT Ant下载解压,配置环境变量,一样的操作.           window中设置ant环境变量:           以下是我电脑ant配置 ANT_HOME    D:\apach

Jmeter +Maven+jenkins+eclipse 接口自动化测试

背景: 首先用jmeter录制或者书写性能测试的脚本,用maven添加相关依赖,把性能测试的代码提交到github,在jenkins配置git下载性能测试的代码,配置运行脚本和测试报告,配置运行失败自动发邮件通知,这样一来性能测试的job配置完成.接着,把性能测试的job配置成开发job的下游job,一旦开发有了新的代码提交运行开发自己的job后,就会自动触发我们性能测试的job.这样我们就实现了接口性能测试的全自动化,我们只需要关注测试失败的邮件! 1 环境搭建 下载安装 jdk &eclip

基于Java+HttpClient+TestNG的接口自动化测试框架(四)-------参数存取处理

在真正开始接口测试之前,我们需要对参数的处理进行梳理.这里所说的“参数”,既包含之前在xml中的配置(我们称之为全局参数),也包含在每一条用例中书写的param.全局参数为固定不变的,而根据接口相应获取的数据是动态变化的. 之前我们已经用${param_name}的形式,定义了如何从公共参数池中调用所需要的参数. 并且当一个接口的请求发送完成,进行下一个接口操作的时候,我们也需要对相应的数据进行处理.例如,前面一个接口的响应中出现了下一个接口需要使用的数据,比如id,password,token

基于Java+HttpClient+TestNG的接口自动化测试框架(五)------ 测试用函数接口类及实现类

在前一篇中,我们着重阐述了参数的处理方法. 但是,这些参数基本都是直接赋值的.而实际的接口测试中,我们会根据需要做成很多的测试数据,这些测试数据会根据不同的情况来使用.例如,我可能需要一个能够随机生成一个中文的字符串,或者需要一个能够迅速求出一个文件或者字符串的MD5的值.在这种情况下,就需要我们动手去写一些函数来进行调用. 不过,如果是在Excel(或者其他文本编辑器)中写测试用例,如何才能让程序能够知道我是在调用一个函数,并且能够把这个函数的返回值赋给变量,正确的传入我想要的地方呢?下面,我

基于Java+HttpClient+TestNG的接口自动化测试框架(六)-------随机函数的处理

我们之前使用接口类及接口实现类的方式,来定义了我们使用的工具类. 而所有的工具类中,随机函数是比较难于处理的.因为随机的对象不明确,随机的个数不明确.我们可以使用定义随机类的方式,来简单而快速的处理我们的随机对象生成的需要. 首先,我们先定义一个randomUtil的类,在这个类中,我们可以将想生成的随机函数进行具体的定义.在此,我们举几个例子.比如,随机生成一个整数,随机生成一个定长(或不定长)的,带汉字(或不带汉字)的字符串,随机生成一个数组等等. 来看一下具体的RandomUtil类的代码

基于Java+HttpClient+TestNG的接口自动化测试框架(八)------ 针对文件的处理

在实际的接口测试中,有时需要根据情况进行文件的上传和下载.在文件数量比较小的时候,我们当然可以直接处理(比如若干个接口都用一个文件).但是,如果我们上传的文件需要使用不同文件夹里不同的文件,而且数量又比较大的情况下,直接写路径就比较麻烦了. 那么,怎样来处理这样的问题呢?还是需要先整理一下思路. 首先,我们需要根据某些特征,找到这些文件.例如,我们可以在指定的文件夹下面,按照文件后缀名来找寻文件.通常,我们在DOS下查询该文件夹下寻找同一后缀名文件的时候,会使用通配符“*”来代替文件名,例如:*

【三】Jmeter接口自动化测试系列之Http接口自动化实战

作者:大虫 本文介绍 Jmeter 工具的 http 接口 自动化测试 实战! 为了通用性,就拿知乎 网站作为实战例子吧! 必备技能:http接口基础知识.抓包,本文不做详细介绍,不会的可以先百度恶补! 首先,我们把 知乎登录的包抓下来: 我们抓一下 获取 Jmeter 对应脚本如下: 获取发现栏目脚本: 使用正则表达提取器,提取栏目内容(what?不会正则表达式?找百度) 使用 foreach 控制器将提取结果合并到一个字符串 打印结果: 运行结果: 在进行http 接口测试的时候,通常需要注

Python 基于python实现的http+json协议接口自动化测试框架源码(实用改进版)

目录 1.      写在前面 2.      开发环境 3.      大致流程 4.      框架简介 5.      运行结果展示 6.      文件与配置 7.      测试接口实例 n      1.登陆接口 n      2.支付密码更改接口 8.      数据库设计 9.      测试用例.测试数据准备 10.        模块与类.函数设计 11.        代码实现 a)         class congfighttp.ConfigHttp b)