這兩天重看了一篇 OO design for testability (Miško Hevery) 的前 15 分鐘,又有新的領悟。
本來我覺得整個 talk 的重點是在於四個常見的錯誤不要犯,重新讀一次之後,我覺得重點是更抽象的設計原則:
設計 OO 的程式的時候,要把 class 分成兩大類:
(1) 一類是 Object Graph Contruction & Lookup ,比方 Factory ,它會有 new operator。
(2) 一類是 Business Logic ,它會有 conditionals 和 loop
依照這種方式設計,如果要測試 Business Logic 的時候,就可以透過 test unit ,重新 wire 一些 fake 的物件去測試 Business Logic 。
而如果要測試 Factory object ,也可以獨立於 business logic 來做測試。
可以測試的程式應該要有性質是:你可以單單只依賴整套軟體組裝起來的方式,就控制軟體的控制流 (You can control the path flow of your software purely by the way the application is wired together.)
於是又提到了一個專有名詞
Seam
A seam is a place where you can alter behavior in your program without editing it in that place.
跟 Seam 相關的另一個詞是
enabling point
Every seam has an enabling point, a place where your can make a decision to use one behavior or another.
Object Seam
附帶一提,我後來針對 seam 去查資料,發現 seam 出自一本書 WELC。在 Working Effectively with Legacy Code 裡,除了作者最建議的 Object seam 之外,作者還介紹了其它兩種 seam:
preprocessing seam 和 link seam 。
object seam 的 enabling point 是「
我們生成待測物件的位置」
link seam 在 Java 可以透過
classpath 環境變數做為 enabling point 。原文對 link seam 的描述:
The enabling point for a link seam is always outside the program text. Sometimes it is in a build or a deployment script. This makes the use of link seams somewhat hard to notice.
preprocessing seam 的 enabling point 則是
preprocessor define 語法
參考資料:
(1)
Testing Effectively With Legacy Code
(2)
How to use link seams in CommonJS(3)
Seams in Javascript