[轉]VS2010中的C#單元測試

來源:互聯網
上載者:User

標籤:blog   http   io   ar   os   使用   sp   檔案   資料   

在VS2010中,單元測試的功能很強大,使得建立單元測試和編寫單元測試代碼,以及管理和運行單元測試都變得簡單起來,通過私人訪問器可以對私人方法也能進行單元測試,並且支援資料驅動的單元測試。

1、建立單元測試項目1.1、從被測試代碼產生單元測試

1)執行個體:建立VC#模式下的控制台應用程式,工程名為CUnitTest

2)輸入簡單的加、減、乘、除函數代碼,如所示

3)可按如下步驟建立單元測試

    (1)在Add方法體內,單擊滑鼠右鍵,在菜單中選擇"建立單元測試",

(2)在出現的"建立單元測試"介面中,Add方法被自動勾上,表示要為這個方法建立單元測試代碼的基本架構,單擊確定按鈕

(3)點擊確定後,在建立測試專案中,輸入需要建立的單元測試的新項目的名稱,然後單擊"建立"按鈕,則自動建立一個新的單元測試代碼項目。

(4)在"解決檔案資源管理員"中可以看到多了一個"AddTest"項目,可以看出"AddTest"項目引用了被測項目的程式集,和單元測試架構Microsoft.VisualStudio.QualityTools.UnitTestFrame,並且自動產生兩個C#代碼檔案AssemblyInfo.cs和ProgramTest.cs

(5)ProgramTest.cs的代碼如所示,可以看到,自動產生了一個"ProgramTest"類,並使用[TestClass()]標識為一個單元測試類,以及一個"AddTest"測試方法,。並用[TestMethod()]標識。

(6)ProgramTest.cs代碼檔案詳講

[TestMethod()]:說明了以下代碼是一個測試案例

Int a = o; // TODO: 初始化為適當的值

int b = 0; // TODO: 初始化為適當的值

這兩句是被測函數的輸入參數,需要我們去修改它的值,也就是我們輸入測試案例的地方。

double expected = 0; // TODO: 初始化為適當的值

double actual;

      這兩句話淺顯易懂,前一句話是定義了期望值和對它進行初始化,後一句話是定義了實際值。預設

Assert.AreEqual(expected, actual);

Assert在這裡可以理解成斷言:在VSTS裡做單元測試是基於斷言的測試。

預設代碼中Assert.Inconclusive 表明這是一個未經驗證的單元測試。在實際的程式中可以注釋掉。

1.2、添加單元測試項目

(1)另外一種單元測試方法是獨立添加單元測試項目,在解決方案中添加一個新的項目,選擇項目類型為"測試專案",

(2)單擊確定後,自動產生一個新的單元測試項目,在"方案總管"中可看到新添加的測試專案"TestProject2"。對比"TestProject2"和"AddTest"可發現,"TestProject2"少了對被測試專案程式集的引用,僅僅引用了單元測試架構的DLL"Microsoft.VisualStudio.QualityTools.UnitTestFrame"

 

2、編寫測試方法

單元測試的基本方法是調用被測代碼的函數,輸入函數的參數值,擷取返回結果,然後與預期測試結果進行比較,如果相等則認為測試通過,否則認為測試不通過。

1、Assert類的使用

Assert.Inconclusive()    表示一個未驗證的測試;

Assert.AreEqual()         測試指定的值是否相等,如果相等,則測試通過;

AreSame()            用於驗證指定的兩個物件變數是指向相同的對象,否則認為是錯誤

AreNotSame()        用於驗證指定的兩個物件變數是指向不同的對象,否則認為是錯誤

Assert.IsTrue()              測試指定的條件是否為True,如果為True,則測試通過;

Assert.IsFalse()             測試指定的條件是否為False,如果為False,則測試通過;

Assert.IsNull()               測試指定的對象是否為空白引用,如果為空白,則測試通過;

