做研究没頭緒,來聊聊新的興趣~
最近常常很高興的和別人說
「你知道嗎?我轉QA了,在做自動測試喔~」
最通常的反應是:
「你用rational嗎? 還是 mercury?」
次常的反應是:
「UI一直變動,不是自動測試改起來很痛苦嗎?」
(還有人覺得很奇怪,啊網頁測試不就點來點去而已…(我踢~~~))
其實對於自動測試的偏執,有大部份的緣由是來自對Iterative 開發的相信。Iterative 開發解答了需求變更的及降低技術風險的問題,但的確帶來新的疑問
「那測試呢?」
如果你是用人工測試,很好,每次新的release 出來,不但要測試新功能,舊功能也要一併測- 加新功能的時候應該沒有一個工程師敢掛保證舊功能不會掛吧? (好吧,至少我不敢…) ,如果你對外宣稱要支援IE6.0, IE7.0, FF2.0,還有safari...喔喔,那變成所有功能要測四次,因為很讓人沒力的是,每種瀏覽器run 起javascript 和css就是同中求異,異中求同,除了乖乖測之外也沒有其它的方法呀~ 全部都用人工,這太慘了(也太累(笨?)了)。
所以自動測試(for acceptance test)對於長期的、Iterative 的開發是必要的。市面上的工具也蠻多,不過我依照個人的偏好,選了selenium當我的戰友。雖然說是偏好,但其實是有幾個重要的理由。個人(真的是個人)覺得,一個好的,用來做 acceptance 的自動測試工具應該要有下列特點:
(1)Ease of Use
通常測試人員花比較少的時間碰code,所以他們對頁面的dom結構不會太熟,此時可能需要一些工具的幫忙,如firefox 的dom inspector, XPather,甚至是可以錄製的工具試錄一小段,幫助測試人員降低一些門檻
(2)Compatible
Must be compatible with browsers you want your software to support. Crystal Clear.
(3)Programmable
因為你的要測的軟體會變(而且有可能是大變)。所以你的腳本一定要能夠跟著改(而且要用十分少的時間成本跟上)。而改…如果指的是重新再錄一次,那也不必了,因為每個Iteration都有可能改,可能你錄完都到下一個Iteration去了,來不及測試是也。一個有效、能跟上軟體進化的測試腳本,應該是高度模組化的東西,當程式的某一個模組改了,你對應相對的模組即可跟上去。所以,個人的感覺是這些腳本要像程式一樣,可以refactor,可以有架構,也就是說,它要能用programming 的方式drive.
第三點也同時帶出一個新問題,那如果要測試的軟體本身就沒有架構(所謂前端的架構)可言,怎麼辦?其實我也不知道,因為沒有經驗過。不過以本人的直覺來看,應該會測不下去吧,至少是蠻痛苦的或會沒有效率。
目前也只是個開頭,不知道以這樣的測試方法來做能否真的有好的助益(早期發現大bug 啦…提高品質啦…等等),需要後續的努力和驗證才能見分曉囉。
2 則留言:
很棒的嘗試,請多提供實際的使用經驗呀…!
你好很少聽到有人提到test automation. 小弟是專門做software testing,目前主攻agile testing, test automation, performance test, 歡迎一起來交流
http://www.wretch.cc/blog/kojenchieh
張貼留言