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

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

  • <strong id="5koa6"></strong>
  • .NET中的TDD

    發表于:2011-11-23來源:未知作者:領測軟件測試網采編點擊數: 標簽:tdd
    TDD(Test-Driven Development)測試驅動開發,就是以測試用例來帶動開發,也就是先做測試用例,然后根據測試用例做開發。TDD的好外使是開發人員可以針對性的做開發,目標就是通過測試用例,當然,TDD更適合做邏輯的程序員,不適合更多的與UI開發相關的程序員。

      TDD(Test-Driven Development)測試驅動開發,就是以測試用例來帶動開發,也就是先做測試用例,然后根據測試用例開發。TDD的好外使是開發人員可以針對性的做開發,目標就是通過測試用例,當然,TDD更適合做邏輯的程序員,不適合更多的與UI開發相關的程序員。

      不管是TDD也好,傳統的開發也好,肯定要先做設計,設計展開后如果采用普通方法做開發,那就是開始寫代碼,然后單元測試,集成測試等工作。如果用TDD,那就要先從設計中把測試列表(其實就是要實現的功能,人機交互的條目羅列出來,形成一個列表)整理出來。然后就開始開發,在TDD中,“紅-綠-重構”的過程很多說明TDD的文章都要說到,本篇也不例外。

      有了測試列后,先拿出一個條目,進行測試的開發,開發完成運行,因為被測的程序還沒有編寫肯定是失敗的,然后實現程序,再測,可能還失敗,改成,測試成功,然后重構來優化代碼,再進入下一個測試條目的循環。

      在.net平臺下,怎么去實現呢?

      本例中用VS2010行進說明,設計部分,可以用vs2010的新功能Modeling,在Modeling里,可以畫類圖,還可以添加其中的成員,包括返回值類型,參數個數和類型,有了這些方法的簽名,對我們先構建測試就提供了依據,對測試程序來說,不關心實現的細節,只用知道參數是什么,返回是什么,拿上這個方法的返回值與給定的返回值作對比,從而來確定方法實現的功能是否正確。在Visual Studio中,可以很方便的來自動創建單元測試,這些方便要歸功于“反射”這個技術。當然,一般而然,測試不是只有一個數據,可能要一系列數據,或者更多的數據,在.net平臺下,也提供了相應的功能。

      下面來做個DEMO說明一下。

      先看一個類圖,也可以把類中的主要功能,當成一個個條目添加到測試列表中。

      我們選一個條目——GetRecord,參數是一個ID的整型,返回值是一個邏輯類型,本方法用來實現在一個庫中查詢輸入的ID,看是否存在。

      根據類圖,可以在類庫項目中生成一個類,如下

     

      1 public class DataOperate
      2     {
      3         public bool GetRecord(int id)
      4         {
      5             throw new Exception("沒有實ì現?");
      6         }
      7     }
      8

      接下來,可以繼于這個方法,來自動創建一個單元測試,右鍵方法,創建測試。

      一個測試的項目就會自動創建進來,在生成的CS文件中,重點看如下代碼(關于單元測試的其他知識可參照http://msdn.microsoft.com/zh-cn/library/ms182515(VS.80).aspx)

     

      1 [TestMethod()]
      2         public void GetRecordTest()
      3         {
      4             DataOperate target = new DataOperate();
      5             int id = 0;
      6             bool expected = false;
      7             bool actual;
      8             actual = target.GetRecord(id);
      9             Assert.AreEqual(expected, actual);
      10         }
      11

      在這里,測試的用例只有一個id=0,返回值為false,現在測試,肯定通不過,因為被測的方法還沒有實現。此時叫做“紅”。

      接下來就要實現GetRecord方法。

      新建一個類庫項目,然后添加一個LINQ To SQL的子項,把下表拖放進LINQ To SQL面板。

      數據表結構

      數據表中數據

      然后在類庫的CS文件中,添加入下代碼:

     

      1 public bool GetRecord(int id)
      2         {
      3             DataClasses1DataContext DCDC = new DataClasses1DataContext("server=.;database=mytestdb;uid=sa;pwd=sa;");
      4             if (DCDC.GetTable<Pic_Table>().Where(record=>record.ID ==id).Count() ==1)
      5             {
      6                 return true;
      7             }
      8             else
      9             {
      10                 return false;
      11             }
      12         }
      13

    原文轉自: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>