您的位置:軟件測試 > 開源軟件測試 > 開源單元測試工具 >
對Ajax應(yīng)用程序進(jìn)行單元測試
作者:網(wǎng)絡(luò)轉(zhuǎn)載 發(fā)布時間:[ 2013/1/31 14:20:55 ] 推薦標(biāo)簽:

您可能從編寫 Ajax 應(yīng)用程序中獲得了極大樂趣,但是對它們執(zhí)行單元測試卻著實(shí)讓人頭痛。 在本文中,Andrew Glover 著手解決 Ajax 的弱點(diǎn)(其中之一),即應(yīng)對異步 Web 應(yīng)用程序執(zhí)行單元測試的固有挑戰(zhàn)。幸運(yùn)的是,他發(fā)現(xiàn)在 Google Web Toolkit 的幫助下,解決這個特殊的代碼質(zhì)量問題要比預(yù)想的容易。

Ajax 在近期無疑是 Web 開發(fā)界時髦的字眼之一 —— 與 Ajax 相關(guān)的工具、框架、書籍以及 Web 站點(diǎn)的劇增是該技術(shù)流行的好證明。此外,Ajax 應(yīng)用程序也相當(dāng)靈巧,不是嗎?不過,像任何一個開發(fā)過 Ajax 應(yīng)用程序的人證實(shí)的一樣,對 Ajax 執(zhí)行測試真的很不方便。事實(shí)上,Ajax 的出現(xiàn)已經(jīng)從根本上使得許多測試框架和工具失效,因?yàn)樗鼈儾]有針對異步 Web 應(yīng)用程序測試進(jìn)行設(shè)計(jì)!

有趣的是,某個支持 Ajax 的框架的開發(fā)人員注意到了這個限制,并為此做了一些非常新穎的設(shè)計(jì):內(nèi)置的可測試性。除此之外,由于該框架簡化了使用 Java™ 代碼(而不是 JavaScript)創(chuàng)建 Ajax 應(yīng)用程序,它的起點(diǎn)甚高,并且充分利用了 Java 平臺上無可置疑的標(biāo)準(zhǔn)測試框架:JUnit。

我所論及的框架當(dāng)然是非常流行的 Google Web Toolkit,也是 GWT。在本文中,我將向您展示 GWT 如何實(shí)際地利用 Java 兼容性,使 Ajax 應(yīng)用程序的每個部分都能像與之對應(yīng)的同步應(yīng)用程序一樣進(jìn)行測試。

 

JUnit 和 GWTTestCase

因?yàn)榕c GWT 有關(guān)的 Ajax 應(yīng)用程序采用 Java 代碼編寫,所以非常適合開發(fā)人員使用 JUnit 進(jìn)行測試。事實(shí)上,GWT 開發(fā)小組還為此創(chuàng)建了一個幫助器類 GWTTestCase,擴(kuò)展自 JUnit 的 3.8.1 TestCase。該基類添加了一些功能,可測試 GWT 代碼并處理某些基礎(chǔ)實(shí)現(xiàn)從而啟動并運(yùn)行 GWT 組件。
 
Google Web Toolkit
Google Web Toolkit 在 Java Web 開發(fā)社區(qū)的發(fā)布聲勢浩大,同時也獲得了與之相稱的巨大轟動。GWT 為利用 Java 代碼進(jìn)行設(shè)計(jì)、構(gòu)建和部署支持 Ajax 的 Web 應(yīng)用程序提供了一種新穎的方式。Java Web 開發(fā)人員不再需要學(xué)習(xí) JavaScript 并花費(fèi)數(shù)個小時解決特定于瀏覽器的問題,他們可以直接進(jìn)行與 Ajax 有關(guān)的富含信息的動態(tài) Web 應(yīng)用程序設(shè)計(jì)。

需要提醒的是:GWTTestCase 并非用來測試與 UI 相關(guān)的代碼 —— 它是為了便于測試那些由 UI 交互觸發(fā) 的異步問題。對 GWTTestCase 用途的誤解使許多剛接觸 GWT 的開發(fā)人員備受挫折,因?yàn)樗麄兤谕軌蛴盟奖愕啬M用戶界面,但終發(fā)現(xiàn)這是徒勞的。

Ajax 組件有兩個基本組成:體驗(yàn)和功能,這些都被設(shè)計(jì)成異步方式。圖 1 演示了一個模擬 Web 表單的簡單 Ajax 組件。由于該組件支持 Ajax,表單的提交是異步執(zhí)行的(即:無需重新載入與傳統(tǒng)表單提交關(guān)聯(lián)的頁面)。

