StrutsTest使用简明手册
2004-06-27 18:51
447 查看
Struts是目前在web开发中广泛使用的几个框架之一,而StrutsTest正是专门负责测试strut应用程序的Mock测试框架。<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />
} public void setUp(){ super.setUp();
//指明web应用的根
File contextFile = new File("D://Projects//fog//implement//web"); setContextDirectory(contextFile);
} protected void tearDown() throws Exception { super.tearDown();
} public void testDoAdd() { //设置action的path setRequestPathInfo("/dpEdit"); //准备action所需要的formbean的参数 addRequestParameter("method", "doAdd"); addRequestParameter("pageId", "1"); addRequestParameter("dpname","测试部门"); addRequestParameter("dptype","测试部门"); addRequestParameter("yn","n"); //执行action actionPerform(); //验证返回的forward verifyForward("success");
} 3. 主要函数和作用: - setContextDirectory,设置web应用的根 - setRequestPathInfo,设置request的请求 - addRequestParameter,将参数和对应的值加入request中 - actionPerform,执行这个请求 - verifyForward,验证forward的名字是否正确 - verifyForwardPath,验证forward的path是否正确 - verifyNoActionErrors,验证在action执行过程中没有ActionError产生 - verifyActionErrors,验证在action执行过程中产生的ActionError集合的内容 具体详细的内容请参见对应的javaDoc。 4. 测试Tile。其基本过程与上面类似,不同之处在于验证:使用verifyTilesForward和verifyInputTilesForward。
5. 测试子模块。其基本过程也和上面一样,不同之处在于需要指定该模块所需要使用的struts-config.xml和调用方式: - 首先,指定所需要的struts-config.xml: setConfigFile("mymodule","/WEB-INF/struts-config-mymodule.xml");
- 其次,指明调用的路径: setRequestPathInfo("/mymodule","/login.do");
使用目的
StrtusTest是junit的扩展,使用它,不需要启动servlet容器就可以方便的测试struts应用程序(容器外测试)。它也是属于使用Mock对象测试,但是与EasyMock不同的是,EasyMock是提供了创建Mock对象的API,而StrutsTest则是专门负责测试Struts应用程序的Mock对象测试框架。除了容器外测试,StrutsTest也可以很方便的用容器内的测试。 当前的版本是StrutsTest2.1.0,在这个版本中不支持Struts1.0。如果需要测试struts1.0的应用程序,对应的版本是StrutsTest2.0。可以从http://sourceforge.net/projects/strutstestcase/下载。用法
1. 基本步骤: - 书写struts action。 - 确定需要进行测试的方式:Mock对象则选用MockStrutsTestCase作为基类;Cactus方式则选用CactusStrutsTestCase;这两种方式以下的步骤都是一样的。 - 使用setUp和tearDown进行初始化,明确这两个函数的第一句话是调用super的方法。 - 设置要测试的struts action的路径,方便strutstest能找到web.xml和struts相关的配置文档。 - 设置action在strtus-config.xml中对应的path名称。 - 设置action需要使用的各个参数值到request对象中,包括action所使用的formbean的值。 - 执行action。 - 验证action的返回路径是否正确,即forward的名字。 - 验证action相关的其余部分。 2. 使用例子(采用Mock方式): public class DeparmentDBActionTest extends MockStrutsTestCase { public DeparmentDBActionTest(String arg0) { super(arg0);} public void setUp(){ super.setUp();
//指明web应用的根
File contextFile = new File("D://Projects//fog//implement//web"); setContextDirectory(contextFile);
} protected void tearDown() throws Exception { super.tearDown();
} public void testDoAdd() { //设置action的path setRequestPathInfo("/dpEdit"); //准备action所需要的formbean的参数 addRequestParameter("method", "doAdd"); addRequestParameter("pageId", "1"); addRequestParameter("dpname","测试部门"); addRequestParameter("dptype","测试部门"); addRequestParameter("yn","n"); //执行action actionPerform(); //验证返回的forward verifyForward("success");
} 3. 主要函数和作用: - setContextDirectory,设置web应用的根 - setRequestPathInfo,设置request的请求 - addRequestParameter,将参数和对应的值加入request中 - actionPerform,执行这个请求 - verifyForward,验证forward的名字是否正确 - verifyForwardPath,验证forward的path是否正确 - verifyNoActionErrors,验证在action执行过程中没有ActionError产生 - verifyActionErrors,验证在action执行过程中产生的ActionError集合的内容 具体详细的内容请参见对应的javaDoc。 4. 测试Tile。其基本过程与上面类似,不同之处在于验证:使用verifyTilesForward和verifyInputTilesForward。
5. 测试子模块。其基本过程也和上面一样,不同之处在于需要指定该模块所需要使用的struts-config.xml和调用方式: - 首先,指定所需要的struts-config.xml: setConfigFile("mymodule","/WEB-INF/struts-config-mymodule.xml");
- 其次,指明调用的路径: setRequestPathInfo("/mymodule","/login.do");
检查表
使用StrutsTest需要注意的地方: - 在TestCase中可以访问request、session等对象,StrutsTest为我们提供了访问接口。 - junit的assert函数和fail函数都可以在StrutsTest中使用。 - 对于文件上载,目前StrutsTest并没有什么特别好的方案。具体参见StrusTest的Faq。相关文章推荐
- StrutsTest使用简明手册
- StrutsTest使用简明手册
- 在Struts中使用Tiles简明手册
- 在Struts中使用Tiles简明手册
- StrutsTest使用手册
- 正则表达式简明使用手册
- junit使用简明手册
- WEB打印PAZU控件-简明使用手册
- RMAN简明使用手册[转载]
- Selenium简明使用手册(二)——运行TestRunner
- WinCVS与CVSNT简明使用手册
- Struts2+Spring的UnitTest编写(使用StrutsTestCase的子类StrutsSpringTestCase)
- 正则表达式简明使用手册
- EasyMock使用简明手册
- Radasm使用简明手册(中文版)
- JunitPerf使用简明手册
- Junit使用简明手册
- Log4net 使用简明手册[转]
- openssl简明使用手册
- 在使用struts标签时,把<s:if>中的test写成了text