使用Jenkins搭建iOS的CI服务器(三)

来源:互联网 发布:南方专业起名软件 编辑:程序博客网 时间:2024/06/05 04:55
 通过上两篇文章我们已经可以编译和部署IPA文件了,现在还差一步邮件通知了,Jenkins默认是提供一个了邮件通知,能够在构建失败或者不稳定状态后发送邮件,但是该邮件通知有较多的局限性,如无法提供详细的邮件内容、无法自定义发送邮件的格式、无法定义灵活的邮件接收配置。所以这里我们使用 Jenkins Email Extension Plugin插件,该插件我们可以自定义很多内容,下面将详细介绍该插件的使用。
     配置邮件系统之前,确保你已经安装了该插件,安装方法可以找之前文章了解。首先需要进行全局设置,点击左侧菜单“系统管理”—“系统设置”,如下图:


     在系统设置中找到“Extended E-mail Notification”项,在该项中可以配置一些全局的email-ext属性,下图是我的配置:



下面是我的配置:

Default Subject:构建通知:${BUILD_STATUS} - ${PROJECT_NAME} - Build # ${BUILD_NUMBER} !
Default Content:
<!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><h2>
                    <font color="#0000FF">构建结果 - ${BUILD_STATUS}</font>
                </h2></td>
        </tr>
        <tr>
            <td><br />
            <b><font color="#0B610B">构建信息</font></b>
            <hr size="2" width="100%" align="center" /></td>
        </tr>
        <tr>
            <td>
                <ul>
                    <li>项目名称&nbsp;:&nbsp;${PROJECT_NAME}</li>
                    <li>构建编号&nbsp;:&nbsp;第${BUILD_NUMBER}次构建</li>
                    <li>SVN&nbsp;版本:&nbsp;${SVN_REVISION}</li>
                    <li>触发原因:&nbsp;${CAUSE}</li>
                    <li>构建日志:&nbsp;<a href="${BUILD_URL}console">${BUILD_URL}console</a></li>
                    <li>构建&nbsp;&nbsp;Url&nbsp;:&nbsp;<a href="${BUILD_URL}">${BUILD_URL}</a></li>
                    <li>工作目录&nbsp;:&nbsp;<a href="${PROJECT_URL}ws">${PROJECT_URL}ws</a></li>
                    <li>项目&nbsp;&nbsp;Url&nbsp;:&nbsp;<a href="${PROJECT_URL}">${PROJECT_URL}</a></li>
                </ul>
            </td>
        </tr>
        <tr>
            <td><b><font color="#0B610B">Changes Since Last
                        Successful Build:</font></b>
            <hr size="2" width="100%" align="center" /></td>
        </tr>
        <tr>
            <td>
                <ul>
                    <li>历史变更记录 : <a href="${PROJECT_URL}changes">${PROJECT_URL}changes</a></li>
                </ul> ${CHANGES_SINCE_LAST_SUCCESS,reverse=true, format="Changes for Build #%n:<br />%c<br />",showPaths=true,changesFormat="<pre>[%a]<br />%m</pre>",pathFormat="&nbsp;&nbsp;&nbsp;&nbsp;%p"}
            </td>
        </tr>
        <tr>
            <td><b>Failed Test Results</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}</textarea>
            </td>
        </tr>
    </table>
</body>
</html>

