1. Jenkins 自动构建提供一个很便利的入口帮助我们自动做一些东西。Jenkins通过一个任务(Job)帮助我们把一个个重复的工作,自动完成。
新建Job后,可以通过
配置源码管理: 拉取代码到工作空间。
构建触发器:定时执行,或者其它触发机制。
构建环境:
构建:通过shell运行ant或者其它方式完成构建。
构建后操作:可以完成邮件通知,或者其它后续工作。
2. 在构建的时候,我们可以执行shell,也就是我们有了控制jenkins所在linux系统帮助完成工作的关键环境。这里我们用到ant.
构建后操作邮件内容html格式。
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>${ENV, var="JOB_NAME"}-第${BUILD_NUMBER}次构建日志</title>
</head>
<body leftmargin="8" marginwidth="0" topmargin="8" marginheight="4" offset="0">
<table width="95%" cellpadding="0" cellspacing="0" style="font-size: 11pt; font-family: Tahoma, Arial, Helvetica, sans-serif">
<tr>
<td>本邮件由程序自动下发,请勿回复!</td>
</tr>
<tr>
<td><br />
<br>
***********************************************
优衣库Api接口自动化测试(日报)
***********************************************
<br>
<b><font color="#0B610B">构建信息</font></b>
<hr size="2" width="100%" align="center" />
</td>
</tr>
<tr>
<td>
<ul>
<li>项目名称:${PROJECT_NAME}</li>
<li>环境信息:https://jenkinsechctp.uniqlo.cn</li>
<li>SVN路径:${SVN_URL}</li>
<li>构建日志:<a href="${BUILD_URL}console">${BUILD_URL}console</a></li>
<li>测试报告:详细报告请双击附件查看!</li>
</ul>
</td>
</tr>
<tr>
<td>
<b><font color="#0B610B">变更信息:</font></b>
<hr size="2" width="100%" align="center" />
</td>
</tr>
<tr>
<td>
<ul>
${JELLY_SCRIPT,template="html"}</a>
</ul>
</td>
</tr>
<!--
<tr>
<td>
<b><font color="#0B610B">Failed Test Results</font></b>
<hr size="2" width="100%" align="center" />
</td>
</tr>
<tr>
<td>
<pre style="font-size: 11pt; font-family: Tahoma, Arial, Helvetica, sans-serif">$FAILED_TESTS</pre>
<br />
</td>
</tr>
<tr>
<td>
<b><font color="#0B610B">构建日志 (最后 100行):</font></b>
<hr size="2" width="100%" align="center" />
</td>
</tr>-->
<!-- <tr>
<td>Test Logs (if test has ran): <a
href="${PROJECT_URL}ws/TestResult/archive_logs/Log-Build-${BUILD_NUMBER}.zip">${PROJECT_URL}/ws/TestResult/archive_logs/Log-Build-${BUILD_NUMBER}.zip</a>
<br />
<br />
</td>
</tr> -->
<!--
<tr>
<td>
<textarea cols="80" rows="30" readonly="readonly" style="font-family: Courier New">${BUILD_LOG, maxLines=100,escapeHtml=true}</textarea>
</td>
</tr>-->
<hr size="2" width="100%" align="center" />
</table>
</body>
</html>
3. Jmeter 带了一个build.xml用来很好地运行Ant结合Jmeter进行工作。
Build.xml的配置可以参考网上文档。
Jmeter 结果输出jtl文件转化成html需要用到xsl样式,这个也可以在Jmeter 的extras下面可以找到。
<?xml version="1.0" encoding="utf-8"?>
<project name="test_jmeter" default="all" basedir=".">
<property environment="env"/>
<tstamp>
<format property="time" pattern="yyyyMMddHHmm" />
</tstamp>
<!-- 需要改成自己本地的 Jmeter 目录-->
<!-- property name="jmeter.home" value="${env.JMETER_HOME}" /-->
<condition property="jmeter.home" value="${JMETER_HOME}" else="/opt/apache-jmeter-3.3">
<isset property="JMETER_HOME" />
</condition>
<property name="lib.dir" value="${jmeter.home}\lib" />
<!-- jmeter生成jtl格式的结果报告的路径-->
<property name="jmeter.result.jtl.dir" value="${basedir}\TestResult\jtl" />
<!-- jmeter生成html格式的结果报告的路径-->
<property name="jmeter.result.html.dir" value="${basedir}\TestReport\html" />
<property name="jmeter.history.dir" value="${basedir}\TestHistory" />
<!-- 生成的报告的前缀 -->
<condition property="hostname" value="${host}" else="HuiLianYiproducts">
<isset property="host" />
</condition>
<property name="ReportName" value="Uniqlo-API-TestReport-" />
<property name="jmeter.result.jtlName" value="${jmeter.result.jtl.dir}/${ReportName}${time}.jtl" />
<property name="jmeter.result.log" value="${basedir}/TestLog/${time}.log" />
<property name="jmeter.result.htmlName" value="${jmeter.result.html.dir}/${ReportName}${time}.html" />
<!-- 电脑地址 -->
<property name="ComputerName" value="LAPTOP-VJV4S5M8" />
<target name="show-test-properties">
<echo>JMETER_HOME : ${jmeter.home}</echo>
<echo>TEST_PATH : ${test.plan.path}</echo>
<echo>THREADGROUP_COUNT : ${threadgroup.count}</echo>
<echo>THREADGROUP_RAMPUP : ${threadgroup.rampup}</echo>
<echo>THREADGROUP_DURATION : ${threadgroup.duration}</echo>
</target>
<target name="run" depends="show-test-properties">
<antcall target="delete" />
<antcall target="run_jmeter" />
<antcall target="report" />
<!--antcall target="sendEmail" /-->
</target>
<target name="run_jmeter">
<taskdef name="jmeter" classname="org.programmerplanet.ant.taskdefs.jmeter.JMeterTask" />
<jmeter jmeterhome="${jmeter.home}" resultlog="${jmeter.result.jtlName}" jmeterlogfile="${jmeter.result.log}">
<!-- 声明要运行的脚本。"*.jmx"指包含此目录下的所有jmeter脚本 -->
<testplans dir="${basedir}\TestSuite" includes="*.jmx" />
<property name="host" value="HuiLianYIproducts"/>
</jmeter>
</target>
<target name="report">
<path id="xslt.classpath">
<fileset dir="${lib.dir}" includes="xalan*.jar"/>
<fileset dir="${lib.dir}" includes="serializer*.jar"/>
</path>
<tstamp><format property="show-data" pattern="'n'"/></tstamp>
<tstamp><format property="report.title" pattern="'Uniqlo API Test Results'"/></tstamp>
<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.htmlName}"
style="${jmeter.home}/extras/jmeter.results.shanhe.me.xsl">
<param name="showData" expression="${show-data}"/>
<param name="titleReport" expression="${report.title}"/>
<param name="dateReport" expression="${report.datestamp}"/>
</xslt>
<copy todir="${jmeter.result.html.dir}">
<fileset dir="${jmeter.home}/extras">
<include name="collapse.png" />
<include name="expand.png" />
</fileset>
</copy>
<copy todir="${jmeter.history.dir}">
<fileset dir="${jmeter.result.html.dir}">
<include name="${ReportName}${time}.html" />
</fileset>
</copy>
</target>
<target name ="delete">
<delete includeEmptyDirs="true">
<fileset dir="${jmeter.result.html.dir}" includes="**/*"/>
</delete>
</target>
</project>
问题Trouble Shooting
1. Jenkins 运行报[jmeter] Waiting for possible Shutdown/StopTestNow/Heapdump message on port
分析思路:
测试Jmeter, 运行:jmeter.sh -n -t testplan.jmx -l log.jtl
测试Jmeter是不是好的。发现问题出在Jmeter脚本上。
2. 如果这一步通过,可以运行 ant run检查ant是不是好的。