| Cactus簡(jiǎn)介 . 簡(jiǎn)介 Cactus實(shí)現了對JUnit測試框架的無(wú)縫擴展,可以方便地測試服務(wù)端應用程序。Cactus可以在下面幾種情況下使用: 測試Servlet以及任何使用了像HttpServletRequest,HttpServletResponse,……這樣的對象的代碼。使用ServletTestCase。 測試Filter以及任何使用了像FilterConfig,……這樣的對象的代碼。使用FilterTestCase。 測試JSP 。使用ServletTestCase或JspTestCase。 測試Taglibs以及任何使用了像PageContext,……這樣的對象的代碼。使用JspTestCase。 測試EJB。ServletTestCase或JspTestCase或FilterTestCase。 Cactus的使用也是非常簡(jiǎn)單的,你寫(xiě)的測試類(lèi)只需繼承ServletTestCase或者JspTestCase、FilterTestCase(它 們都繼承了JUnit的TestCase)。寫(xiě)好測試代碼后需要啟動(dòng)web容器,然后執行測試代碼。在下面的章節中我們將通過(guò)例子向你詳細講解。 Cactus項目Apache Jakarta Commons的一個(gè)子項目,網(wǎng)址是:[url]http://jakarta.apache.org/commons/cactus/[/url]。 . TestCase框架 在Cactus下,我們寫(xiě)的TestCase與JUnit有所不同,先看一段代碼,如下: public class TestSample extendsServletTestCase/JspTestCase/FilterTestCase { public TestSample (String testName) { super(testName); } public void setUp() { } public void tearDown() { } public void beginXXX(WebRequest theRequest) { } public void testXXX() { } public void endXXX(WebResponse theResponse) { } 上面是一個(gè)Cactus測試類(lèi)的完整代碼框架,其中的extends部分需要按你所測試的不同目標來(lái)繼承不同的類(lèi)(簡(jiǎn)介中有所描述)。 另外我們注意到兩個(gè)新的方法beginXXX和endXXX的,這兩個(gè)方法分別會(huì )在testXXX執行前和執行后執行,它們和setUp、 tearDown不同的是beginXXX和endXXX會(huì )在相應的testXXX前執行,而setUp和tearDown則在每個(gè)testXXX方法前 都會(huì )執行。另外beginXXX和endXXX是客戶(hù)端代碼,所以在這兩個(gè)方法里是無(wú)法使用request這樣的服務(wù)端對象的。 對于endXXX方法需要另加說(shuō)明的是,在Cactus v1.1前(包括v1.1),它的形式是這樣的public void endXXX(HttpURLConnection theConnection),而在Cactus v1.2開(kāi)始它的形式有兩種可能: public void endXXX(org.apache.cactus.WebResponse theResponse); public void endXXX(com.meterware.httpunit.WebResponse theResponse); 可以看到區別在于引用的包不同,為什么會(huì )這樣的呢?因為在v1.2開(kāi)始Cactus集成了HttpUnit這個(gè)組件。如果你熟悉HttpUnit這個(gè)組件,我想應該明白為什么要集成HttpUnit。下面我們來(lái)看一段代碼開(kāi)比較一下兩者的區別: public void endXXX(org.apache.cactus.WebResponse theResponse) { String content = theResponse.getText(); assertEquals(content, "<html><body><h1>Hello world!</h1></body></html>"); } public void endXXX(com.meterware.httpunit.WebResponse theResponse) { WebTable table = theResponse.getTables()[0]; assertEquals("rows", 4, table.getRowCount()); assertEquals("columns", 3, table.getColumnCount()); assertEquals("links", 1, table.getTableCell(0, 2).getLinks().length); } 當然,在實(shí)際應用中你需要根據不同的需要來(lái)選擇不同的endXXX。兩個(gè)WebResponse的差別可以參見(jiàn)兩者各自的API Doc,這里就不再多說(shuō)了。 如何在Cactus里寫(xiě)測試 . 寫(xiě)測試代碼 首先,我們給出被測類(lèi)的代碼,是一個(gè)Servlet: public class SampleServlet extends HttpServlet { public void doGet(HttpServletRequest theRequest, HttpServletResponse theResponse) throws IOException { PrintWriter pw = theResponse.getWriter(); theResponse.setContentType("text/html"); pw.print("<html><head/><body>"); pw.print("A GET request"); pw.print("</body></html>"); } public String checkMethod(HttpServletRequest theRequest) { return theRequest.getMethod(); } } Cactus中的測試類(lèi)框架已經(jīng)在上面給出。下面來(lái)看一下例子,例子是從中Cactus自帶的實(shí)例中抽取的一部分,如下: public class TestSampleServlet extends ServletTestCase { public void testReadServletOutputStream() throws IOException { SampleServlet servlet = new SampleServlet(); servlet.doGet(request, response); } public void endReadServletOutputStream(WebResponse theResponse) throws IOException { String expected = "<html><head/><body>A GET request</body></html>"; String result = theResponse.getText(); assertEquals(expected, result); } public void beginPostMethod(WebRequest theRequest) { theRequest.addParameter("param", "value", WebRequest.POST_METHOD); } public void testPostMethod() { SampleServlet servlet = new SampleServlet(); assertEquals("POST", servlet.checkMethod(request)); assertEquals("value", request.getParameter("param")); } } 第一個(gè)方法testReadServletOutputStream,調用doGet,相當于在客戶(hù)端提交請求,然后在Servlet處理后會(huì )產(chǎn)生一個(gè)回 饋,所以,在endReadServletOutputStream方法里,我們通過(guò)調用response的相應方法判斷回饋是否符合預期結果。 第二個(gè)方法testPostMethod,在這之前有一個(gè)beginPostMethod,在這個(gè)方法里我們以POST方式往request里增加一個(gè)表 單數據param,值為”value”。下面在testPostMethod我們就要驗證表單數據是否以POST方式提交到了服務(wù)端的Servlet里, 所以,我們看到了兩個(gè)assertEquals,分別進(jìn)行了判斷。在這里我們要注意到beginPostMethod方法中的theRequest和 testPostMethod中的request的區別,在前面我們已經(jīng)提到過(guò),beginPostMethod是在客戶(hù)端執行的,所以它方法內的所有操 作事實(shí)上是模擬頁(yè)面操作的,比如上面的設置表單數據,而testPostMethod是服務(wù)端執行的,其中的request也是服務(wù)端的。 配置cactus.properties和web.xml cactus.properties cactus.contextURL 這個(gè)屬性是必須的,它指定了web應用的訪(fǎng)問(wèn)地址 例:cactus.contextURL = [url]http://localhost:8080/test[/url] cactus.servletRedirectorName 可選,當測試類(lèi)繼承ServletTestCase時(shí)用于指定Cactus Servlet Redirector的映射名稱(chēng)。默認:ServletRedirector 例:cactus.servletRedirectorName = ServletRedirector cactus.jspRedirectorName 可選,當測試類(lèi)繼承ServletTestCase時(shí)用于指定Cactus Jsp Redirector的映射名稱(chēng)。默認:ServletRedirector 例:cactus.jspRedirectorName = JspRedirector cactus.filterRedirectorName (For J2EE API 1.3 only) 可選,當測試類(lèi)繼承ServletTestCase時(shí)用于指定Cactus Filter Redirector的映射名稱(chēng)。默認:ServletRedirector 例:cactus.filterRedirectorName = FilterRedirector Cactus.properties你可以放置在WEB-INF/classes/下。 web.xml 在web.xml里要為相應的測試類(lèi)指定相應的Cactus Redirector。 ServletTestCase對應org.apache.cactus.server.ServletTestRedirector JspTestCase對應/jspRedirector.jsp FilterTestCase對應org.apache.cactus.server.FilterTestRedirector <web-app> <filter> <filter-name>FilterRedirector</filter-name> <filter-class>org.apache.cactus.server.FilterTestRedirector</filter-class> </filter> <filter-mapping> <filter-name>FilterRedirector</filter-name> <url-pattern>/FilterRedirector</url-pattern> </filter-mapping> <servlet> <servlet-name>ServletRedirector</servlet-name> <servlet-class>org.apache.cactus.server.ServletTestRedirector</servlet-class> </servlet> <servlet> <servlet-name>JspRedirector</servlet-name> <jsp-file>/jspRedirector.jsp</jsp-file> </servlet> <servlet-mapping> <servlet-name>ServletRedirector</servlet-name> <url-pattern>/ServletRedirector</url-pattern> </servlet-mapping> <servlet-mapping> <servlet-name>JspRedirector</servlet-name> <url-pattern>/JspRedirector</url-pattern> </servlet-mapping> </web-app> 如果你的測試類(lèi)繼承了JspTestCase則需要將jspRedirector.jsp文件放置到你在web.xml中指定的路徑里。 安裝說(shuō)明 在使用Cactus時(shí),strutstest.jar還需要有下列包的支持。包可放置在WEB-INF/lib下 如下: Client端,需要如下包 junit.jar servlet.jar cactus.jar httpclient.jar commons-logging.jar httpunit.jar,Tidy.jar,xerces.jar(可選,如果你集成了httpunit的話(huà)就需要,也就是在endXXX中使用了httpunit) Server端(也就是web容器)需要如下包 cactus.jar junit.jar aspectjrt.jar commons-logging.jar 寫(xiě)好測試代碼后將class放置在WEB-INF/classes下 被測代碼也放置在WEB-INF/classes下 寫(xiě)好cactus.properties和web.xml兩個(gè)配置文件 啟動(dòng)web容器 運行測試代碼 |
聯(lián)系客服