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

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

  • <strong id="5koa6"></strong>
    • 軟件測試技術
    • 軟件測試博客
    • 軟件測試視頻
    • 開源軟件測試技術
    • 軟件測試論壇
    • 軟件測試沙龍
    • 軟件測試資料下載
    • 軟件測試雜志
    • 軟件測試人才招聘
      暫時沒有公告

    字號: | 推薦給好友 上一篇 | 下一篇

    單元測試小技巧[4]

    發布: 2010-6-01 11:36 | 作者: 不詳 | 來源: 領測測試網采編 | 查看: 37次 | 進入軟件測試論壇討論

    領測軟件測試網

      單元測試小技巧[4]   軟件測試 

        在一個單獨單元測試中避免多重聲明

      我們將聲明故障看作一個程序弊病的象征且聲明被當作軟件體的指示點或者“血液檢查”。你可以找到越多的癥狀,程序弊病就越可以輕松的被診斷和排除掉。如果你在一個測試中定義了多重聲明,只有第一個故障聲明將會以拋出異常的方式顯示出來。請參考下面插圖之中的測試代碼:

      <TestMethod()> _
      Public Sub Sum_AnyParamBiggerThan1000IsNotSummed()
          Assert.AreEqual(3, Sum(1001, 1, 2)
          Assert.AreEqual(3, Sum(1, 1001, 2) ' Assert fails
          Assert.AreEqual(3, Sum(1, 2, 1001) ' This line never executes
      End Sub

      你可能沒有發現以上代碼之中其他可能的征兆。在一個故障之后,并發的聲明不會被執行。這些不能生效的聲明可能提供了有價值的數據(或者征兆)可能能夠幫助你很快的集中的焦點而且發現潛在的問題。因此在一個獨立的測試中運行多重聲明增加了具有很少價值復雜性。另外,聲明應該被獨立的運行,我們應該設置自我獨立的單元測試以使得你具有能夠很好的發現錯誤的機會。

      創建易讀性測試

      如果你以前寫過單元測試,你是否在單元測試上寫了一個好的聲明行?可許不是這樣的,大多數開發者并不厭煩去寫一個好的聲明因為他們更加關心去寫測試。

      假設你是團隊中的一個新的開發者,你試圖讀一個單元測試。連接這個:

      <TestMethod()> _
      Public Sub TestCalcParseNegative()
          Dim c As New Calc
          Assert.AreEqual(1000, c.Parse("-1, -1000")
      End Sub

      作為一個簡單的練習,如果你理解了上例中Calc分列方法的用法,你很可能可以進行很好的推測,但是他可以簡單的作為人員數量的用例使得輸出結果為1000:

      • 在組中返回最大的負數作為一個正數。

      • 如果數字是負數且返回值為剩下幾個數的總和作為一個正數,那么忽略第一個數字。

      • 返回相互作乘積運算而得的數字。

      現在請參考下面在單元測試之中的小改動:

      <TestMethod()> _
      Public Sub Parse_NegativeFirstNum_ReturnsSumOfTheRestAsPositive()
          Dim c As New Calc
          Dim parsedSumResult As Integer = c.Parse("-1", "-1000")
          Const SUM_WITH_IGNORED_FIRST_NUM As Integer = 1000
          Assert.AreEqual(SUM_WITH_IGNORED_FIRST_NUM, parsedSumResult)
      End Sub

      這個是不是比較容易理解呢?當聲明消息消失之后,表達意圖最合適的地方就是測試的名字。 如果你廣泛的使用了它,你將會發現你不再需要讀測試代碼就能明白代碼測試的目的所在。事實上,你經常根本不需要寫任何注釋,因為代碼,特別是那些帶著實例的,他們自己是證明自己的。

      名字包含了三部分內容: 測試下方法的名字(解析),測試下的狀態或者規則(帶著第一個負數傳遞一個字符串),以及預期的輸出或者運行情況(剩余數字的總和以一個正數的形式返回)。需要注意的是我從名稱中將Test以及Calc這兩個詞刪除。我已經知道這是一個屬性的測試因此在此沒有重復此信息的必要。我也知道這是一個在Calc類中的測試因為測試類經常是寫給一個特殊類的(這個類也許已經被命名為CalcTests)。

      名字也許會很長,但是又有誰在乎呢?它讀起來更像是一個標準英語的句子而且它使得一個新來的開發者更容易明白測試的內容。更是這樣,當這個測試發生故障時,我們甚至不需要調試代碼就可以知道問題究竟出在哪里。

    延伸閱讀

    文章來源于領測軟件測試網 http://www.kjueaiud.com/

    TAG: 單元 技巧


    關于領測軟件測試網 | 領測軟件測試網合作伙伴 | 廣告服務 | 投稿指南 | 聯系我們 | 網站地圖 | 友情鏈接
    版權所有(C) 2003-2010 TestAge(領測軟件測試網)|領測國際科技(北京)有限公司|軟件測試工程師培訓網 All Rights Reserved
    北京市海淀區中關村南大街9號北京理工科技大廈1402室 京ICP備10010545號-5
    技術支持和業務聯系:info@testage.com.cn 電話:010-51297073

    軟件測試 | 領測國際ISTQBISTQB官網TMMiTMMi認證國際軟件測試工程師認證領測軟件測試網

    老湿亚洲永久精品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>