持續集成 .Net手冊--提高開發效率和質量

參考:http://blog.csdn.net/chelsea/article/details/132525

持續集成 .Net手冊

1、概念

Martin Fowler的文章:Continuous Integration  中文翻譯:持續集成html

2、工具

傳統工具:VisualStudio.Net,VisualSourceSafe,Rational ClearCaseweb

自動編譯工具:NAntNAntContribajax

迴歸測試工具:NUnit併發

代碼檢查工具:FxCop工具

持續集成工具:CruiseControl.Netpost

3、步驟

  • CruiseControl.Net監控遠程版本控制系統的變化測試

  • 變化發生時CruiseControl.Net調用編譯工具進行編譯(NAnt或VisualStudio.Net)網站

  • 編譯成功後調用NUnit進行迴歸測試ui

  • 編譯成功後調用FxCop進行代碼檢查編碼

  • 完畢後將編譯結果、測試結果、代碼檢查結果發送至開發人員、主管經理,併發布至網站

    圖示:

    

    全部這一切都是按照編制好的腳本自動進行的

4、實施示例

目前咱們使用的是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>

5、幾點提示

  • 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外部工具,推薦使用
  • 各類工具的安裝、使用,在各自的文檔裏都很是詳細,網上亦有無數資源

6、參考資料

相關文章
相關標籤/搜索