<ruby id="rxdll"></ruby><strike id="rxdll"></strike>

    <rp id="rxdll"></rp>
      <del id="rxdll"><meter id="rxdll"></meter></del>
      <pre id="rxdll"><font id="rxdll"></font></pre>
        <pre id="rxdll"></pre>
      <p id="rxdll"><thead id="rxdll"></thead></p><dl id="rxdll"><progress id="rxdll"><form id="rxdll"></form></progress></dl>

      <ol id="rxdll"><thead id="rxdll"><track id="rxdll"></track></thead></ol>
      <i id="rxdll"><dfn id="rxdll"></dfn></i>
      <font id="rxdll"><meter id="rxdll"></meter></font>

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

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

        Mock Objects:缺點和用例

        發布: 2009-4-13 09:42 | 作者: 不詳 | 來源: 測試時代采編 | 查看: 52次 | 進入軟件測試論壇討論

        領測軟件測試網  編寫單元測試代碼是一件很困難的工作。大多數情況下,我們需要測試那些以前沒有編寫過的使用復雜的協作軟件(如數據庫,應用程序服務器或軟件模塊)的代碼。我們可能還需要處理一些難以在測試環境下生成的條件。建立這些依賴關系可能需要相當長的時間,這抵消了其自動測試方面的優勢。本文將著重介紹Mock Objects——來自XP社區的一項測試技術(XP社區提供了一種獨立的代碼測試,這種測試是通過模擬外部依賴來實現的)。和使用任何其它工具一樣,我們要謹慎,防止濫用。

        Mock Objects概述
                近些年來,開發人員又重新發現了自己編寫測試代碼的好處。他們認同,發現并修改軟件中的錯誤所付出的代價是昂貴的。結果,Unit Testing作為查找代碼錯誤和幫助確定系統需求的方法,成為了軟件開發流程中不可或缺的一部分。單元測試的主要目標是獨立地對每一個工作單元(通常是一個類)進行測試。獨立代碼測試是一件困難的工作,尤其是難以在測試中快速建立依賴關系的情況下。編寫和維護單元測試代碼的難度越大,開發人員就越容易失去信心,并停止編寫測試代碼。
                Tim Mackinnon、Steve Freeman和Philip Craig在他們的文章“Endo-Testing: Unit Testing with Mock Objects”中對Mock對象的基本概念進行了介紹,這篇文章發表在XP2000上。Mock對象(或Mock)模擬代價昂貴且難以使用的協作軟件,并提供了一種方法用于:

        在測試環境中建立復雜的依賴關系(例如,模擬數據庫連接,代替真正的數據庫連接)
        驗證測試行為是否符合期望結果(例如,驗證JDBC連接在使用結束后關閉——也就是在特定時刻調用java.sql.Connection中的close方法)
        模擬難以生成的環境條件(例如,模擬JDBC驅動程序拋出的SQLException類)。
        雖然很有用,但Mock并不是萬能的,濫用Mock所帶來的壞處將會大于它為項目帶來的好處。

        Mock的缺點
        Mock程序員需要注意以下幾個問題。

        Mock可能會隱藏集成問題

                尤其是,如果我們只使用Mock進行代碼測試,而不編寫集成測試,則這種情況很可能發生。

        請考慮圖1中的例子。

        圖1 將新員工信息存儲于數據庫中

                EmployeeBO類提供了與Employees有關的業務服務,并使用EmployeeDAO通過JDBC將數據持久存儲在關系數據庫中。測試EmployeeBO意味著建立一個數據庫,并用它來存儲數據。

                Mock對象的支持者認為,通過模擬EmployeeDAO,我們可以節約相當多的時間和精力,避免了建立和使用真實數據庫的開銷。Mock可以有效地加快單元測試的創建和執行過程,但是它們不能保證系統作為一個整體能夠正常運行。Mock可能會隱藏所模擬的協作軟件中的錯誤和缺陷。為了找到那些缺陷,我們需要在測試套件中包含集成測試。在本例中,測試系統使用數據庫存儲員工信息。Mock測試只能驗證EmployeeBO與EmployeeDAO 之間的交互是正確的——也就是說,EmployeeBO 僅僅在適宜時間從EmployeeBO 調用期望的方法。只有集成測試才能幫助我們發現問題,比如JDBC驅動程序和數據庫本身的bug,這些bug在應用程序走向產品時不應存在。

        Mock為測試代碼帶來混亂和重復

                下面的代碼使用 EasyMock 測試:EmployeeBO用EmployeeDAO存儲新員工信息和更新當前員工信息。

        @Before public void setUp() {
        mockEmployeeDAO = createMock(EmployeeDAO.class);
        employeeBO = new EmployeeBO(mockEmployeeDAO);
        employee = new Employee("Alex", "CA", "US");
        }

        延伸閱讀

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

        TAG: Mock MOCK mock Objects 缺點

        21/212>

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

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

        国产女主播精品_国产片婬乱18一级毛片视频_国产午夜激无码av毛片不卡_国产精品欧美久久久天天影院
          <ruby id="rxdll"></ruby><strike id="rxdll"></strike>

          <rp id="rxdll"></rp>
            <del id="rxdll"><meter id="rxdll"></meter></del>
            <pre id="rxdll"><font id="rxdll"></font></pre>
              <pre id="rxdll"></pre>
            <p id="rxdll"><thead id="rxdll"></thead></p><dl id="rxdll"><progress id="rxdll"><form id="rxdll"></form></progress></dl>

            <ol id="rxdll"><thead id="rxdll"><track id="rxdll"></track></thead></ol>
            <i id="rxdll"><dfn id="rxdll"></dfn></i>
            <font id="rxdll"><meter id="rxdll"></meter></font>

              <mark id="rxdll"><dfn id="rxdll"></dfn></mark>