您的位置:軟件測試 > 開源軟件測試 > 開源單元測試工具 > Nunit
Nunit中如何進行事務性單元測試
作者:網絡轉載 發(fā)布時間:[ 2013/4/2 15:55:04 ] 推薦標簽:

單元測試要求:單元測試方法并不真正去變更數據庫,也是說單元測試不依賴于數據庫中的數據。那我們如何解決執(zhí)行單元測試方法后,不變更數據庫中數據呢?

一般的解決方案有兩種:

1、 新建一個單元測試數據庫,開發(fā)數據庫與單元測試數據庫分離,單元測試方法完全基于單元測試數據庫。

此中方法的優(yōu)點是:,開發(fā)人員在開發(fā)期間不會對單元測試數據庫中數據進行變更,也不會影響單元測試方法 在任何時間執(zhí)行。

缺點:單元測試數據庫和開發(fā)數據庫同步問題,特別是對迭代式開發(fā)項目,數據庫是根據需求在不斷地跟進或者變更,同步問題成為了單元測試正常運行的瓶頸。

2、 使用事務對單元測試方法的執(zhí)行進行回滾。

此種方法的優(yōu)點:解決了方法一中缺點,不會出現數據庫結構不同步的問題。

缺點:在進行CRUD(Create/Read/Update/Delete)操作時,需要在單元測試方法中進行一些插入數據操作,從而保證單元測試與開發(fā)數據庫的獨立,造成了單元測試工作量增加。

在實際的項目中,可以根據需要選擇符合自己的解決方案,如果數據庫結構在項目進入開發(fā)階段已經確定,并且以后不會有變動,建議采用第一種方案,否則建議第二種方案。目前我們項目采用第二中方案。
一、NUnit事務性單元測試

那使用Nunit框架如果保證數據的會滾呢?這里我們使用了COM+事務。

即System.EnterpriseServices;

具體如下:

/// <summary>

    ///單元測試基類,所有單元測試類都需要繼承此類

    /// </summary>

    [TestFixture]

    [Transaction(TransactionOption.Required)]

    public class DatabaseFixture:ServicedComponent

    {

        public DatabaseFixture()

        {

            //

            // TODO: Add constructor logic here

            //

        }

        [TearDown]

        public void TransactionTearDown()

        {

            if (ContextUtil.IsInTransaction)

            {

                ContextUtil.SetAbort();

            }

        }

所有的單元測試方法都需要繼承與此類。比如:

public class AddressSqlDAOTest : DatabaseFixture

這樣,單元測試方法執(zhí)行完后,會繼續(xù)執(zhí)行DatabaseFixture類中的TransactionTearDown()方法。從而會滾之前的數據操作,單元測試方法也不會影響開發(fā)數據庫,同樣開發(fā)數據庫也不會影響單元測試方法的執(zhí)行,從而保證了單元測試與數據庫數據的獨立。

 
二、如何CRUD單元測試

1、測試增加方法:判斷返回的主鍵是否>0,如果主鍵>0 說明單元測試方法成功,否則失敗

2、測試查詢方法:首先在執(zhí)行單元測試類中的插入數據方法(不是被測試類中的插入方法,而是在單元測試類中寫的插入方法,一定要區(qū)分開),然后執(zhí)行查詢方法。

3、測試更新方法:首先在執(zhí)行單元測試類中的插入數據方法,然后執(zhí)行更新方法。

4、測試刪除方法:首先在執(zhí)行單元測試類中的插入數據方法,然后執(zhí)行刪除方法。

 
三、單元測試的命名規(guī)范

為了便于后期單元測試方法的維護,建議如下命名單元測試類 和單元測試方法。

單元測試類名:被測試類名稱+Test

單元測試方法名:被測試方法名稱+Test
 

四、總結

至此,大家可以利用Nunit中如何進行事務性單元測試已經完畢,相信大家也已經了解了如何讓單元測試獨立于數據庫數據,從而更高效地進行單元測試,也不影響開發(fā)。

軟件測試工具 | 聯(lián)系我們 | 投訴建議 | 誠聘英才 | 申請使用列表 | 網站地圖
滬ICP備07036474 2003-2017 版權所有 上海澤眾軟件科技有限公司 Shanghai ZeZhong Software Co.,Ltd