自動測試成為你Java項目中的一部分了嗎?你最愛的測試框架是什么?使用的又是哪一種標(biāo)準(zhǔn)?
本文的4名開發(fā)者將和你一起分享他們在自動測試領(lǐng)域中的觀點和經(jīng)驗。當(dāng)你的項目面臨測試階段的時候,希望這些觀點能對你有所幫助。我們真摯的希望我們能夠為這個領(lǐng)域中新手提供一些有用建議和標(biāo)準(zhǔn)。
文章最后列出了文章的作者和提到的測試框架。
論自動測試
——Tom Wheeler
當(dāng)我給那些有經(jīng)驗的開發(fā)者上課時,我發(fā)現(xiàn)只有40%左右的人寫測試。大約還有40%的人甚至從來沒聽說過JUnit,這其中更有一般人完全沒有單元測試的概念。開發(fā)者通常處于在項目經(jīng)理制定的緊促計劃的壓力中——而那些項目經(jīng)理同樣處于客戶的壓力之下,客戶希望他們的軟件能夠被快速的開發(fā)出。不幸的是,測試是項目中的一個重要部分而很多人卻輕易的將它砍掉。真是目光短淺,那種做法只會讓你的應(yīng)用成為bug的樂園而且會大大超出你的計劃時間。
為什么會這樣?因為寫自動測試實際上省下了大量的運行時間。每個開發(fā)者都會出錯而通過測試可以幫助找到這些錯誤??赡苁止y試在某些方面要比自動測試更快一些,但是手工測試需要用戶界面。手工測試的結(jié)果并不一致,因為測試者和開發(fā)者一樣都會犯錯。而一個自動測試總會保持結(jié)果的一致性。
也許更重要的是,當(dāng)一個舊bug被修復(fù)或者新特性被添加時會引入更多的bug。你需要在改變系統(tǒng)后重新運行所有的測試。這也是自動測試的價值體現(xiàn),因為對比手工測試的開銷,自動測試的開銷是微不足道的。如果開發(fā)者經(jīng)常測試,他們可以更容易地發(fā)現(xiàn)并修改問題,這可以保證代碼質(zhì)量并保證團隊開發(fā)的進度。
比較JUnit和TestNG
——Meera Subbraro
Martin Fowler曾說過,軟件開發(fā)領(lǐng)域中此前從沒有過這樣的事情:很少幾行代碼對大量的代碼起了如此重要的作用。JUnit過去直到如今依然是單元測試的一個標(biāo)準(zhǔn)。它是最流行的開源工具。當(dāng)然現(xiàn)在我們有許多有別于JUnit的其他的開源工具。我自己,除了使用JUnit外,我還是用TestNG。下面我們來談?wù)勏逻@兩個框架。
JUnit和TestNG都使用Annotation,都使得測試簡單有趣。如果你寫兩個測試類,一個使用JUnit一個使用TestNG,除非你看到它們import語句,否則你幾乎看不到他們之間的差別。
如果你是一個TDD的信徒,通過運行測試來完成你的持續(xù)集成過程。TestNG可能更加適合。重新運行失敗的測試這樣的機制對于每天都進行編譯來說非常有幫助。而這個特性只有TestNG才有。
TestNG的另一個亮點是支持參數(shù)化。在JUnit中如果你要測試不同的參數(shù),你需要寫不同的測試用例來覆蓋不同參數(shù)。而在TestNG,通過使用xml配置文件做到。開發(fā)者可能會抱怨XML文件”這下好了,除了要維護那些測試用例,我還要維護那么一堆xml文件”。(譯者按:JUnit4也已經(jīng)支持參數(shù)化測試了)
JUnit生成的HTML格式的報告非常好。我使用TestNG和Java 6,生成的報告遠沒有JUnit那么漂亮。
最后,兩個框架都有自己的長處和弱處,必要時我們可以同時使用。讓我們使用這兩個偉大的框架,享受編寫測試的快樂吧。
我為什么從JUnit換到了TestNG上
——Andres Almiray
當(dāng)我開始編寫測試程序時候,我選擇了JUnit3.x。因為那個時候它是唯一的開源選擇,而且有著相當(dāng)詳盡的文檔和成堆的書供我參考。在此基礎(chǔ)上還有許多擴展如dbUnit,xmlUnit幫助測試一些大型組件。但是如果我們需要面對更多復(fù)雜的測試,通常是集成/功能測試,很明顯JUnit會力不從心。那就是為什么我換到TestNG上。Cedric和Alexandru TestNG的作者從一開始就很明確,TestNG是為更廣的測試場合而設(shè)計,而不僅是單元測試。TestNG可以運行沒有修改過的JUnit測試,這使得兩者的轉(zhuǎn)換非常平滑。
稍后發(fā)布的JUnit4.x在細節(jié)上非常類似TestNG,這也彌補了這兩個框架的裂痕。TestNG仍然是我最喜歡的,而且它仍然保持更新。現(xiàn)在在開源的Java測試框架中仍然有新進者,easyb,一個基于Groovy行為驅(qū)動開發(fā)的測試工具,為Java和Groovy測試。通過編寫合理的測試或是假定一個任務(wù),它可以視為一種規(guī)范盡管它是可執(zhí)行代碼。如果你在Ruby世界中使用Rspec一樣。
為什么JUnit仍然是首選
——Aslam Khan
像許多人開始測試驅(qū)動開發(fā)和單元測試一樣,我也是從JUnit3.x起步的。我發(fā)現(xiàn)JUnit是最廣泛的工具,出現(xiàn)在各種不同的地方(ANT,Maven,Eclipse,IntelliJ IDEA, 等)。它也很容易介紹給那些新團隊。我也使用TestNG對它的多樣性同樣印象深刻。然而,JUnit的大量插件(dbUnit,xmlUnit等)使得Junit仍然是首選的。如果你花大量的時間在Spring上,那么基于Junit的Srping ApplicationContext aware測試用例會帶來優(yōu)勢。為了測試前臺,我?guī)缀踔皇褂肧elenium。我曾經(jīng)涉足過Canoo和其他的框架,但是發(fā)現(xiàn)這些途徑都是反TDD模式的。使用Selenium,我可以處理Selenium測試腳本和記錄,給任何需要的人并日后處理。
如果我們談?wù)摰氖羌兇獾腡DD,即書寫良好的代碼(不僅僅是良好的