1. 系统邮件配置
步骤一:
首页--管理Jenkins--System Configuration-- Configure System 进入配置界面
image.png
步骤二:
在配置界面找到Jenkins Location下配置
Jenkins URL,系统管理员邮件地址(也就是发送邮件的邮箱地址)
image.png
页面滚到最下面
SMTP服务器:要根据不同的邮箱而定,可以百度查一下,例子中配置的是qq邮箱,对应的就是smtp.qq.com
勾选使用SMTP认证,用户名填写上面系统管理员邮件地址,密码是此邮箱的授权码,而不是邮箱的登录密码
image.png
邮箱中要开启服务,发短信生成授权码
image.png
只需填写上面内容,保存后,可以测试一下配置是否能成功发送并收到邮件
image.png
注意:系统邮件配置只会在构建项目失败的时候才会发送邮件,所以一般不用,而需要一个可编辑的邮箱插件,下面介绍
2. 安装插件 Email Extension Plugin 并配置
安装插件
image.png首页--管理Jenkins--System Configuration-- Configure System 进入配置界面
找到Extended E-mail Notification
填写SMTP server,
image.png
点开高级,填写SMTP Username,如果SMTP Password在上面系统邮件配置中已经配置了,就会默认填写,但是此处的授权码必须重新获取后再填写在此处,不能使用上次默认填写的,否则会发送邮件失败,报错
502 Invalid input from 59.34.141.181 to newxmesmtplogicsvrszc11.qq.com
image.png
在后面有个默认触发,根据自己需求修改
image.png
勾选调试模式,再根据自己需求设置触发条件
image.png
进入项目页面--配置
拉到最后,点击构建后的操作--选择Editable Email Notification
image.png
Project From这个可以不写,如果要写的话,必须写系统配置的邮箱
Project Recipient List 写上接收邮件的邮箱地址,用英文逗号隔开
image.png
3. 邮箱模板
项目页面--配置--构建后操作Editable Email Notification里面可以修改内容的类型
Content Type,比如修改成HTML后,Default Content要填上HTML模板,可以网上百度,下面提供一个模板
image.png
邮件模板中有很多全局环境变量,
image.png image.png
Jenkins发送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>
(本邮件由系统自动发出,无需回复!)<br/>
各位好,以下是${PROJECT_NAME}项目构建信息<br/>
<td><font color="#CC0000">构建结果 - ${BUILD_STATUS}</font></td>
</tr>
<tr>
<td><br/>
<b><font color="#0B610B">构建信息 - ${BUILD_STATUS}</font></b>
<hr size="2" width="100%" align="center" /></td>
</tr>
<tr>
<td>
<ul>
<li>项目名称:${PROJECT_NAME}</li>
<li>构建编号:第${BUILD_NUMBER}次构建</li>
<li>构建版本:2021.1.0.0</li>
<li>触发原因:${CAUSE}</li>
<li>构建状态:${BUILD_STATUS}</li>
<li>构建日志:<a href="${BUILD_URL}console">${BUILD_URL}console</a></li>
<li>构建地址:<a href="${BUILD_URL}">${BUILD_URL}</a></li>
<li>工作目录:<a href="${PROJECT_URL}ws">${PROJECT_URL}ws</a></li>
<li>项目地址:<a href="${PROJECT_URL}">${PROJECT_URL}</a></li>
<li><a href="http://1xx.1xx.3.xx:81xx/plateform-backend/report/interfaceReport/xxx/${BUILD_TIMESTAMP}/index.html" >查看测试报告</a></li>
</ul>
<h4><font color="#0B610B">测试结果</font></h4>
<hr size="2" width="100%" />
<div>
本次测试共执行<b>${TEST_COUNTS}</b>个用例,
成功<b style="color: green">${TEST_COUNTS,var="pass"}</b>个,
失败<b style="color: red">${TEST_COUNTS,var="fail"}</b>个,
跳过<b style="color: #FFEB3B">${TEST_COUNTS,var="skip"}</b>个。
</div>
<h4><font color="#0B610B">失败用例</font></h4>
<hr size="2" width="100%" />
$FAILED_TESTS<br/>
<h4><font color="#0B610B">变更记录</font></h4>
<hr size="2" width="100%" />
<!-- <ul>
${CHANGES_SINCE_LAST_SUCCESS,reverse=true,format="%c",changestFormat="%d[%a]%m"}
</ul>
-->变更明细:<a href="${PROJECT_URL}changes">${PROJECT_URL}changes</a><br/>
</td>
</tr>
</table>
</body>
</html>
可用的环境变量
查看全局环境变量
image.png
邮件显示效果
image.png
unitest无法检测到用例个数,需要用pytest,结合alure测试报告
网友评论