1. 程式人生 > >VS2010單元測試入門例項一

VS2010單元測試入門例項一

VS2010中的單元測試

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

備註:當使用excel儲存為csv檔案的時候,要另存為,而不是直接改檔名,否則會出現錯誤@!!文章中用到的程式碼和圖片有時間再新增。

1、建立單元測試專案

1.1、從被測試程式碼生成單元測試

1)例項:建立VC#模式下的控制檯應用程式,工程名為UnitTest2


2)輸入簡單的加、減、乘、除函式程式碼,如下:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

namespace UnitTest2
{
    class Program
    {
        static void Main(string[] args)
        {

        }
        public int Add(int a, int b)
        {
            return a + b;
        }
        public int Dec(int a, int b)
        {
            return a - b;
        }
        public int Mul(int a, int b)
        {
            return a * b;
        }
        public int Div(int a, int b)
        {
            return a / b;
        }
    }
}

 

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

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


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


3)點選確定後,在新建測試專案中,輸入需要建立的單元測試的新專案的名稱,然後單擊“建立”按鈕,則自動建立一個新的單元測試程式碼專案。

4)在“解決檔案資源管理器”中可以看到多了一個“AddTest”專案,可以看出“AddTest”專案引用了被測專案的程式集,和單元測試框架Microsoft.VisualStudio.QualityTools.UnitTestFrame,並且自動產生兩個C#

程式碼檔案AssemblyInfo.csProgramTest.cs

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

6ProgramTest.cs程式碼檔案詳講

[TestMethod()]:說明了以下程式碼是一個測試用例

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

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

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

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

double actual;

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

Assert.AreEqual(expected, actual);

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

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

我們新增的測試用例如下:在ProgramTest.cs檔案中補充如下內容

        /// <summary>
        ///Add 的測試
        ///</summary>
        [TestMethod()]
        public void AddTest()
        {
            Program target = new Program(); // TODO: 初始化為適當的值
            int a = 3; // TODO: 初始化為適當的值
            int b = 4; // TODO: 初始化為適當的值
            int expected = 7; // TODO: 初始化為適當的值
            int actual;
            actual = target.Add(a, b);
            Assert.AreEqual(expected, actual);
           // Assert.Inconclusive("驗證此測試方法的正確性。");
        }
在測試檢視中,右擊--執行選定內容

結果如下:

在上圖中右擊,可以檢視程式碼覆蓋率和檢視測試結果詳細資訊,如下圖:

1.2、新增單元測試專案

1)另外一種單元測試方法是獨立新增單元測試專案,在解決方案中新增一個新的專案,選擇專案型別為“測試專案”,

2)單擊確定後,自動產生一個新的單元測試專案,在“解決方案資源管理器”中可看到新新增的測試專案“TestProject2”。對比“TestProject2”和“AddTest”可發現,“TestProject2”少了對被測試專案程式集的引用,僅僅引用了單元測試框架的DLLMicrosoft.VisualStudio.QualityTools.UnitTestFrame”

2、編寫測試方法

單元測試的基本方法是呼叫被測程式碼的函式,輸入函式的引數值,獲取返回結果,然後與預期測試結果進行比較,如果相等則認為測試通過,否則認為測試不通過。

1Assert類的使用

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

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

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

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

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

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

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

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

2CollectionAssert類的使用

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

StringAssert類的使用

用於比較字串。

StringAssert.Contains

StringAssert.Matches

StringAssert.tartWith

3、資料驅動的單元測試

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

3.1ACCESS資料驅動單元測試

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

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

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

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

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

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

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

7)資料來源的使用

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

8Acess資料來源中的表為

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()]在執行完每個測試後執行程式碼

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