圖 1. 一個支持 Ajax 的簡單 Web 表單

輸入一個有效單詞,單擊組件的 Submit 按鈕,將向服務(wù)器發(fā)送消息請求該單詞的定義。該定義通過回調(diào)異步返回,相應(yīng)地插入到 Web 頁面,如圖 2 所示:


圖 2. 單擊 Submit 按鈕后顯示響應(yīng)

功能性和集成測試

圖 2 所示的交互測試可用于多個不同場景,但是其中兩種場景為常見。從功能性觀點(diǎn)考慮,您或許希望編寫一個測試:填入表單值,單擊 Submit 按鈕,然后驗(yàn)證表單是否顯示定義。另外一個選擇是集成測試,使您能夠驗(yàn)證客戶端代碼的異步功能。GWT 的 GWTTestCase 正是被設(shè)計(jì)用來執(zhí)行此類測試。

需要牢記的是:在 GWTTestCase 測試用例環(huán)境下不可以進(jìn)行用戶界面測試。在設(shè)計(jì)和構(gòu)建 GWT 應(yīng)用程序時,您必須清楚不要依賴用戶界面 測試代碼。這種思路需要把交互代碼從業(yè)務(wù)邏輯中分離出來,正如您已經(jīng)了解的,這是佳的入門實(shí)踐!

舉例而言,重新查看圖 1 和圖 2 所示的 Ajax 應(yīng)用程序。該應(yīng)用程序由四個邏輯部分構(gòu)成:TextBox 用于輸入目標(biāo)單詞,Button 用于執(zhí)行單擊,還有兩個 Label(一個用于 TextBox,另一個顯示定義)。實(shí)際 GWT 模塊的初始方法如清單 1 所示,但是您該如何測試這段代碼呢?


清單 1. 一個有效的 GWT 應(yīng)用程序,但是如何測試它?

                public class DefaultModule implements EntryPoint { public void onModuleLoad() {   Button button = new Button("Submit");   TextBox box = new TextBox();   Label output = new Label();   Label label = new Label("Word: ");   HorizontalPanel inputPanel = new HorizontalPanel();   inputPanel.setStyleName("input-panel");   inputPanel.setVerticalAlignment(HasVerticalAlignment.ALIGN_MIDDLE);   inputPanel.add(label);   inputPanel.add(box);   button.addClickListener(new ClickListener() {    public void onclick(Widget sender) {      String word = box.getText();      WordServiceAsync instance = WordService.Util.getInstance();       try {         instance.getDefinition(word, new AsyncCallback() {                      public void onFailure(Throwable error) {             Window.alert("Error oclearcase/" target="_blank" >ccurred:" + error.toString());           }           public void onSuccess(Object retValue) {             output.setText(retValue.toString());           }    });        }catch(Exception e) {          e.printStackTrace();  } }   });   inputPanel.add(button);   inputPanel.setCellVerticalAlignment(button,     HasVerticalAlignment.ALIGN_BOTTOM);   RootPanel.get("slot1").add(inputPanel);   RootPanel.get("slot2").add(output);   }} 


清單 1 的代碼在運(yùn)行時發(fā)生了嚴(yán)重的錯誤:它無法按照 JUnit 和 GWT 的 GWTTestCase 進(jìn)行測試。事實(shí)上,如果我試著為這段代碼編寫測試,從技術(shù)方面來說它可以運(yùn)行,但是無法按照邏輯工作?紤]一下:您如何對這段代碼進(jìn)行驗(yàn)證?惟一可用于測試的 public 方法返回的是 void, 那么,您怎么能夠驗(yàn)證其功能的正確性呢?

如果我想以白盒方式驗(yàn)證這段代碼,必須分離業(yè)務(wù)邏輯和特定于用戶界面的代碼,這需要進(jìn)行重構(gòu)。這本質(zhì)上意味著把清單 1 中的代碼分離到一個便于測試的獨(dú)立方法中。但是這并非聽上去那么簡單。很明顯組件掛鉤是通過 onModuleLoad() 方法實(shí)現(xiàn),但是如果我想強(qiáng)制其行為,可能 必須操縱某些用戶界面(UI)組件。

軟件測試工具 | 聯(lián)系我們 | 投訴建議 | 誠聘英才 | 申請使用列表 | 網(wǎng)站地圖
滬ICP備07036474 2003-2017 版權(quán)所有 上海澤眾軟件科技有限公司 Shanghai ZeZhong Software Co.,Ltd