9. 測試替身

2018-02-23 16:23 更新

第 9 章?測試替身

Gerard Meszaros 在 [Meszaros2007] 中介紹了測試替身的概念:

有時候?qū)Ρ粶y系統(tǒng)(SUT)進行測試是很困難的,因為它依賴于其他無法在測試環(huán)境中使用的組件。這有可能是因為這些組件不可用,它們不會返回測試所需要的結(jié)果,或者執(zhí)行它們會有不良副作用。在其他情況下,我們的測試策略要求對被測系統(tǒng)的內(nèi)部行為有更多控制或更多可見性。
如果在編寫測試時無法使用(或選擇不使用)實際的依賴組件(DOC),可以用測試替身來代替。測試替身不需要和真正的依賴組件有完全一樣的的行為方式;他只需要提供和真正的組件同樣的 API 即可,這樣被測系統(tǒng)就會以為它是真正的組件!
--Gerard Meszaros

PHPUnit 提供的 getMockBuilder($type) 方法可以在測試中用來自動生成對象,此對象可以充當任意指定原版類型(接口或類名)的測試替身。在任何預(yù)期或要求使用原版類的實例對象的上下文中都可以使用這個測試替身對象來代替。

在默認情況下,原版類的所有方法都會被替換為只會返回 null 的偽實現(xiàn)(其中不會調(diào)用原版方法)。使用諸如 will($this->returnValue()) 之類的方法可以對這些偽實現(xiàn)在被調(diào)用時應(yīng)當返回什么值做出配置。

局限性:final、private、與 static 方法

請注意,final、privatestatic 方法無法對其進行上樁(stub)或模仿(mock)。PHPUnit 的測試替身功能將會忽略它們,并維持它們的原始行為。

警告

請關(guān)注一下這個事實:參數(shù)管理方式已經(jīng)修改過了。在之前的實現(xiàn)中,將會克隆對象的所有參數(shù)。這樣就無法檢查傳遞給方法的是否是同一個對象。Example?9.15, “測試某個方法將會被調(diào)用一次,并且以某個特定對象作為參數(shù)。” 展示了新的實現(xiàn)方式在什么情況下會非常有用。Example?9.16, “創(chuàng)建仿件對象時啟用參數(shù)克隆”展示了如何切換回之前的行為方式。

以上內(nèi)容是否對您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號
微信公眾號

編程獅公眾號