开发web工程时,单元测试DAO层方法有时候不是很方便。因为需要连接数据,如果通过页面请求测试,不但效率低,遇上逻辑复杂还要绕上一大圈才可能进入这个方法时就更麻烦了。这里介绍一种在jboss(这里用的版本是4.2)下不用启动jboss便可测试DAO方法的方案。
主要借助一个测试包jrunittesthelper.jar.在web工程根目录下配置一个定义数据库参数的文件,比如junittest.properties
文件内容如下:是不是和平时配置数据库连接是一样的。
好,下来是一个简单例子。
现在就可以不启动web容器,测试自己的WEB工程了.
主要借助一个测试包jrunittesthelper.jar.在web工程根目录下配置一个定义数据库参数的文件,比如junittest.properties
文件内容如下:
- com.javaranch.unittest.helper.sql.pool.JNDIName=java:/OracleDS //jboss里自定义的数据源名称
- com.javaranch.unittest.helper.sql.pool.dbDriver=oracle.jdbc.driver.OracleDriver //采用的数据库驱动
- com.javaranch.unittest.helper.sql.pool.dbServer=jdbc:oracle:thin:@192.168.1.5:1433:test//数据库连接串
- com.javaranch.unittest.helper.sql.pool.dbLogin=usname //数据库用户名
- com.javaranch.unittest.helper.sql.pool.dbPassword=123 //数据库密码
好,下来是一个简单例子。
- package test;
- import junit.framework.TestCase;
- import org.hibernate.Session;
- import com.javaranch.unittest.helper.sql.pool.JNDIUnitTestHelper;
- public abstract class DAOTest extends TestCase {
- @Override
- protected void setUp() throws Exception {
- super.setUp();
- if(JNDIUnitTestHelper.notInitialized()){
- JNDIUnitTestHelper.init("junittest.properties");//从配置文件读取数据相关参数
- }
- }
- @Test
- public void testGetDkp() {
- MyDAO dao = MyDAOFactory.get...();
- dao.getAllProduct();
- ......
- }
- @Override
- protected void tearDown() throws Exception {
- super.tearDown();
- }
- }
这篇博客介绍了一个简单的JUnit测试Web工程中DAO的方法。首先配置了数据源的详细信息,包括JNDI名、数据库驱动、连接串、用户名和密码。然后创建了一个抽象的DAOTest类,继承自TestCase,在setUp方法中初始化数据源,使用JNDIUnitTestHelper读取配置文件参数。测试用例中展示了如何获取DAO实例并调用方法进行测试。
759

被折叠的 条评论
为什么被折叠?



