【喬樑】用Nant和Nunit構建C#專案
以前沒使用Nant和Nunit建立過C#程式碼的自動化構建,今天自己寫了一個C#程式,想用Nant和Nunit構建C#程式碼。可寫好build檔案後執行UnitTest時遇到了麻煩。命令列提示如下:
查了一下資料解決了這個問題。
解決方法是:
一、在該程式的config檔案(如果程式名是money.dll,則該檔名為money.dll.config)中加入如下程式碼:
xml version="1.0" encoding="utf-8" ?>
<configuration>
<runtime>
<assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
<dependentAssembly>
<assemblyIdentity name="nunit.framework" publicKeyToken="96d09a1eb7f44a77" culture="Neutral" />
<bindingRedirect oldVersion="2.0.6.0" newVersion="2.4.3.0" />
<bindingRedirect oldVersion="2.1.4.0" newVersion="2.4.3.0" />
dependentAssembly>
assemblyBinding>
runtime>
configuration>
二、使用VS2005提供的gacutil把nant.core.dll 和 nant.framework.dll註冊一下。具體做法是:
1、在window開始選單用執行VS所帶的Visual Studio 2005 Command Prompt。
2、切換到nunit的bin目錄下
3、順序執行下列命令
gacutil /i nunit.core.dll // 註冊core

gacutil /i nunit.framework.dll //註冊framework

gacutil /l //檢視是否註冊上
三、大功告成。
現在執行 nant unittest 就完事大吉。
附 nant 的 build 檔案如下:
xml version="1.0"?>
<project name="CSharpMoney" default="ut">
<property name="output.dir" value="../bin" />
<property name="output.dll" value="../bin/cs-money.dll" />
<property name="reports.dir" value="../reports"/>
<target name="clean">
<delete dir="${output.dir}"/>
<delete dir="${reports.dir}"/>
target>
<target name="copyfile" depends="clean">
<mkdir dir="${output.dir}" unless="${directory::exists(output.dir)}" />
<copy file="../nunit/bin/nunit.framework.dll" todir="${output.dir}"
if="${file::exists('nunit/bin/nunit.framework.dll')}" />
target>
<target name="build" depends="copyfile">
<csc target="library" output="${output.dll}" debug="true">
<sources>
<include name="*.cs" />
sources>
<references>
<include name="../nunit/bin/nunit.framework.dll" />
references>
csc>
target>
<target name="ut" depends="build">
<mkdir dir="${reports.dir}"/>
<exec program="..NUnit unit-console.exe">
<arg value="${output.dll}"/>
<arg value="/config=cs-money.dll.config"/>
<arg value="/xml=${reports.dir}TestReport-Unit.xml"/>
<arg value="/nologo"/>
<arg value="/noshadow"/>
exec>
target>
project>
Could not load file or assembly 'nunit.framework, Version=2.4.3.0, Culture=neutral, PublicKeyToken=96d09a1eb7f44a77' or one of its dependencies. The system cannot find the file specified.
查了一下資料解決了這個問題。
解決方法是:
一、在該程式的config檔案(如果程式名是money.dll,則該檔名為money.dll.config)中加入如下程式碼:












二、使用VS2005提供的gacutil把nant.core.dll 和 nant.framework.dll註冊一下。具體做法是:
1、在window開始選單用執行VS所帶的Visual Studio 2005 Command Prompt。
2、切換到nunit的bin目錄下
3、順序執行下列命令





三、大功告成。
現在執行 nant unittest 就完事大吉。
附 nant 的 build 檔案如下:



































來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/12639172/viewspace-364792/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 喬樑專訪——讓持續交付變為可能
- 你竟然沒用 Maven 構建專案?Maven
- 用Idea 2019.3+和Gradle5.2.1+ 構建SpringBoot多專案(二)IdeaGradleSpring Boot
- 用mobx構建大型專案的最佳實踐
- Gradle之多專案構建Gradle
- JAVA專案映象構建Java
- Gradle構建SpringBoot專案GradleSpring Boot
- CMAKE 《window構建專案》
- webpack快速構建專案Web
- Maven 構建 Java 專案MavenJava
- 用mobx構建大型專案的最佳實踐(2)
- Makefile 專案構建最佳化原理與應用
- 【CuteJavaScript】Angular6入門專案(1.構建專案和建立路由)JavaScriptAngular路由
- 如何構建「大型 Node.js 專案」的專案結構?Node.js
- 使用Maven構建Java專案MavenJava
- 使用gradle構建springboot專案GradleSpring Boot
- 2. vite 構建專案Vite
- 使用Dockerfile構建django專案DockerDjango
- SpringBoot淺析——專案構建Spring Boot
- 【CuteJavaScript】Angular6入門專案(2.構建專案頁面和元件)JavaScriptAngular元件
- Vue(1):用Vue-cli構建Vue3專案Vue
- 構建dubbo分散式平臺-maven構建根專案分散式Maven
- 小白學習Vue(11)--環境安裝及專案構建 | webstorm構建vue專案VueWebORM
- 有手就行5——jenkins專案構建型別(pipeline流水線專案構建推薦)Jenkins型別
- 使用 webpack 構建小程式專案Web
- 如何構建大型的前端專案前端
- gulp構建es6專案
- Gradle快速構建Spring Boot專案GradleSpring Boot
- vue-cli構建vue專案Vue
- 如何使用Webpack工具構建專案Web
- 如何使用Docker構建前端專案Docker前端
- jenkins構建go及java專案JenkinsGoJava
- 在gradle中構建java專案GradleJava
- Jenkins 2.32.3引數化構建maven專案-java專案JenkinsMavenJava
- ABAP system landscape和vue專案webpack構建的最佳實踐VueWeb
- 使用 happypack 提升 Webpack 專案構建速度APPWeb
- webpack+nodejs+npm構建前端專案WebNodeJSNPM前端
- Gradle學習系列----多專案構建Gradle
- 首次使用ideal構建maven專案webIdeaMavenWeb