Jester 由 Ivan Moore 編寫,它是測試由程序員和開發人員編寫的單元測試的工具。該工具基于這樣一個假設:代碼中的很多區域包含了條件語句、循環語句和 case 語句,并且在一些代碼區域中,類的圈復雜度(cyclomatic complexity)由于存在很多執行路徑而會突然增加。Jester 主要關注的是類似這樣的代碼。但是要運行它,必須使用指向各個資源的格式良好的類路徑。
Grester 是針對 Jester 的 Apache Maven 包裝器,它減輕了從項目依賴關系構造 Java™ 類路徑之類的麻煩,這樣您可以使用 Jester 更輕松地測試執行點。Grester 還增強了使用 Maven 的一些優點,Maven 是其基礎架構的核心。在對沒有使用測試驅動方式編寫的代碼進行額外檢查時,Jester 尤為有用。此類代碼可以是舊式應用程序中的遺留代碼,甚至還可以是近編寫的代碼,這些代碼的開發人員認為使用 Agile 的測試驅動方法指導構建高質量代碼來說難度較大。
實際上,您可以使用 Grester 來突破使用非測試驅動方式編寫代碼的限制。根據我的經驗,范圍蔓延(scope creep)和可能錯失或繞過實際業務函數的代碼將會增加錯誤數和惡意代碼 數量(快速處理 blob 反模式,即使在很小的代碼段中,都不必作為單個難于管理的模塊或模塊集)。
本文不會探討解釋 Jester 的輸出及精確說明 Jester 如何工作的技術細節。要獲得這些信息,請參閱 參考資料 中由 Elliott Rusty Harold 撰寫的文章,或者訪問 Ivan Moore 的 Web 站點。本文旨在探討獲取并圍繞 Jester 使用 Maven 插件包裝器。
獲取 Grester
您可以通過兩個來源之一獲取 Grester,它們都列在 參考資料 中。運行 Grester 所需的基礎設施非常少:您只需要使用 Maven 能構建和使用 Grester。Grester 是用 Groovy 編寫的,Groovy 是一種動態語言,它的語法類似于 Java 并且擁有 Python 和 Ruby 等語言的優點。Grester 本質上只是用于快速運行 Jester 工具的另一個 Maven 插件,因此 Grester 的真正威力來自 Jester。在本文中,結合使用了 Jester V1.37 與 Grester V0.3 alpha 發行版。
Jester 打破常規:為什么呢?
如果所有項目 Java Archive (JAR) 依賴關系都位于一個位置,那么直接運行 Jester 不可能比在 Java 類路徑條目中引用單個路徑更簡單。但是,當依賴關系散布到整個文件系統中時,每次 Jester 運行的配置問題會十分復雜而討厭,尤其是在各個依賴關系隨時間改變位置時。使用 Maven 將顯著簡化此過程。
Jester 運行在 Maven 項目構建配置以外的每個實例中。那么,Grester 的特別之處在哪里?答案在于 Maven 組織其依賴關系的方式。這種 “安排” 非常高效,Maven 不但嘗試把 Java(或 Groovy)JAR 和 Web 歸檔 (WAR) 的查找方式標準化,而且還嘗試把保存方式標準化。
Linux 和 UNIX 用戶注意
Grester 的文件大小非常小,并且在解壓縮后,您可以放心地刪除目前的壓縮歸檔。這里是在 Windows 計算機中使用 Cygwin 來說明解壓縮它是多么簡單 —— 甚至在模擬的 Linux 環境中也一樣。但是,不建議用早于 Grester 0.3 的版本在 Linux 或 UNIX 系統上試驗,因為雖然 Windows alpha 版本非常穩定,但是缺少一些操作系統功能。不過,在所有版本中,都使用 Jester V1.37。
安裝 Grester
獲取 TAR 壓縮資源(.tar 文件和 tar.gz 文件適用于 UNIX® 和 Linux®)或者 Microsoft® Windows® ZIP 文件后,請將其解壓縮。有很多種方法可以完成此操作:在這里,我使用 Windows 中的 Cygwin 實用程序。
圖 1. 用 Windows 中的 Cygwin 實用程序解壓縮 Grester
您還可以將 TAR 實用程序與 xzvf 選項結合使用來解壓縮 tar.gz 文件,或者與 xvf 選項結合使用來解壓縮普通 .tar 文件。圖 2 給出了該過程的示例。
圖 2. 用 TAR 實用程序解壓縮 Grester tar.gz 文件
終的目錄結構應當類似于圖 3。
圖 3. 在 Windows 中解壓縮的 Grester
配置、構建和安裝 Grester
此時,您已經準備好讓 Maven 知道可以從哪個外部系統庫獲得相關 Grester Groovy 依賴關系,從而在本地把 Grester 編譯和安裝成 Maven 插件。您可以通過把兩個遠程系統庫添加到 $MAVEN_HOME/conf/settings.xml 文件中來完成此操作,如下所示: