集成与构建指南(5)

原创 2004年03月01日 10:10:00

1.1         CruiseControl执行脚本<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />

持续集成的过程由缺省文件名为config.xml的配置文件来定义。config.xml中确定了构建周期间隔,以及检测配置库状态、调用Ant配置文件进行构建等步骤的内容。为了实现自动化持续集成,还应编制Ant封装(wrapper)配置文件,它在调用原始Ant构建脚本(相当于将原始Ant脚本封装在内)的基础上,添加用于持续集成的更新源码目录等步骤。

1.1.1          CruiseControl项目配置文件

CruiseControl项目配置文件描述了一个集成项目(project),它由引导段(bootstrappers)、检测修改集段(modificationset)、调度段(schedule)、日志记录段(log)、发布段(publishers)、插件定义段(plugin)组成。引导段用来设置持续集成流程开始执行时相关的初始化任务,例如更新源码管理中的指定文件;检测修改集段则指定了需要检测的已置于配置管理下的目标源码,以便在检测到有源码更新后启动后续的构建步骤,例如clearcase中的某分支下、某视图中的一个目录;调度段是持续集成流程的核心部分,在此确定了构建周期间隔、休眠时段,并描述了构建的目标,目标通常指向一个Ant封装配置文件;日志记录段指定了将向发布步骤提供数据的各项日志记录;发布段则设置了对构建结果进行发布和通知的内容,例如指定报告的E-mail地址等;插件定义段用来指定CruiseControl各项功能实现对应的插件类

1.1.2       CruiseControl配置文件示例

下面是一个CruiseControl项目的配置文件示例:

 

<?xml version="1.0"?>

<cruisecontrol>

         <project name="peripheral_api_project">

                   <bootstrappers>

                            <currentbuildstatusbootstrapper file="currentbuild.txt"/>

                   </bootstrappers>

                   <modificationset quietperiod="30">

                           <clearcase branch="PCHL_V1_Dev" recursive="true"

                                    viewpath="d:/Shared_Views/PCHL_V1_Dev/PCHL_Components/protocols_api/peripheral"/>

                   </modificationset>

                   <schedule interval="60">

                            <ant buildfile="proj.xml" target="cleanbuild" multiple="5"/>

                            <ant buildfile="proj.xml" target="masterbuild" multiple="1"/>

                            <pause starttime="1900" endtime="2359"/>

                            <pause starttime="0000" endtime="0659"/>

                            <pause day="saturday" starttime="0000" endtime="2359"/>

                            <pause day="sunday" starttime="0000" endtime="2359"/>

                   </schedule>

                   <log dir="logs/peripheral_api_project" encoding="ISO-8859-1">

                            <merge dir="d:/Shared_Views/PCHL_V1_Dev/PCHL_Components/protocols_api/peripheral/bin/test-results"/>

                   </log>

                   <publishers>

                            <currentbuildstatuspublisher file="currentbuild.txt"/>

                            <email mailhost="sysway.com" returnaddress="xghu@sysway.com" defaultsuffix=""

                                     buildresultsurl="http://pchl1-tstn:8080/cruisecontrol/buildresults" logdir="logs/peripheral_api_project"

                                     css="C:/Development_Tools/Building-Utils/cruisecontrol-2.1.5/reporting/jsp/css/cruisecontrol.css"

                                     xsldir="C:/Development_Tools/Building-Utils/cruisecontrol-2.1.5/reporting/jsp/xsl">

                                     <always address="xghu@sysway.com"/>

                                     <failure address="xghu@sysway.com"/>

                                     <map alias="huxg" address="xghu@sysway.com"/>

                            </email>

                   </publishers>

                   <plugin name="currentbuildstatusbootstrapper"

                            classname="net.sourceforge.cruisecontrol.bootstrappers.CurrentBuildStatusBootstrapper"/>

                   <plugin name="clearcasebootstrapper"

                            classname="net.sourceforge.cruisecontrol.bootstrappers.ClearCaseBootstrapper"/>

                   <plugin name="clearcase" classname="net.sourceforge.cruisecontrol.sourcecontrols.ClearCase"/>

                   <plugin name="ant"

                           classname="net.sourceforge.cruisecontrol.builders.AntBuilder"/>

                   <plugin name="pause"

                            classname="net.sourceforge.cruisecontrol.PauseBuilder"/>

                   <plugin name="email"

                            classname="net.sourceforge.cruisecontrol.publishers.HTMLEmailPublisher"/>

                   <plugin name="currentbuildstatuspublisher"

                            classname="net.sourceforge.cruisecontrol.publishers.CurrentBuildStatusPublisher"/>

                   <plugin name="labelincrementer"

                            classname="net.sourceforge.cruisecontrol.labelincrementers.DefaultLabelIncrementer"/>

         </project>

</cruisecontrol>

 

1.1.3       Ant封装(wrapper)配置文件示例

下面是一个Ant封装(wrapper)配置文件示例:

 