Assert.IsNotNull()          測試指定的對象是否為非空,如果不為空白,則測試通過;

2、CollectionAssert類的使用

用於驗證對象集合是否滿足條件

StringAssert類的使用

用於比較字串。

StringAssert.Contains

StringAssert.Matches

StringAssert.tartWith

 

3、資料驅動的單元測試

資料驅動的單元測試是指單元測試的輸入資料遍曆一個資料來源的所有行。從資料來源的沒一行讀入資料並傳入給測試方法使用

3.1、ACCESS資料驅動單元測試

1)開啟測試檢閱視窗,選擇測試檢視

2)在測試檢閱視窗中選擇需要配置成資料驅動方式的單元測試方法,然後按F4,開啟單元測試的屬性視窗

3)編輯"資料連線字串"屬性,在"屬性"視窗中單擊該屬性,然後單擊省略符號 (…)。這將開啟"選擇資料來源"對話方塊,其中列出了若干個可能的資料來源,包括 ODBC、Microsoft SQL Server 和 Microsoft Access。選擇一個資料來源後將開啟一個特定於該資料來源類型的對話方塊;可以使用此對話方塊配置該資料來源的串連屬性。配置完資料連線後,連接字串會作為"資料連線字串"的值出現。此字串還會作為單元測試方法的一個屬性儲存區起來

4)在這個介面中,選擇一個Acess表data.mdb,單擊"確定"按鈕完成設定,回到"單元測試屬性"視窗。可以看到資料來源的已經設定好。

5)在建立與資料來源的串連之後,可以選擇一個資料表。當您單擊"屬性"視窗的值列中的下拉式清單時,將會列出所串連的資料庫中的表。從此列表中選擇的表就是在運行單元測試時將檢索其中的行的表。與"資料連線字串"等其他屬性一樣,"資料表名稱"也會作為單元測試方法的一個屬性儲存區起來。

6)在"資料存取方法",請選擇"順序"或"隨機";預設值為"順序"。此設定表示從資料來源的表中檢索記錄的順序。

    可以看到,在測試方法前面已經添加了一行:

7)資料來源的使用

通過 TestContext 類的 DataRow 和 DataConnection 屬性將資料提供給正在啟動並執行單元測試。下面為使用TestContext 類的 DataRow屬性來讀入資料行

8)Acess資料來源中的表為

3.2、讀取Excel的方法:

1)在案頭建立一個txt檔案,變更檔名為data.dsn

2)選中"資料庫連接字串",單擊右邊列的按鈕,更改資料來源為Microsoft ODBC資料來源,點擊"確定"按鈕

3)選擇使用連接字串,點擊產生

4)選擇Excel資料來源的驅動程式,點擊"下一步"

5)選擇data.dsn為資料來源儲存檔案,一直選擇"下一步"。

6)在彈出的選擇活頁簿中,選擇用例的輸入檔案data.txt,點擊"確定"

7)選擇用例所在的Sheet頁,選擇"完成"

8)資料來源的使用代碼

4、單元測試的運行

單元測試的運行有兩種方式:調試和運行。可以像調試普通代碼一樣對單元測試代碼進行調試,當然也可以直接運行,單元測試的結果將在"測試結果"介面中展示,雙擊測試結果,可以得到測試結果的詳細資料。單元測試的程式碼涵蓋範圍可以在"程式碼涵蓋範圍結果"介面中展示。

5、附加測試屬性

"附加測試屬性"。預設都是被注釋掉的,只要我們取消注釋就可以使用了。這個功能的加入,很大程度上是為了增加測試的靈活性。具體的屬性有:

[ClassInitialize()]在運行類的第一個測試前先運行代碼

[ClassCleanup()]在運行完類中的所有測試後再運行代碼

[TestInitialize()]在運行每個測試前先運行代碼

[TestCleanup()]在運行完每個測試後運行代碼

如在執行測試時,將測試執行時間輸入到日誌中,代碼如下

[轉]VS2010中的C#單元測試

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.