各種測試方法的問題
在 Exploratory Software Testig 一書中, James Whittaker在第二章中, 提到各種測試方法的不足:
Defect Preventation
從開發人員的角度來說, 他們希望藉由 design review, code review, static analysis tool, 和 unit test, 來增加軟體的質量.
但是作者覺得這些方法都有些根本的問題:
(1) 開發人員通常不是個好的測試人員
- 開發人員想的是"如何才能實現這個功能", 而測試人員則是從"如何才能攻破這個功能" 來思考.
- 因此開發人員會有盲點, 需要有另一組人從不同觀點來思考
- 但是不代表開發人員不用作測試, 像是 formatting, data validation 和 error handling 等等都需要及時處理和驗證. 等到測試人員發現, 時間會花得很長, 也修正的代價也很高
(2) 靜止狀態的程式不能完全代表真的測試目標
- 有很多錯誤是和執行環境有關係, 通常在開發環境這些錯誤不會發生的
(3) 缺乏客戶真正資料
- 有些錯誤是和客戶真實的資料有關, 或者需要實行一段時間後, 累積效果出現後才會有問題
- 可是開發人員通常沒有這些資料, 並且也沒有這麼長的測試時間, 所以無法找出這型別的錯誤
Defect Detection
通常分成手動測試和兩種:
自動化測試
- 測試人員不一定會是好的開發人員, 有些人可以, 有些人可能不行.
- 測試程式也是會有 bug, 一旦出現後, 測試人員需要更多時間來除錯, 維護它的正確性和強固性. 所以你要花在測試的時間多, 還是應該花在維護測試程式的時間多?
- 此外測試程式所在的執行環境, 以及所用的測試資料, 不是客戶的資料, 所以效果還是有限. 並且客戶可能也沒有勇氣, 讓你在他的 production 執行.
- Oracle Problem 的問題是最難處理的, 也就是當你執行完測試時, 你無法確認是否真的實行正確. 像是 install 完畢, 甚麼叫做 install 成功, 是所有 service 都啟動, 是所有檔案都複製完畢, 還是所有 registry 寫正確. 你可能無法列的出來, spec 也不會寫甚麼叫做功能運作正確.
手動測試
- 也是由人來進行測試, 需要充分發聰明才智, 設計出真實客戶環境的資料和使用狀況. 尤其是有關 business logic 更是需要人腦介入.
- 手動測試比自動化測試強的地方, 是因為現實狀況有太多不確定的因素, 有太多 scenario, 會導致測試程式設計師小的情況太多, 錯誤時都需要人腦介入, 一一來跟蹤.
- 可是手動測試很慢, 無法反覆使用, 測試步驟可能不一定有規律, 也不一定都能重複.
Defect Preventation
從開發人員的角度來說, 他們希望藉由 design review, code review, static analysis tool, 和 unit test, 來增加軟體的質量.
但是作者覺得這些方法都有些根本的問題:
(1) 開發人員通常不是個好的測試人員
- 開發人員想的是"如何才能實現這個功能", 而測試人員則是從"如何才能攻破這個功能" 來思考.
- 因此開發人員會有盲點, 需要有另一組人從不同觀點來思考
- 但是不代表開發人員不用作測試, 像是 formatting, data validation 和 error handling 等等都需要及時處理和驗證. 等到測試人員發現, 時間會花得很長, 也修正的代價也很高
(2) 靜止狀態的程式不能完全代表真的測試目標
- 有很多錯誤是和執行環境有關係, 通常在開發環境這些錯誤不會發生的
(3) 缺乏客戶真正資料
- 有些錯誤是和客戶真實的資料有關, 或者需要實行一段時間後, 累積效果出現後才會有問題
- 可是開發人員通常沒有這些資料, 並且也沒有這麼長的測試時間, 所以無法找出這型別的錯誤
Defect Detection
通常分成手動測試和兩種:
自動化測試
- 測試人員不一定會是好的開發人員, 有些人可以, 有些人可能不行.
- 測試程式也是會有 bug, 一旦出現後, 測試人員需要更多時間來除錯, 維護它的正確性和強固性. 所以你要花在測試的時間多, 還是應該花在維護測試程式的時間多?
- 此外測試程式所在的執行環境, 以及所用的測試資料, 不是客戶的資料, 所以效果還是有限. 並且客戶可能也沒有勇氣, 讓你在他的 production 執行.
- Oracle Problem 的問題是最難處理的, 也就是當你執行完測試時, 你無法確認是否真的實行正確. 像是 install 完畢, 甚麼叫做 install 成功, 是所有 service 都啟動, 是所有檔案都複製完畢, 還是所有 registry 寫正確. 你可能無法列的出來, spec 也不會寫甚麼叫做功能運作正確.
手動測試
- 也是由人來進行測試, 需要充分發聰明才智, 設計出真實客戶環境的資料和使用狀況. 尤其是有關 business logic 更是需要人腦介入.
- 手動測試比自動化測試強的地方, 是因為現實狀況有太多不確定的因素, 有太多 scenario, 會導致測試程式設計師小的情況太多, 錯誤時都需要人腦介入, 一一來跟蹤.
- 可是手動測試很慢, 無法反覆使用, 測試步驟可能不一定有規律, 也不一定都能重複.
本文轉自:
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/29379563/viewspace-1276693/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- javascript中的各種問題JavaScript
- RMQ問題的各種解法MQ
- 聊聊各種測試的區別
- Hadoop測試常見問題和測試方法Hadoop
- ArchLinux各種問題彙總Linux
- 更新macOS Monterey後遇到的各種Bug問題及解決方法Mac
- 交流學習SAP ERP的各種問題和方法,如何快速入行?
- 各種環境下的滲透測試
- 面試題裡的那些各種手寫面試題
- 關於各種揹包問題
- N皇后問題(各種優化)優化
- junit 測試中各種斷言用法
- 被騰訊問蒙的各種Redis複雜問題Redis
- 測試CMS同步問題測試CMS同步問題
- 測試方法的七種分類
- 測試架構師如何解讀測試平臺的各種爭議架構
- 一種新的UI測試方法:視覺感知測試UI視覺
- iOS面試問答集錦,從容應對各種面試技術難題!iOS面試
- 各種工具在軟體測試中的作用,值得收藏!
- 測試的薪資問題
- 測試MySQL鎖的問題MySql
- 幾種軟體測試方法
- 解決ASP.NET中的各種亂碼問題ASP.NET
- 測試面試問題(二)面試
- 完美解決jspdf各種中文亂碼問題JS
- 一文徹底搞懂面試中常問的各種“鎖”面試
- 解決Spring Boot測試方法Failed to load ApplicationContext問題Spring BootAIAPPContext
- 幾種常見的效能測試方法概述
- 非同步系統的兩種測試方法非同步
- Spring Boot 切面的一種的測試方法Spring Boot
- python中list的各種方法使用Python
- 測試跨域問題跨域
- python各種加解密方法Python解密
- 如何解決重要資料檔案各種問題?
- 面試題:水平垂直居中的17種方法面試題
- 軟體測試面試問題_介面測試(二)面試
- 測試伺服器頻寬的幾種方法伺服器
- 伺服器網路測試的幾種方法伺服器