全局属性介绍:
1. .Override Global Settings:如果不选,该插件将使用默认的 E-mail Notification 通知选项。反之,您可以通过指 定不同于( 默认选项)的设置来进行覆盖。
2. Default Content Type:指定构建后发送邮件内容的类型,有 Text 和 HTML 两种.
3. Use List-ID Email Header:为所有的邮件设置一个 List-ID 的邮件信头,这样你就可以在邮件客户端使用过滤。
它也能阻止邮件发件人大部分的自动回复 (诸如离开办公室、休假等等 )。你可以使用你习惯的任何名称或者 ID 号, 但是他们必须符合如下其中一种格式 (真实的 ID 必须要包含在<和>标记里):
<ci-notifications.company.org>
Build Notifications <ci-notifications.company.org>
“Build Notifications” <ci-notifications.company.org>
关于更详细的 List-ID 说明请参阅 RFC-2919.
4. Add 'Precedence: bulk' Email Header:设置优先级,更详细说明请参阅 RFC-3834.
5. Default Recipients:自定义默认电子邮件收件人列表。如果没有被项目配置覆盖 ,该插件会使用这个列表。您可以
在项目配置使用$ DEFAULT_RECIPIENTS 参数包括此默认列表,以及添加新的地址在项目级别。添加抄送: cc:
电子邮件地址例如 ,CC:someone@somewhere.com
6. Reply To List:回复列表, A comma separated list of e-mail addresses to use in the Reply-To header of
the email. This value will be available as $DEFAULT_REPLYTO in the project configuration.
7. Emergency reroute:如果这个字段不为空,所有的电子邮件将被 单独发送到该地址(或地址 列表)。
8. Excluded Committers :防止邮件被邮件系统认为是垃圾邮件 ,邮件列表应该没有扩展的账户名
(如:@domain.com ),并且使用逗号分隔
9. Default Subject:自定义邮件通知的默认主题名称 。该选项能在邮件的主题字段中替换一些 参数,这样你就可以在
     构建中包含指定的输出信息。
10. Maximum Attachment Size:邮件最大附件大小。
11. Default Content:自定义邮件通知的默认内容主体 。该选项能在邮件的内容中替换一些 参数,这样你就可以在构建
中包含指定的输出信息。
12. Default Pre-send Script:默认发送前执行的脚本 (注:grooy 脚本,这是我在某篇文章上看到的 ,不一定准确)。
13. Enable Debug Mode:启用插件的调试模式。这将增加额外的日志输出 ,构建日志以及 Jenkins 的日志。在调试
     时是有用的,但不能用于生产。
14. Enable Security:启用时,会禁用发送脚本的能力,直接进入 Jenkins 实例。如果用户试图访问 Jenkins 管理对
     象实例,将抛出一个安全异常。
15. Content Token Reference:邮件中可以使用的变量,所有的变量都是可选的。


     上面是全局设置,要想激活邮箱通知,还需要在任务配置中配置,进入到任务配置中选择“增加构建后操作步骤”,选择Editable Email Notification,如图:
     

添加邮件通知后,默认是不会发送邮件通知的,因为我们还没有配置邮件触发器,选择Advanced Settings,将会添加一个成功的触发器如图:
触发器的邮件属性和之前全局的配置是一样的,这里可以为不同的触发条件配置不同的邮件内容。可以点击下面的Add Trigger添加多个触发器,这样就可以做到成功、失败通知到不同的人员,可以有以下触发器,所有的触发器都只能配置一次:

Failure:即时发送构建失败的邮件。如果”Still Failing”触发器已配置,而上一次构建的状态是”Failure”,那么”Still Failing” 触发器将发送一封邮件来替代 (它)。
Unstable:即时发送构建不稳固的邮件。如果”Still Unstable”触发器已配置,而上一次构建的状态是”Unstable”,那么”Still Unstable”触发器将发送一封邮件来替代 (它)。
Still Failing:如果两次或两次以上连续构建的状态为 ”Failure”,发送该邮件。 Success:如果构建的状态为”Successful”发送邮件。如果”Fixed”已配置,而上次构建的状态为 “Failure”或“Unstable”,那 么”Fixed”触发器将发送一封邮件来替代 (它)。 Fixed:当构建状态从“Failure”或“Unstable”变为”Successful”时发送邮件。
Still Unstable:如果两次或两次以上连续构建的状态为 ” Unstable “,发送该邮件。
Before Build:当构建开始时发送邮件。


参考资料:

http://blog.csdn.net/leijiantian

http://blog.csdn.net/wangmuming/article/category/2167947

http://webfrogs.me/2013/12/31/jenkins-ios-ci/

http://blog.csdn.net/qs_csu/article/details/9356023

https://github.com/webfrogs/xcode_shell
0 0
原创粉丝点击