美文网首页katp我爱编程
jmeter实战(三)Jmeter+Ant+Jenkins接口自

jmeter实战(三)Jmeter+Ant+Jenkins接口自

作者: 芯W | 来源:发表于2018-07-26 15:19 被阅读0次

       Jmeter可以做接口测试,也能做压力测试,而且是开源软件;Ant是基于Java的构建工具,可以跨平台,Jenkins是持续集成工具。将这三者结合起来可以搭建一套Web HTTP接口测试的持续构建环境,实现接口自动化测试,pc系统是Windows。

    1、安装jmeter

    2、安装JDK

            1、2步骤之前已经听过怎么安装配置了,故省略。。。

    3、安装ANT

          3.1 安装包下载

    下载地址 http://ant.apache.org/bindownload.cgi,下载后解压到指定位置即可,我是放在D:\Program Files (x86)\apache-ant-1.10.3,与jmeter放在同一位置

    3.2 配置系统变量

    ANT_HOME 为   D:\Program Files (x86)\apache-ant-1.10.3

    CLASSPATH为   %ANT_HOME%\lib;

    PATH为  %ANT_HOME%\bin;

           3.3 安装验证

    验证安装结果,命令行输入ant -v,出现版本信息则安装成功

    4、Ant配置Jmeter:就是用ant构建命令来调动执行jmeter接口测试,并生成测试报告

    4.1 配置库文件

    将jmeter extras目录下的ant-jmeter-1.1.1.jar文件拷贝到ant安装目录下的lib文件夹中

    4.2  配置ant的编译文件 build.xml

    新建的txt文件,并将此文件改名为build.xml,将如下文本敲进在文档里,或者在网上找现成的再修改

    注意:jmeter的extras文件下也有个build.xml文档,不要用这个文档来改,是两回事,会出问题!!!。。。。这里的build文档是自己新建。。新建。。新建。。    

    PS:已经弄好的build.xml文件和htlm样式模板jmeter-results-shanhe-me.xsl

    链接:https://pan.baidu.com/s/1iI3shn_yd3oF-rNvnohmrQ 密码:7fjt

    如下按实际情况修改build.xml文件

    4.3  配置jmeter.properties文档

    找到jmeter.properties文档,在jmeter/bin目录下,打开该文档并编辑,修改jmeter报告输出格式为xml:改jmeter.save.saveservice.output_format=csv 为jmeter.save.saveservice.output_format=xml,并去掉前面的注释符号#

    4.4 验证配置,执行构建测试

    将之前jmeter的脚本保存, 并将build.xml配置文件放在与测试脚本相同的目录下

    4.5  执行测试

    在build.xml所在目录打开命令窗口(鼠标在空白处按下shift键后在右键),或者命令行cd到build.xml文件所在目录,输入ant run回车,执行测试

    看到build successful 则说明构建测试成功,离成功越来越近了。。。

    4.6   查看测试结果报告

    在报告输出存放路径下查看是否有jtl和html结果报告,存放路径在build文档中也有

    打开html文档,测试结果展现了执行的用例名称、成功率、用例执行时间等结果参数

    这样的结果不太直观,因为用jmeter自带的测试报告得到的测试报告信息并不是很全,下面讲一下怎么优化测试报告

    4.7、 优化测试报告

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

    ②设置测试输出报告要输出的内容:同样在jmeter.properties中,设置需要输出的内容为true,并去掉前面的注释符号#,这里全部设置成true→保存

    jmeter.save.saveservice.data_type=true

    jmeter.save.saveservice.label=true

    jmeter.save.saveservice.response_code=true

    # response_data is not currently supported for CSV output

    jmeter.save.saveservice.response_data=true

    # Save ResponseData for failed samples

    jmeter.save.saveservice.response_data.on_error=false

    jmeter.save.saveservice.response_message=true

    jmeter.save.saveservice.successful=true

    jmeter.save.saveservice.thread_name=true

    jmeter.save.saveservice.time=true

    jmeter.save.saveservice.subresults=true

    jmeter.save.saveservice.assertions=true

    jmeter.save.saveservice.latency=true

    jmeter.save.saveservice.connect_time=true

    jmeter.save.saveservice.samplerData=true

    jmeter.save.saveservice.responseHeaders=true

    jmeter.save.saveservice.requestHeaders=true

    jmeter.save.saveservice.encoding=true

    jmeter.save.saveservice.bytes=true

    jmeter.save.saveservice.url=true

    jmeter.save.saveservice.filename=true

    jmeter.save.saveservice.hostname=true

    jmeter.save.saveservice.thread_counts=true

    jmeter.save.saveservice.sample_count=true

    jmeter.save.saveservice.idle_time=true

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

    ④再次用ant构建测试,查看优化后的测试报告

    5、配置Jenkins,构建持续化集成

    5.1  安装Jenkins:

    ①前提条件:已经成功安装了JDK,因为jenkins是一款基于Java的持续集成工具。

    ②准备工具:下载安装包,https://jenkins.io/index.html,下载jenkins的war包。

    5.2  配置环境变量

    JENKINS_HOME 为   D:\Program Files (x86)\jenkins

    5.3  启动jenkins

          在jenkins.war包放置目录下,shift+右键打开cmd,输入命令:  java -jar jenkins.war  ,就可以启动jenkins了。再在浏览器中输入:http://127.0.0.1:8080/,打开jenkins,配置用户名、密码及插件,这里需要配置invoke ant插件、HTML测试报告展示的插件

    5.4、新建并配置一个JOB

    设置项目名称:

    配置构建:

    配置构建:invoke ant

    配置测试报告插件,用于打开测试结果报告

    配置完成

    PS:Jenkins构建生成的报告无法展示 HTML 样式的问题

    解决方案:

    临时解决方案:Jenkins系统管理-脚本命令行,输入如下命令并进行执行:System.setProperty("hudson.model.DirectoryBrowserSupport.CSP", "")    

    再次进行构建,新生成的HTML就可以正常展示样式了。需要说明的是,该操作对之前构建生成的HTML报告无效 PS:该配置只是临时生效,当重启Jenkins后,Content Security Policy又会恢复为默认值,从而HTML样式又没法展示了

    永久解决方案

    当前,Jenkins官方还没有相应的解决方法,我们只能在每次启动或重启Jenkins时,重新修改该安全策略。

    如果手工地来重复这项工作,也是可行,但并不是一个好的解决方案。

    回到刚才的脚本命令行,会发现我们执行的命令其实就是一段Groovy代码;那么,如果我们可以实现在Jenkins每次启动时自动地执行该Groovy代码,那么也就同样能解决我们的问题了。

    好在Jenkins已经有相应的插件:

    Startup Trigger: 可实现在Jenkins节点(master/slave)启动时触发构建;

    Groovy plugin: 可实现直接执行Groovy代码。

    搜索安装startup-trigger-plugin和Groovy插件后,我们就可以进行配置了。

    配置方式如下:

    新建一个job,该job专门用于Jenkins启动时执行的配置命令;

    在Build Triggers模块下,勾选Build when job nodes start;

    在Build模块下,Add build step->Execute system Groovy script,在Groovy Script中输入配置命令,System.setProperty("hudson.model.DirectoryBrowserSupport.CSP", "")。

    需要注意的是,添加构建步骤的时候,应该选择Execute system Groovy script,而不是Execute Groovy script。关于这两者之间的差异,简单地说,Groovy Script相当于是运行在master/slave系统JVM环境中,而system groovy script,则是运行在Jenkins master的JVM环境中,与前面提到的Jenkins Script Console功能相同。如需了解更多信息,可查看Groovy plugin的详细说明

    至此,我们就彻底解决HTML样式展示异常的问题了。

    但还有一点需要格外注意,在本文的演示中,我们修改CSP(Content Security Policy)配置时关闭了的所有安全保护策略,即将hudson.model.DirectoryBrowserSupport.CSP设置为空,其实这是存在很大的安全隐患的。

    正确的做法,我们应该是结合项目的实际情况,选择对应的安全策略。例如,如果我们需要开启脚本文件加载,但是只限于Jenkins服务器上托管的CSS文件,那么就可以采用如下配置。

    System.setProperty("hudson.model.DirectoryBrowserSupport.CSP", "sandbox; style-src 'self';")

    除此之外,CSP可以实现非常精细的权限配置,详细配置可参考Content Security Policy Reference

    相关文章

      网友评论

        本文标题:jmeter实战(三)Jmeter+Ant+Jenkins接口自

        本文链接:https://www.haomeiwen.com/subject/dwhilftx.html