3、持续集成流程

  一般在互联网软件开发和测试过程中,增加了持续集成构建,在开发和测试环节会进行多次集成与构建,做的比较好的公司,如google,微软等,可以集单元测试、功能自动化测试等集成在一起构建,做到分支代码变更脚本通知一条龙智能流程化和服务化,可见下图-6流程所示。

  4、持续集成优点

  通过上述概念和模式的阐述,让读者很容易发现持续集成大的优点是降低风险,提高项目研发过程的效率和质量,迎合在互联网时代信息快速更新的现象。持续集成本身并不能帮助开发工程师找到bug,它是通过不断的测试和反馈来尽早的发现缺陷,问题发现的越早处理问题的成本越小越容易解决,由于无法证明通过了测试的代码是无bug存在的,所以持续集成中的测试非常重要,好的测试能够更多更快的发现当前版本中的错误。

  往往在开发和测试过程中,软件的缺陷是累积性的,当缺陷很多时,很难发现它们,利用持续集成构建的思想,在项目过程中可以尽早的发现缺陷,大限度的降低了我们在项目后期发现缺陷的可能性和偶然性。

  每成功构建运行一次意味着之前做的代码提交可以成功集成,没有与他人提交的分支代码发生冲突,没有带来新的缺陷,有利于开发人员对项目保持自信心和提高工程师的工作激情。

  持续集成在项目中的频繁部署将会使终部署的难度降到小,用户能够看到频繁上线的软件,并做及时的沟通反馈,有助于增强互联网模式下用户的信心和动力,也有助于Web产品化和服务化朝着正确的方向快速发展。

  5、持续集成构建分析及工具

  在敏捷的软件开发和测试团队中,我们所要做的只不过是:不断的回顾、找出问题与瓶颈、不断地重构。通过不断重构持续集成基础结构以及自动化构建脚本,使其达到我们对“反馈时间”和“判断质量准确性”的要求。另外,我们已将“持续集成”扩展到整个软件开发周期,涵盖了持续部署及发布。在上面的配置文件中,不难看出在管道模式中的两个Stage分别名为 “UAT”测试和交付的“Production”,它们一个用于部署新版本到我们自己的持续集成服务器,另一个用于部署新版本到一个公用的持续集成服务器。部署 ‘UAT’的频率为两天到一周之间,‘Production’的频率基本都是一周。这样,我们可以得到快速反馈,改进自己的产品,同时其它团队可以尽早地使用我们开发的新功能。

  目前业界主流的持续集成工具主要有:Apache Continuum,CruiseControl,Hudson,Maven,LuntBuild等等,开源工具使用的比较多是Hudson框架。

  五、Hudson介绍

  1、Hudson简介

  是一个功能强大的持续集成框架,可以持续构建和测试软件项目,并监控持续集成中生成的报告,属于开源框架,可以进行多元化插件开发与集成。

  框架的优点是基于WAR包,安装部署非常简单,提供了功能完善的Web管理界面和强大的报告输出功能,另外是有丰富的插件支持,并支持自动化安装,便于维护。

  2、核心应用

  由于是开源框架,在项目实践中可以不断完善我们持续集成过程存在的问题,可以集成更多的插件解决我们想要自助的集成模式。

  目前在笔者参与的项目中的核心应用主要有几个部分:

  1)静态代码检查(Findbugs工具)

  2)单元测试(Junit)

  3)代码覆盖率检查(Cov)

  3、安装与配置

  开源框架,有便利的安装指南,安装起来非常快捷,主要步骤有:

  ● 下载Hudson WAR包

  ● 部署到Jboss服务中

  ● 安装Html Report Plugin插件

  ● 安装Cobertura Plugin插件

  ● 安装Findbugs Plugin插件

  ● 创建分组视图和用户权限

  配置也比较简单,主要配置插件和SVN代码及环境相关的条件,我们先看下配置插件,见下图所示:

  Cobertura配置(图-7)