我們注意到的第一件事情是此類包含一個[TestFixture]屬性與之關聯(lián)-這是一種描述類包含測試代碼的方法(此屬性可以被繼承)。此類必須為public,并且對于其超類沒有任何限制。此類也必須有個一缺省的構造子。
此類包含一個的方法-TransferFunds,而且有一個[Test]屬性與之關聯(lián)-它標志了該方法是一個測試方法。測試方法必須返回void,并且不能帶有參數(shù)。在我們的測試方法中,我們對一個需要測試的對象進行了普通的初始化,執(zhí)行以測試的業(yè)務方法,并且檢查了業(yè)務對象的狀態(tài)。Assert類定義了一組方法,這些方法用來檢查前置條件,在我們的例子里,我們使用AreEqual方法保證在轉帳之后,2個帳戶都有正確的余額(本方法有許多重載方法,在本示例中的版本有如下參數(shù):第一個參數(shù)是一個期望值,第二個參數(shù)是實際值)。
編譯并運行此實例。假設你已經(jīng)將你的測試代碼編譯為一個bank.dll。啟動NUnit GUI(安裝文件會在桌面和“Program Files"上創(chuàng)建一個快捷方式)。在GUI啟動之后,選擇File->Open菜單,并指向bank.dll所在的路徑,在”Open“對話框打開選擇該文件。當bank.dll文件加載之后,你 會在左邊的面板上看到一個測試樹形結構 ,在右邊會有一組狀態(tài)。點擊Run按鈕,狀態(tài)條以及測試樹的TransferFunds節(jié)點會變紅-我們的測試失敗了。”Error and Failures"面板顯示如下信息:
TransferFunds : expected <250> but was <150>
而且,棧跟蹤面板會報告測試代碼中的失敗之處:
at bank.AccountTest.TransferFunds() in C: unitBankSampleTestsAccountTest.cs:line 17
這正是我們期望的:測試失敗是因為我們并沒有實現(xiàn)TransferFunds方法,F(xiàn)在我們讓它工作吧。不要關閉此GUI,返回你的IDE并修復此代碼,讓你的TransferFunds方法如下:
public void TransferFunds(Account destination, float amount)
{
destination.Deposit(amount);
Withdraw(amount);
}
現(xiàn)在,重新編譯代碼,再一次點擊GUI上的按鈕-狀態(tài)條以及測試樹變綠了。(注意GUI是如何為您重新加載程序集的;我們會一直打開GUI,并在IDE中繼續(xù)編寫代碼,寫出更多的測試)。
讓我們在Account代碼里加入一些錯誤的檢查。我們?yōu)閹艏尤胄〉挠囝~,保證銀行可以繼續(xù)讓他們的錢可以支付小額度的透支。在Account類里增加一個小余額的屬性:
private float minimumBalance = 10.00F;
public float MinimumBalance
{
get{ return minimumBalance;}
}
我們使用一個異常來描繪一個透支:
namespace bank
{
using System;
public class InsufficientFundsException : ApplicationException
{
}
}
在AccountTest類里加入一個新的方法:
[Test]
[ExpectedException(typeof(InsufficientFundsException))]
public void TransferWithInsufficientFunds()
{
Account source = new Account();
source.Deposit(200.00F);
Account destination = new Account();
destination.Deposit(150.00F);
source.TransferFunds(destination, 300.00F);
}