<?xml version="1.0"?>

<project name="peripheral_api_cc" default="masterbuild">

         <property file="proj.properties"></property>

         <property name="proj.dir" location="${proj.path}"/>

         <target name="update" description="Update packages from ClearCase">

                   <ccupdate log="clearcase.log" overwrite="true" viewpath="${proj.dir}"/>

         </target>

         <target name="clean" description="Clean all build products">

                   <ant dir="${proj.dir}/build" target="CleanAll"/>

         </target>

         <target name="build">

                   <ant dir="${proj.dir}/build" target="AutoBuild"/>

         </target>

         <target name="rununittests" depends="build">

                   <ant dir="${proj.dir}/build" target="Test"/>

         </target>

         <target name="smoketest" depends="build">

         </target>

         <target name="masterbuild" depends="update,rununittests,smoketest"

                   description="Cruise control master build"/>

         <target name="cleanbuild" depends="clean,masterbuild"

                   description="Cruise control clean build"/>

</project>

 

注意本Ant项目配置文件中主要添加了update目标,用来将proj.properties文件中定义的 proj.path=d:/Shared_Views/PCHL_V1_Dev/PCHL_Components/protocols_api/peripheral目录下的所有内容进行更新。

1.1.4       cruisecontrol执行示例

cruisecontrol在命令行下执行的示例:

<?xml:namespace prefix = v ns = "urn:schemas-microsoft-com:vml" />CSDN_Dev_Image_2004-2-291846270.png

 

集成与构建指南

首次贡献一个在项目中已经得到验证的持续集成方案,使用了Ant/Cpptask和cruisecontrol,欢迎有志于自动化构建和持续集成的同仁进行交流 http://umlchina.smiling....
  • hunthu2000
  • hunthu2000
  • 2004年03月01日 10:07
  • 806

集成与构建指南(10)

1.1         项目系统集成发布的实施方案项目最终产品即目标系统由各个构件和引用的第三方开发包共同组装而成,可以认为其源码就是各构件的源码,必须纳入配置管理只剩下构建脚本和专门用于验收测试的代...
  • hunthu2000
  • hunthu2000
  • 2004年03月01日 10:11
  • 591

集成与构建指南-概述

作者  胡协刚 目    录1            概述... 52            术语说明... 53            角色与职责... 64            集成环境... ...
  • hunthu2000
  • hunthu2000
  • 2004年03月01日 10:05
  • 880

集成与构建指南(8)

1          各类构件集成的实施方案1.1         第三方开发包的实施方案第三方开发包在使用时有如下特点:每个产品有各自不同的目录结构,组织的方式不统一,直接使用将增加引用和依赖关系的...
  • hunthu2000
  • hunthu2000
  • 2004年03月01日 10:11
  • 595

集成与构建指南(9)

1.1         项目构件的实施方案项目本身构件与第三方开发包不同,可以直接使用统一的目录结构,源码必须纳入配置管理,并且要进行细粒度的版本控制。针对上述特点,本项目对构件的源码结构组织如下图所...
  • hunthu2000
  • hunthu2000
  • 2004年03月01日 10:11
  • 578

集成与构建指南(7)

1          构件的集成原则1.1         生产者与消费者不同构件的开发者之间通常处于一种生产者与消费者的关系,即生产者交付工件提供给消费者使用。生产者交付的工件类型有:原始(Orig...
  • hunthu2000
  • hunthu2000
  • 2004年03月01日 10:11
  • 625

集成与构建指南(3)

4         集成环境为了将源码等中间工件编译、链接生成的一个建造(build),必须使用相应的编译工具;而实现构建的自动化,则需要类似make等构建工具的支持;实施持续集成还依赖CruiseC...
  • hunthu2000
  • hunthu2000
  • 2004年03月01日 10:10
  • 1035

集成与构建指南(2)

2        术语说明Ÿ         冒烟测试用于快速验证一个系统集成的工作版本被成功地构建的一组测试。它们必须是低成本的测试(比如自动化的测试),目标是保证一个相对稳定的、值得展开后续重量级...
  • hunthu2000
  • hunthu2000
  • 2004年03月01日 10:05
  • 912

集成与构建指南(4)

1          构建基础知识1.1         Ant构建脚本自动化构建的核心是表达构件间依赖关系和构建步骤的脚本,Make工具使用makefile,而Ant使用了基于XML格式的缺省文件名...
  • hunthu2000
  • hunthu2000
  • 2004年03月01日 10:10
  • 710

集成与构建指南(6)

1          集成构建基本流程1.1         概述在构建开始前,构架师应当确定项目初步的基本源码包组织结构,和包之间的依赖关系等,并定义项目统一的构建目录结构。构架师还应指导集成员制定...
  • hunthu2000
  • hunthu2000
  • 2004年03月01日 10:11
  • 1074
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:集成与构建指南(5)
举报原因:
原因补充:

(最多只允许输入30个字)