• <ruby id="5koa6"></ruby>
    <ruby id="5koa6"><option id="5koa6"><thead id="5koa6"></thead></option></ruby>

    <progress id="5koa6"></progress>

  • <strong id="5koa6"></strong>
  •   Nunit中如何進行事務性單元測試

    發表于:2009-12-18來源:作者:點擊數: 標簽:
    Nunit中如何進行事務性單元測試 單元測試代碼 單元測試要求: 單元測試方法 并不真正去變更 數據庫 ,也就是說單元測試不依賴于數據庫中的數據。那我們如何解決執行單元測試方法后,不變更數據庫中數據呢? 一般的 解決方案 有兩種: 1、 新建一個單元測試數

      Nunit中如何進行事務性單元測試  單元測試代碼

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

      一般的解決方案有兩種:

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

      此中方法的優點是:,開發人員在開發期間不會對單元測試數據庫中數據進行變更,也就不會影響單元測試方法 在任何時間執行。

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

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

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

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

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

      一、NUnit事務性單元測試

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

      即System.EnterpriseServices;

      具體如下:

      ///

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

      ///

      [TestFixture]

      [Transaction(TransactionOption.Required)]

      public class DatabaseFixture:ServicedComponent

      {

      public DatabaseFixture()

      {

      //

      // TODO: Add constructor logic here

      //

      }

      [TearDown]

    原文轉自:http://www.kjueaiud.com

    老湿亚洲永久精品ww47香蕉图片_日韩欧美中文字幕北美法律_国产AV永久无码天堂影院_久久婷婷综合色丁香五月

  • <ruby id="5koa6"></ruby>
    <ruby id="5koa6"><option id="5koa6"><thead id="5koa6"></thead></option></ruby>

    <progress id="5koa6"></progress>

  • <strong id="5koa6"></strong>