切尔斯基

http://liguanglei.name
  博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理

持续集成 .Net手册

Posted on 2005-12-24 23:53  chelsea  阅读(849)  评论(0编辑  收藏  举报
 

持续集成 .Net手册

一、概念

Martin Fowler的文章:Continuous Integration  中文翻译:持续集成

二、工具

传统工具:VisualStudio.Net,VisualSourceSafe,Rational ClearCase

自动编译工具:NAntNAntContrib

回归测试工具:NUnit

代码检查工具:FxCop

持续集成工具:CruiseControl.Net

三、步骤

  • CruiseControl.Net监控远程版本控制系统的变化

  • 变化发生时CruiseControl.Net调用编译工具进行编译(NAnt或VisualStudio.Net)

  • 编译成功后调用NUnit进行回归测试

  • 编译成功后调用FxCop进行代码检查

  • 完毕后将编译结果、测试结果、代码检查结果发送至开发人员、主管经理,并发布至网站

    图示:

   

    所有这一切都是按照编制好的脚本自动进行的

四、实施示例

目前我们使用的是ClearCase

主控软件为CruiseControl.Net,其脚本文件为ccnet.config

  • 配置远程版本控制系统

- <sourcecontrol type="clearCase">
  <viewPath>D:\cc_view\USE_TECH_DEPT\Platform\Nucleus\2产品开发\2实现\Nucleus1.0\Source</viewPath>
  <useLabel>false</useLabel>
  </sourcecontrol>
  • 配置编译工具

- <build type="nant">
  <executable>F:\software\Agile.Net\nant-0.85-nightly\bin\nant.exe</executable>
  <baseDirectory>F:\software\Agile.Net\nant-0.85-nightly\bin</baseDirectory>
  <buildFile>Y:\nucleus.build</buildFile>
  <logger>NAnt.Core.XmlLogger</logger>
- <targetList>
  <target>build</target>
  <target>fxcop</target>
  </targetList>
  </build>
  • 配置测试用例

- <tasks>
- <nunit>
  <path>D:\Program Files\NUnit 2.2\bin\nunit-console.exe</path>
- <assemblies>
  <assembly>Y:\NewPDObject\TestNewPDObject\bin\Debug\TestNewPDObject.exe</assembly>
  </assemblies>
  </nunit>
  </tasks>
  • 配置报告形式
<publishers>
- <xmllogger>
  <logDir>..\web\log</logDir>
- <mergeFiles>
  <file>Y:\nucleus.xml</file>
  </mergeFiles>
  </xmllogger>
- <email from="ajaxchelsea@163.com" mailhost="163.com" includeDetails="TRUE">
  <projectUrl>http://ajaxchelsea/ccnetweb</projectUrl>
- <users>
  <user name="BuildGuru" group="buildmaster" address="ajaxchelsea@163.com" />
  <user name="chelsea" group="developers" address="chelsea@chelseafc.com" />
  <user name="ajax" group="developers" address="ajax@ajaxfc.com" />
  </users>
- <groups>
  <group name="developers" notification="always" />
  <group name="buildmaster" notification="always" />
  </groups>
  </email>
  </publishers>
  • 其中CruiseControl.Net没有提供代码检查工具FxCop的支持,其文档建议使用NAnt的<exec>任务来调用FxCop,直到出现<fxcop>的Task,因此,需要配置NAnt的脚本文件:
- <target name="fxcop" depends="build">
  <exec program="D:\Program Files\Microsoft FxCop 1.30\fxcopcmd.exe" commandline="/p:Y:\nucleus.fxcop /o:Y:\nucleus.xml" failonerror="false" />
  </target>

五、几点提示

  • CruiseControl.Net会自动根据本地ClearCase的View监控远程VOB
  • 其实除了监控远程版本控制系统外其它的任务都可以由NAnt来完成,CCNet只负责监控变化并调用NAnt即可
  • 可以直接为CCNet配置VisualStudio.Net解决方案"<build type="devenv" solutionfile="D:\dev\MyProject\MyProject.sln" configuration="debug" /> ",但这样就无法配置FxCop了,至少目前如此;
  • ccnetservice.exe.config中有一句“<add key="ccnet.config" value="C:\Downloads\TestData\ccnet.config" /> ”应该是配置ccnet.config的路径,但现在好像不管用,还得将ccnet.config放在server目录下 
  • 最好避免中文路径,否则就需要手工为几个Xml格式的文件,如.csproj等加入编码方式“<?xml version="1.0" encoding="UTF-8" ?>,或者将中文路径映射为虚拟硬盘:“subst Y: "D:\cc_view\USE_TECH_DEPT\Platform\Nucleus\2产品开发\2实现\Nucleus1.0\Source"”
  • NUnit有VisualStudio.Net插件NUnitAddin,FxCop等亦可以配置为VisualStudio外部工具,推荐使用
  • 各种工具的安装、使用,在各自的文档里都非常详细,网上亦有无数资源

六、参考资料