CruiseControl step by step(2)

上一篇文章中,我们已经看到CruiseControl开始工作了。接下来我们先了解一个它的配置文件,然后再加入你的项目。
CruiseControl的配置文件的确了比较复杂,一方面是因为:它太灵活,太想完成你想达到的任何效果了。另一方面就是:它在文档化方面的确很落后。你只能在用户组中找答案。(不过,这也是学习的一个途径。如果你了解开源的话,你就会习惯于在用户组中找答案啦。)


再了解配置文件之前,让我们先定义一下我们可能会用到的术语。

  1. 工作目录(也就是CruiseControl的工作目录):是指启动CruiseControl的脚本目录。在Stand-alone情况下,就是文件cruisecontrol.bat所在的目录。如果你把它部署到了应用服务器中,那一般就指bin目录了。

       2.  Log 目录:就是CruiseControl存储所有构建项目日志信息的目录,默认值为工作目录下名为logs目录。
       3. Projects目录:就是CruiseControl存储所有构建项目源代码的目录,默认值为工作目录下名为projects目录。

一、配置文件及其正确位置

      配置文件包括两个,一个名为config.xml,另一个名为dashboard-config.xml。默认情况下,这两个文件和cruisecontrol.bat在同一下目录下,即工作目录
     如果在配置文件中,任何路径前面如果没有“/”的话,那就是相对于工作目录的。
   
     
      另外,CruiseControl是可以改变他们的位置的,但建议在没有深入了解CruiseControl时,不要试图改变它们,因为我们的目标是让CruiseControl在最短的时间里为你创建价值。

二、Config.xml 文件

< cruisecontrol >
    
< project  name ="connectfour" >  --这里的name应该和你在projects目录下的项目名完全一致。

        
< listeners >          --用于监听项目状态的变化(指building,passed等)
            
< currentbuildstatuslistener  file ="logs/${project.name}/status.txt" />   --这里的${project.name}
        
</ listeners >                                                                                                                 是指“connectfour”

        
< bootstrappers >        --用于CruiseControl从Repository更新代码
            
< svnbootstrapper  localWorkingCopy ="projects/${project.name}"   />
        
</ bootstrappers >

        
< modificationset  quietperiod ="30" >      --用于监听在quietperiod 秒内 Repository 是否变化
            
< svn  localWorkingCopy ="projects/${project.name}" />
        
</ modificationset >

        
< schedule  interval ="300" >   --用于每隔 interval 秒, CruiseControl去检查并计划一次构建
            
<ant anthome="apache-ant-1.7.0" buildfile="projects/${project.name}/build.xml"/>
        
</schedule>

        
<log>  --用于得到并保存log文件。默认情况下,将放在projects/${project.name}的目录下
            
<merge dir="projects/${project.name}/target/test-results"/> --用于将Build中生成的结果合并
        
</log>                                                                                                            到log文件中

        
<publishers>  --用于将构建的结果(如二进制文件)发布到指定的位置
            
<onsuccess>  --决定在构建成功的情况下,发布哪些内容
                
<artifactspublisher dest="artifacts/${project.name}" file="projects/${project.name}/target/${project.name}.jar"/>
            
</onsuccess>
        
</publishers>

    
</project>
</cruisecontrol>


三、dashboard-config.xml

<? xml version="1.0" encoding="UTF-8" ?>
<!--
/********************************************************************************
 这里省略了一些声明 :)
 ********************************************************************************/
 
-->
 
< dashboard >
     
< buildloop
        
logsdir =""         --这里指定logs目录,一定要与config.xml文件中一致,否则你会有麻烦。
                                                如果为空串,则默认为工作目录下的logs目录。
              artifactsdir
=""   />   --这里指定 artifacts 目录,一定要与config.xml文件中一致
                                                   
如果为空串,则默认为工作目录下的artifacts目录。
     < features  allowforcebuild ="" />  --是否可以在Dashboard上强制构建(force build)
    
< trackingtool  projectname =""  baseurl =""  keywords ="" />  --这是用于与Mingle的集成
     
< subtabs >   --在这里,你可以自己扩展你自己的subtab页,不过要先实现一些接口。
        
< subtab  class ="net.sourceforge.cruisecontrol.dashboard.widgets.ErrorsAndWarningsMessagesWidget"   />
    
</ subtabs >
</ dashboard >


四、配置文件中的注意事项
 

1、如果logs、artifacts和projects目录不存在,在你运行CruiseControl之前,要手工建立它们。
2、确保两个配置文件中的logs/artifacts目录指向同一个目录。因为CruiseControl core会向其中写数据,而Dashboard会从中读数据。

五、小贴士

在Config.xml文件中,有几个元素的概念要先澄清一下(只针对当前示例,严格定义请参见CruiseControl的文档)。

  1. <listeners> 用于监听状态变化,如waiting for build,queued,building。一般不用改变。
  2. <bootstrappers>用于检出代码,CruiseControl有很多种bootstrapper,示例中使用的是SVN。localWorkingCopy属性是指你把代码检出到安装CruiseControl机器的哪个文件目录。
  3. <modificationset>用于监听Repository的变化频率,如果CruiseControl发现代码有变化,而且在quietperiod秒内没有其它用户检入代码(用于保证被构建的版本完整性),CruiseControl才会检出代码。
  4. <schedule >用于指定CruiseControl去检查Repository的时间间隔。并指定使用哪个构建文件。示例中使用的是ant脚本,构建文件是被检出项目的根目录下的build.xml(即在Repository中)。
  5. <log>用于指定CruiseControl把日志放在哪里,把哪些构建结果放在日志中。如果没有指定任何属性,默认为logs目录下的${project.name}目录。
  6. <publishers> 用于在构建结束后,发布哪些消息和文件。CruiseControl有很多插件可以做各种各样的Publishing。例如,在构建成功后,通过http调用指定的页面,也可以给指定的人发邮件。在失败时,播放音乐,通知team。

猜你喜欢

转载自liming495.iteye.com/blog/1866365