隨心蕓蕓 @ JPeanut(舊版)

          搬遷至 http://www.17m.net.cn/

          BlogJava 首頁 新隨筆 聯(lián)系 聚合 管理
            43 Posts :: 0 Stories :: 54 Comments :: 0 Trackbacks


          作者:陳市明/Slipper Feng 摘自:http://www.aygfsteel.com/JPeanut

          J2EE 是目前公認的比較慢的一種開發(fā),相比 .net php asp 等而言。其實, j2ee 的開發(fā)者都深有體會的, java 代碼編寫的速度其實并不慢,在 eclipse jbuilder 等可視化界面的幫助下,編寫代碼變的越來越簡單;但是在調(diào)試的時候,每改完一個 java 或者 xml 代碼要預(yù)覽改的效果的話,必須要重新構(gòu)建,部署,重啟服務(wù)器 , 這些動作反反復(fù)復(fù),消耗的時間不少。

          近期為公司寫了個單元測試的框架,基本上解決了反反復(fù)復(fù)構(gòu)建,部署,重啟服務(wù)器的問題。我們的項目的都是運用了類似 struts spring hibernate MVC 架構(gòu)(下面簡稱 ssh ),不同的就是中間的 aop 是自己開發(fā)實現(xiàn)的,而沒有運用 spring 的。不過,我們的單元測試框架對標準的 struts spring hibernate 支持也挺好。

          STRUTS原理圖.JPG

          上面的是在 ssh 的一次交互的原理圖,做過 struts 開發(fā)者都會很熟悉。首先,是 jsp 通過 submit url 將表單數(shù)據(jù)提交給后臺 action servlet ,后臺通過在 struts-config.xml 中的配置找到相關(guān)的××× Action ,然后通過××× Service ,××× Dao 操作數(shù)據(jù)庫,再將數(shù)據(jù)返回給另外一個 jsp ,讓他顯示結(jié)果。

          模擬STRUTS的單元測試模擬圖.JPG


          上面的圖是我們單元測試框架實現(xiàn)構(gòu)建,部署,重啟服務(wù)器的原理圖。我們很容易從圖上看的出來,我們寫了個 Test ××× Action 來模擬 2 jsp 的動作,該類分成 2 部分上面一部分是模擬了 jsp 頁面 submit 的動作(包括模擬提交給 url ,模擬提交數(shù)據(jù)),下面一部分是接收××× Action 返回的數(shù)據(jù),然后,進行校驗(此處的校驗,我們用了 junit 的斷言功能)。通過用 java 類來模擬 jsp 的好處在于,我們可以完全把這個一個交互作為一個 application 來運行起來,非常容易的做到單步調(diào)試,而不用到真實的平臺上,啟動服務(wù)器上運行。(注:此處有 2 db :開發(fā) db 和測試 db ,這個再以后的介紹中會講到)

          我們還為在這個架構(gòu)上開發(fā)制定了流程:

          1 把當(dāng)天需要開發(fā)的模塊的 java 代碼全部些好

          2 通過這種模式調(diào)試 java 代碼

          3 在確保這些 java 代碼無誤后,構(gòu)建,部署,啟動服務(wù)器

          4 然后編寫所有的 jsp (因為修改 jsp 無需啟動服務(wù)器)

          這樣,在開發(fā)一天的所有代碼,幾乎都不用怎么重啟服務(wù)器,可以為開發(fā)人員省下很多時間,也使得開發(fā)人員喜歡的單步調(diào)試變的異常簡單,提高代碼的質(zhì)量。

          我們已經(jīng)在真實的項目中實施了該流程的開發(fā),得到的效果和預(yù)期的一樣。當(dāng)然還是比不過其他語言的開發(fā),不過我們的架構(gòu)還在不斷改進(通過改進流程、編寫 eclipse 等開發(fā)工具的插件等方法),使我們的開發(fā)人員可以更加快的進行 j2ee 的開發(fā)。


          posted on 2006-04-18 23:04 陳市明 閱讀(2793) 評論(9)  編輯  收藏 所屬分類: 基于j2ee單元測試框架介紹

          Feedback

          # re: 基于j2ee單元測試框架介紹之一-調(diào)試無需啟動中間件 2006-04-19 08:54 charon@xxx
          兄弟,你們公司是不是閉門造車很久了???  回復(fù)  更多評論
            

          # re: 基于j2ee單元測試框架介紹之一-調(diào)試無需啟動中間件 2006-04-19 21:39 葉子
          寫得形象易懂,有針對性.贊!  回復(fù)  更多評論
            

          # re: 基于j2ee單元測試框架介紹之一-調(diào)試無需啟動中間件 2006-04-20 12:50
          同意樓上觀點,寫得8錯,挺有思想的!赫赫!  回復(fù)  更多評論
            

          # re: 基于j2ee單元測試框架介紹之一-調(diào)試無需啟動中間件 2006-04-20 16:28 小陸
          業(yè)務(wù)層應(yīng)該初一dao和service層之間。
          單元測試的重點應(yīng)該在業(yè)務(wù)層上。

          從你的圖上,我沒看見業(yè)務(wù)層。  回復(fù)  更多評論
            

          # re: 基于j2ee單元測試框架介紹之一-調(diào)試無需啟動中間件 2006-04-20 19:17 陳市明
          @小陸
          恩,單元測試重點在業(yè)務(wù)層面,我現(xiàn)在是通過action去調(diào)用到后臺的業(yè)務(wù)層,所有的測試都是在action層面的。我這樣做的目的使為了讓單元測試做到功能測試的效果(呵呵,我使測試組成員,當(dāng)然要減輕自己的工作量)。
          其實,我這樣做,通過代碼覆蓋率報告一樣可以做到業(yè)務(wù)層的 測試,只是對業(yè)務(wù)層的容錯出來還是很難測試到。  回復(fù)  更多評論
            

          # re: 基于j2ee單元測試框架介紹之一-調(diào)試無需啟動中間件 2006-04-25 14:43 廣州大盜
          創(chuàng)新的精神值得學(xué)習(xí)。
          但一個問題是, 你們的系統(tǒng)似乎沒有使用ejb。
          如果使用ejb會怎么處理,主要是容器負責(zé)的事務(wù)等。

             正如你說的,你是testor; 而且我注意到你們的流程第一點:1 把當(dāng)天需要開發(fā)的模塊的 java 代碼全部些好。所以 我的感覺是,這只是對測試人員來說,不用頻繁部署和重啟服務(wù)器; 而且“不用”的原因是:一天只部署一次,你看我說的對嗎?
             所以,你講的測試框架對來說coder并不適用。

            回復(fù)  更多評論
            

          # re: 基于j2ee單元測試框架介紹之一-調(diào)試無需啟動中間件 2006-04-25 19:40 陳市明
          @廣州大盜
          呵呵,我們的項目的確是沒有ejb的,,所以框架目前沒有對ejb提供功能..但是,,并不是說完全沒有辦法..框架可以再'"基于j2ee單元測試框架介紹之二'"中可以看到,,框架有自己的插件協(xié)議,只要按照這個協(xié)議編寫,,完全不用修改原來的代碼,,久可以添加很多功能..,,當(dāng)然也可以直接把junit的擴展封裝下作為我們的插件用,,相信關(guān)于ejb的我們還是可以做到的..公司之前大家都認識很難解決的jms的問題也通過自己的編寫jms插件來解決了..
          對于事務(wù),,我們的項目中都用jta的,,這個在這個框架中,,我們也通過編寫了jta的模擬的transtraction,,在aop容器在內(nèi)存中直接替換成我們的transation的了..雖然還是有點問題的,,但是還是解決這樣的問題了..  回復(fù)  更多評論
            

          # re: 基于j2ee單元測試框架介紹之一-調(diào)試無需啟動中間件 2006-06-04 10:07 Slipper Feng
          就要答辯了,緊張!  回復(fù)  更多評論
            

          # re: 基于j2ee單元測試框架介紹之一-調(diào)試無需啟動中間件 2006-06-05 23:51 陳市明
          呵呵,沒關(guān)系的哈,我來保駕  回復(fù)  更多評論
            

          主站蜘蛛池模板: 临清市| 武汉市| 玉山县| 西丰县| 登封市| 衡南县| 桃源县| 襄樊市| 郁南县| 临泉县| 潢川县| 乡宁县| 深州市| 合江县| 东阿县| 吉木乃县| 澎湖县| 柘城县| 台湾省| 永泰县| 石屏县| 哈尔滨市| 昂仁县| 伊春市| 丹江口市| 罗城| 武强县| 福清市| 菏泽市| 阳信县| 兴业县| 万盛区| 康乐县| 福海县| 正安县| 丰城市| 深州市| 阿勒泰市| 永靖县| 泰安市| 东乡县|