编写一个Cruisecontrol的扩展插件

老牌的持续集成工具Cruisecontrol已经很少更新了,后起之秀Hudson相比之下却是非常的活跃。CC和Hudson对插件的支持都很好,本想在Hudson上编写一个RTX消息插件,被maven绕晕了,就先在CC里面实现一个罢。

RTX是一种企业办公用的即时通讯工具,界面简洁清爽,而且可以和企业组织结构相结合,我个人还是比较喜欢的。面对面的沟通永远是最高效的,如果在半径20米范围内,还用rtx聊,那就过之不及。请站起来,走过去。扯远了,言归正传。

RTXPublisher这个插件的目的非常简单,在构建完成后通过RTX通知团队相关人员。让我们直接开始动手吧:
1)CC的插件是以Jar包的形式放在lib目录下。为了生成cc_rtx_plugin.jar. 我们先创建一个工程cc_rtx_plugin,目录结构非常之简单。
cc_rtx_plugin
   |--src
         |--com
                |--david
                       |--RTXPublisher.java
   |--lib
         |--cruisecontrol.jar   (会使用到其中的net.sourceforge.cruisecontrol.Publisher, net.sourceforge.cruisecontrol.util.XMLLogHelper)

2) RTXPublisher的关键代码:
public class RTXPublisher implements Publisher {
  //几个配置项:failureOnly是否仅在构建失败时调用,receivers消息接收者,
  //buildresultsurl构建结果链接,和htmlemail插件的同名属性一样
    private boolean failureOnly = false;
    private String receivers;
    private String buildresultsurl;
    //重载validate,检验输入参数
    public void validate() throws CruiseControlException {
        if (null == receivers)
            throw new CruiseControlException("Receivers missing");
    }
    //重载publish
    public void publish(Element cruisecontrolLog) throws CruiseControlException {
        XMLLogHelper logHelper = new XMLLogHelper(cruisecontrolLog);
        String buildResult = "构建成功";
        if (logHelper.isBuildSuccessful()) {
            if (failureOnly)    //仅在失败时提醒
                return;
        } else {
            buildResult = "构建失败";
        }
        final String buildId = logHelper.getLabel();
        Date buildTime = DateUtil.parseFormattedTime(logHelper.getBuildTimestamp(), "buildTime");
        Format format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
        String formatBuildTime = format.format(buildTime);
        String title = "[" + logHelper.getProjectName() + "]" + buildId + buildResult;
        String msgInfo = "构建时间:" + formatBuildTime
                    + "/n代码更新:" + logHelper.getModifications().size()
                    + "/n点击[查看详细构建结果|" + buildresultsurl + "]";
        sendRTX(title, msgInfo);// rtx notify       
    }
}
具体发RTX消息的实现不是重点,这里不赘述.

3) 把生成的jar包放到cc_home/lib目录下,注意如果你使用到其他的jar包,也要一并放过去。现在开始配置config.xml来使用cc_rtx_plugin.jar
<cruisecontrol>
   <!--放在project里面,则仅这个project使用,放在cruisecontrol节点下,就可以多个project公用 -->
   <plugin name="rtxpublisher" classname="com.david.RTXPublisher" />
   
....
    <project name="connectfour">
        <publishers>
            <rtxpublisher receivers="david" failureOnly="false"
              buildresultsurl="http://localhost:8080/cruisecontrol/buildresults/${project.name}"
            />
        </publishers>
    </project>
</cruisecontrol>

4)重新启动cruisecontrol构建一把试试看吧。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值