qileilove

          blog已經轉移至github,大家請訪問 http://qaseven.github.io/

          軟件測試金字塔

          軟件測試金字塔

           在敏捷方法中,持續集成是其基石,持續集成的核心是自動化測試。下面這篇關于測試金字塔的文章,來自大師Martin Fowler。

            測試金字塔的概念來自Mike Cohn,在他的書Succeeding With Agile中有詳細描述:測試金字塔最底層是單元測試,然后是業務邏輯測試,最后是端到端的測試(GUI或CLI)。

            在我的職業生涯中,很多次聽到過自動化測試,自動化測試意味著端到端的通過界面完成的測試。完成這種自動化測試的工具一般是錄制然后回放,初始使用很容易,不需要任何編碼技能。

            不過你使用一段時間后就會遇到很多麻煩,GUI的自動化測試運行速度都很慢導致版本發布速度下降,同時完成自動化測試的軟件,一般都是商業軟件需要license因此只能在特定的機器上部署,且不容易通過腳本集成。

            GUI測試用例還很脆弱,如對系統的一些修正可能導致很多用例的失敗,這時候你需要重新錄制。你可以放棄錄制的方法來解決這個問題,通過寫GUI測試代碼,但是這樣效率非常低。就算你已經很精通了GUI測試代碼的編寫,端到端的GUI測試用例也很容易出現不可預期結果的問題-一些用例成功一些用例失敗,因此,基于GUI的自動化測試是脆弱、耗時(包括用例維護和執行)的。所以測試金字塔要表達的是:底層應當有更多的單元測試和接口測試和邏輯測試,GUI測試用例能覆蓋到主業務流程即可。

            我們注意到測試金字塔中間這一層:服務。業務服務的測試,我稱其為皮下測試,因為這一層就在用戶界面GUI下面。服務測試可以完成很多端到端的功能測試而不需要像GUI自動化測試那樣需要使用復雜的框架。如一個Web應用,你可能使用自己寫的腳本測試端到端的邏輯,而GUI自動化你可能會使用Selenium這個工具。

            測試金字塔發源與敏捷測試實踐,使用測試金字塔原則很容易將你項目中的測試用例達到平衡的狀態。在很多項目中都混淆了“端到端測試”,“UI測試”,“面向用戶的測試”的概念,其實他們都是測試的不同角度。例如你有一個javascript開發的應用,那UI部分就需要用javascript的單元測試工具Jasmine完成大部分的UI功能測試;復雜的業務邏輯需要使用面向用戶的表單(form)來測試,而不僅僅是底層的單元測試。

            因此我通常將上層的測試稱為“測試的第二防線”,如果你的一個上層測試用例執行失敗,表現出來不僅僅是這個功能有問題,還說明你遺漏了這個地方的單元測試,因此你在修復功能之后,還需要補充相關的單元測試用例。

          posted on 2012-12-19 12:31 順其自然EVO 閱讀(452) 評論(0)  編輯  收藏 所屬分類: 測試學習專欄

          <2012年12月>
          2526272829301
          2345678
          9101112131415
          16171819202122
          23242526272829
          303112345

          導航

          統計

          常用鏈接

          留言簿(55)

          隨筆分類

          隨筆檔案

          文章分類

          文章檔案

          搜索

          最新評論

          閱讀排行榜

          評論排行榜

          主站蜘蛛池模板: 双牌县| 凤庆县| 林甸县| 炉霍县| 竹山县| 内乡县| 大洼县| 怀远县| 澄江县| 巴彦县| 金华市| 长丰县| 宜章县| 威海市| 汉中市| 汾西县| 通州市| 大名县| 和硕县| 西安市| 兴山县| 望奎县| 元朗区| 德州市| 寻甸| 万源市| 武鸣县| 肥城市| 察雅县| 睢宁县| 衡南县| 西宁市| 高碑店市| 沙坪坝区| 永昌县| 尚义县| 金溪县| 濮阳县| 泸溪县| 东乡族自治县| 峨眉山市|