• 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环境变量,如下为我的配置

    1. ANT_HOME E:\apache-ant-1.10.5
    2. Path E:\apache-ant-1.10.5\bin
    3. 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,其内容如下:


    1. <?xml version="1.0" encoding="UTF-8"?>
    2. <project name="ant-jmeter-test" default="run" basedir=".">
    3. <tstamp>
    4. <format property="time" pattern="yyyy_MM_dd_HH_mm" />
    5. </tstamp>
    6. <!-- 需要改成自己本地的 项目路径根 目录,即jmeter安装文件所在的目录-->
    7. <property name="project.home" value="..\" />
    8. <!-- 需要改成自己本地的 Jmeter 目录-->
    9. <property name="jmeter.home" value="${project.home}\apache-jmeter-3.2" />
    10. <!-- jmeter生成jtl格式的结果报告的路径-->
    11. <property name="jmeter.result.jtl.dir" value="${project.home}\report\jtl" />
    12. <!-- jmeter生成html格式的结果报告的路径-->
    13. <property name="jmeter.result.html.dir" value="${project.home}\report\html" />
    14. <!-- 生成的报告的前缀-->
    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.all_htmlName" value="${jmeter.result.html.dir}/All_Report/All${ReportName}_${time}.html" />
    18. <property name="jmeter.result.detail_htmlName" value="${jmeter.result.html.dir}/Detail_Report/Detail${ReportName}_${time}.html" />
    19. <target name="run">
    20. <antcall target="test" />
    21. <antcall target="report" />
    22. </target>
    23. <target name="test">
    24. <taskdef name="jmeter" classname="org.programmerplanet.ant.taskdefs.jmeter.JMeterTask" />
    25. <jmeter jmeterhome="${jmeter.home}" resultlog="${jmeter.result.jtlName}">
    26. <!-- 声明要运行的目录和脚本。"*.jmx"指包含此目录下的所有jmeter脚本-->
    27. <testplans dir="${project.home}\jmeter_Code" includes="*.jmx" />
    28. <property name="jmeter.save.saveservice.output_format" value="xml"/>
    29. </jmeter>
    30. </target>
    31. <path id="xslt.classpath">
    32. <fileset dir="${jmeter.home}/lib" includes="xalan*.jar"/>
    33. <fileset dir="${jmeter.home}/lib" includes="serializer*.jar"/>
    34. </path>
    35. <target name="report">
    36. <tstamp> <format property="report.datestamp" pattern="yyyy/MM/dd HH:mm" /></tstamp>
    37. <xslt
    38. classpathref="xslt.classpath"
    39. force="true"
    40. in="${jmeter.result.jtlName}"
    41. out="${jmeter.result.all_htmlName}"
    42. style="${jmeter.home}/extras/jmeter-results-detail-report_21.xsl" />
    43. <xslt
    44. classpathref="xslt.classpath"
    45. force="true"
    46. in="${jmeter.result.jtlName}"
    47. out="${jmeter.result.detail_htmlName}"
    48. style="${jmeter.home}/extras/jmeter.results.shanhe.me.xsl" />
    49. <!-- 因为上面生成报告的时候,不会将相关的图片也一起拷贝至目标目录,所以,需要手动拷贝 -->
    50. <copy todir="${jmeter.result.html.dir}/All_Report">
    51. <fileset dir="${jmeter.home}/extras">
    52. <include name="collapse.png" />
    53. <include name="expand.png" />
    54. </fileset>
    55. </copy>
    56. </target>
    57. </project>
    • 按实际情况修改build.xml文件,相关说明如下

       

    • 3、配置jmeter.properties
      • 配置jmeter报告输出格式为xml。在jmeter根目录下apache-jmeter-3.2\bin\jmeter.properties文件中修改 jmeter.save.saveservice.output_format=csv 为 jmeter.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发送测试报告到邮箱

    1. #encoding=utf-8
    2. import time
    3. import smtplib
    4. import email
    5. from email.mime.text import MIMEText
    6. from email.mime.multipart import MIMEMultipart
    7. import sys
    8. import os.path
    9. reload(sys)
    10. sys.setdefaultencoding('utf-8')
    11. #收件箱,如果是list请以逗号分隔
    12. mailto_list=['testXXX1@126.com','testXXX2@126.com']
    13. #发件箱
    14. mail_host="smtp.126.com"
    15. mail_user="XXXXtest"
    16. mail_pass="XXXXXX"
    17. mail_postfix="126.com"
    18. def send_mail(attfile1, attfile2):
    19. today = time.strftime('%Y-%m-%d',time.localtime(time.time()))
    20. detailTime = time.strftime('%H:%M:%S',time.localtime(time.time()))
    21. todaytime = today + ' 00:00:00'
    22. selectres = todaytime
    23. send_header = "[demo项目][线上环境][自动化用例测试报告]- ".encode("utf-8") + today +" "+detailTime
    24. me= mail_user+"@"+mail_postfix
    25. msg = MIMEMultipart()
    26. msg['Subject'] = send_header
    27. msg['From'] = me
    28. msg['To'] = ";".join(mailto_list)
    29. #正文
    30. fp = open(attfile1,"r")
    31. content1 = fp.read()
    32. fp.close()
    33. content2 = '

      测试结果及更多详情请查看邮件附件【All_Report.html】和【Detail_Report.html】!!!

      '
    34. msg.attach(MIMEText(content1 + content2, 'html', 'utf-8'))
    35. #总体报告目录
    36. att1 = MIMEText(open(attfile1, 'rb').read(), 'base64', 'gb2312')
    37. att1["Content-Type"] = 'application/octet-stream'
    38. att1["Content-Disposition"] = 'attachment; filename="All_Report.html"'
    39. msg.attach(att1)
    40. #详细报告目录
    41. att2 = MIMEText(open(attfile2, 'rb').read(), 'base64', 'gb2312')
    42. att2["Content-Type"] = 'application/octet-stream'
    43. att2["Content-Disposition"] = 'attachment; filename="Detail_Report.html"'
    44. msg.attach(att2)
    45. try:
    46. server = smtplib.SMTP()
    47. server.connect(mail_host)
    48. server.ehlo()
    49. server.starttls()
    50. server.login(mail_user,mail_pass)
    51. server.sendmail(me, mailto_list, msg.as_string())
    52. server.quit()
    53. return True
    54. except Exception, e:
    55. print str(e)
    56. return False
    57. #======查找测试报告目录,找到最新生成的测试报告文件====
    58. def new_report(testreport):
    59. result_dir = testreport
    60. #获取该目录下的所有文件,将文件存到列表lists里
    61. lists=os.listdir(result_dir)
    62. #重新按时间先后对目录下(列表lists里)的文件进行排列,最新文件排末尾
    63. lists.sort(key=lambda fn: os.path.getmtime(result_dir+"\\"+fn))
    64. #找到最新生成的文件,并加上路径,lists(-1)倒数第一个
    65. file_new = os.path.join(result_dir,lists[-1])
    66. return file_new
    67. if __name__ == '__main__':
    68. report_dir1 = "../report/html/Detail_Report" #详细报告目录
    69. report_dir2 = "../report/html/All_Report" #总体报告目录
    70. #找到生成的最新的测试报告
    71. file_new1 = new_report(report_dir1)
    72. file_new2 = new_report(report_dir2)
    73. print(file_new2)
    74. if send_mail(file_new2, file_new1):
    75. print u"测试报告邮件发送成功!"
    76. else:
    77. print u"测试报告邮件发送失败!"

    3、执行测试,查看结果

    • build配置文件放在与测试脚本同目录下

    • 执行测试

    1. 命令行cd到build.xml文件所在目录,输入 ant run ,执行测试,如图

    2. 看到build successful 则说明构建测试成功
    • 测试报告
    1. 概要报告如下

    2. 详细报告如下

       

    2023最新Jmeter接口测试从入门到精通(全套项目实战教程)

  • 相关阅读:
    解决gif 透明度问题
    苹果搜索广告投放(ASA)因元数据被拒有哪些情况呢(下)
    C++ //练习 10.2 重做上一题,但读取string序列存入list中。
    2022IDEAMaven搭建MyBatis框架(标签和对象不理解的看一下初始那一期的基础部分)
    Vscode MacOS版本下载及html配置
    [原创]JVM垃圾回收机制和常见垃圾收集器-CMS、G1、ZGC
    【代码仓库提交大文件,用Git LFS!】
    k8s集群reset恢复重置
    中介模式简介
    NTP/NTPD-时间同步服务
  • 原文地址:https://blog.csdn.net/ada4656/article/details/134296904