编写一个Cruisecontrol的扩展插件

本文介绍如何为持续集成工具Cruisecontrol开发一个RTX消息通知插件,该插件可在构建完成后向团队成员发送即时消息通知。文章详细展示了插件的实现过程,包括工程结构、关键代码段以及配置步骤。
老牌的持续集成工具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构建一把试试看吧。

内容概要:文章以“智能网页数据标注工具”为例,深入探讨了谷歌浏览器扩展在毕业设计中的实战应用。通过开发具备实体识别、情感分类等功能的浏览器扩展,学生能够融合前端开发、自然语言处理(NLP)、本地存储与模型推理等技术,实现高效的网页数据标注系统。文中详细解析了扩展的技术架构,涵盖Manifest V3配置、内容脚本与Service Worker协作、TensorFlow.js模型在浏览器端的轻量化部署与推理流程,并提供了核心代码实现,包括文本选择、标注工具栏动态生成、高亮显示及模型预测功能。同时展望了多模态标注、主动学习与边缘计算协同等未来发展方向。; 适合人群:具备前端开发基础、熟悉JavaScript和浏览器机制,有一定AI模型应用经验的计算机相关专业本科生或研究生,尤其适合将浏览器扩展与人工智能结合进行毕业设计的学生。; 使用场景及目标:①掌握浏览器扩展开发全流程,理解内容脚本、Service Worker与弹出页的通信机制;②实现在浏览器端运行轻量级AI模型(如NER、情感分析)的技术方案;③构建可用于真实场景的数据标注工具,提升标注效率并探索主动学习、协同标注等智能化功能。; 阅读建议:建议结合代码实例搭建开发环境,逐步实现标注功能并集成本地模型推理。重点关注模型轻量化、内存管理与DOM操作的稳定性,在实践中理解浏览器扩展的安全机制与性能优化策略。
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值