相信大家對于“免疫”這個詞都不會感到陌生,拿農業(yè)來講,第一次用農藥來消滅害蟲,效果很客觀,但是重復使用,效果就會變得越來越差,這是因為害蟲身上出現了免疫性。在軟件測試中,測試免疫也是真實存在的,重復使用同一批用例進行測試,能測試出來的bug
變得越來越少,很多bug都被遺漏了。
因為軟件是在不斷進化的,新的bug也在不斷產生,同樣一批用例,只能發(fā)現會引起已覆蓋功能衰退的regression bug。很多新bug對這批用例是有免疫力的,這便是“測試免疫”。測試免疫我們一定不能忽視,要及時想辦法解決,那么究竟該怎樣應對呢?
1. 需要不斷更新測試策略
測試策略是一個動態(tài)的過程,應該隨時根據情況進行調整,例如哪個模塊風險比較大,就將策略往這個方向傾斜。測試類型大大小小至少有100多種,在制定測試策略時,可以考慮多樣化,組合型的測試策略,例如自動化測試+探索測試,從而對癥下藥,實現優(yōu)勢互補。
在軟件測試中有這樣一個說法“三分開發(fā),七分維護”,測試用例是一個長期維護的過程,需要及時的查漏補缺,跟蹤遺漏出去的bug打上補丁。我們要密切注意跟蹤軟件的變化,提前預測這些變化可能給用戶場景帶來的影響必要時還要及時新增測試用例進行覆蓋,做好以不變應萬變的準備。
通俗的來講,測試免疫是一種客觀存在的規(guī)律,只有不斷更新測試策略和測試用例,才能有效彌補用例有效性的損失,切記不能無動于衷。