持续集成 .Net手册
2004-10-11 18:15
281 查看
持续集成 .Net手册
一、概念
Martin Fowler的文章:Continuous Integration 中文翻译:持续集成二、工具
传统工具:VisualStudio.Net,VisualSourceSafe,Rational ClearCase自动编译工具:NAnt,NAntContrib
回归测试工具:NUnit
代码检查工具:FxCop
持续集成工具:CruiseControl.Net
三、步骤
CruiseControl.Net监控远程版本控制系统的变化变化发生时CruiseControl.Net调用编译工具进行编译(NAnt或VisualStudio.Net)
编译成功后调用NUnit进行回归测试
编译成功后调用FxCop进行代码检查
完毕后将编译结果、测试结果、代码检查结果发送至开发人员、主管经理,并发布至网站
图示:
![](http://www.cnblogs.com/images/cnblogs_com/coolbug/image002.gif)
所有这一切都是按照编制好的脚本自动进行的
四、实施示例
目前我们使用的是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外部工具,推荐使用
各种工具的安装、使用,在各自的文档里都非常详细,网上亦有无数资源
六、参考资料
DailyBuild全攻略Draco.Net
持续集成 Java手册
相关文章推荐
- 持续集成 .Net手册
- 持续集成 .Net手册
- 持续集成 .Net手册--提升开发效率和质量
- 持续集成 .Net手册
- 自动化持续集成编译 配置 CruiseControl.Net SVN
- 自动化持续集成编译 配置 CruiseControl.Net SVN
- 自动化持续集成编译 配置 CruiseControl.Net SVN
- 转载:CruiseControl.Net持续集成平台搭建总结
- 持续集成:CruiseControl.NET + VisualSVN.Server
- (转)持续化集成工具CruiseControl.NET
- 基于GO的windows环境下net项目的持续集成demo--安装、配置
- 使用CruiseControl.Net全面实现持续集成
- ASP.NET Core + Docker + Jenkins + gogs + CentOS 从零开始搭建持续集成
- 持续集成工具CruiseControl.net对软件项目过程的改善
- ASP.NET Core+Docker+Jenkins实现持续集成的完整实例
- 数据库开发的持续集成 - CruiseControl.Net的项目配置
- CruiseControl.Net持续集成平台搭建总结
- Jenkins持续集成 & .NET
- 持续集成好工具CruiseControl.Net
- 持续集成 Java手册